package Mouse::Meta::Method::Destructor;
-use strict;
-use warnings;
-
-sub generate_destructor_method_inline {
- my ($class, $meta) = @_;
-
- my $demolishall = do {
- if ($meta->name->can('DEMOLISH')) {
- my @code = ();
- for my $class ($meta->linearized_isa) {
- no strict 'refs';
- if (*{$class . '::DEMOLISH'}{CODE}) {
- push @code, "${class}::DEMOLISH(\$self);";
- }
- }
- join "\n", @code;
- } else {
- return sub { }; # no demolish =)
+use Mouse::Util qw(:meta); # enables strict and warnings
+
+sub _empty_DESTROY{ }
+
+sub _generate_destructor{
+ my (undef, $metaclass) = @_;
+
+ if(!$metaclass->name->can('DEMOLISH')){
+ return \&_empty_DESTROY;
+ }
+
+ my $demolishall = '';
+ for my $class ($metaclass->linearized_isa) {
+ if (Mouse::Util::get_code_ref($class, 'DEMOLISH')) {
+ $demolishall .= "${class}::DEMOLISH(\$self);\n";
}
- };
+ }
- my $code = <<"...";
+ my $source = sprintf("#line %d %s\n", __LINE__, __FILE__) . <<"...";
sub {
my \$self = shift;
- $demolishall;
+ local \$?;
+
+ my \$e = do{
+ local \$@;
+ eval{
+ $demolishall;
+ };
+ \$@;
+ };
+ no warnings 'misc';
+ die \$e if \$e; # rethrow
}
...
- local $@;
- my $res = eval $code;
- die $@ if $@;
- return $res;
+ my $code;
+ my $e = do{
+ local $@;
+ $code = eval $source;
+ $@;
+ };
+ die $e if $e;
+ return $code;
}
1;
+__END__
+
+=head1 NAME
+
+Mouse::Meta::Method::Destructor - A Mouse method generator for destructors
+
+=head1 VERSION
+
+This document describes Mouse version 0.49
+
+=head1 SEE ALSO
+
+L<Moose::Meta::Method::Destructor>
+
+=cut