my $args = $class->BUILDARGS(@_);
- my $instance = Mouse::Meta::Class->initialize($class)->new_object($args);
- $instance->BUILDALL($args);
- return $instance;
-}
-
-sub BUILDARGS {
- my $class = shift;
+ my $meta = Mouse::Meta::Class->initialize($class);
+ my $self = $meta->new_object($args);
- if (scalar @_ == 1) {
- (ref($_[0]) eq 'HASH')
- || $class->meta->throw_error("Single parameters to new() must be a HASH ref");
+ # BUILDALL
+ if( $self->can('BUILD') ) {
+ for my $class (reverse $meta->linearized_isa) {
+ my $build = Mouse::Util::get_code_ref($class, 'BUILD')
+ || next;
- return {%{$_[0]}};
- }
- else {
- return {@_};
+ $self->$build($args);
+ }
}
+
+ return $self;
}
sub DESTROY {
my $self = shift;
+ return unless $self->can('DEMOLISH'); # short circuit
+
local $?;
my $e = do{
local $@;
eval{
- $self->DEMOLISHALL();
+
+ # DEMOLISHALL
+
+ # We cannot count on being able to retrieve a previously made
+ # metaclass, _or_ being able to make a new one during global
+ # destruction. However, we should still be able to use mro at
+ # that time (at least tests suggest so ;)
+
+ foreach my $class (@{ Mouse::Util::get_linear_isa(ref $self) }) {
+ my $demolish = Mouse::Util::get_code_ref($class, 'DEMOLISH')
+ || next;
+
+ $self->$demolish();
+ }
};
$@;
};
return unless $self->can('BUILD');
for my $class (reverse $self->meta->linearized_isa) {
- my $build = do{
- no strict 'refs';
- no warnings 'once';
- *{ $class . '::BUILD' }{CODE};
- } or next;
+ my $build = Mouse::Util::get_code_ref($class, 'BUILD')
+ || next;
$self->$build(@_);
}
# that time (at least tests suggest so ;)
foreach my $class (@{ Mouse::Util::get_linear_isa(ref $self) }) {
- my $demolish = do{
- no strict 'refs';
- no warnings 'once';
- *{ $class . '::DEMOLISH'}{CODE};
- } or next;
+ my $demolish = Mouse::Util::get_code_ref($class, 'DEMOLISH')
+ || next;
$self->$demolish();
}
=head1 VERSION
-This document describes Mouse version 0.39
+This document describes Mouse version 0.40_05
=head1 METHODS