X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FMethod%2FGenerated.pm;h=1e35f76d19459331f73950f2f5d2c5a619ce5249;hb=cfde7a47afcc5ceef67837c8a463aac89b5b955f;hp=dcb2721ca33a050464c49bbfd90fb00fa215cdc5;hpb=e7a64dadc404e79eef5d2524905292f82968e1c4;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Method/Generated.pm b/lib/Class/MOP/Method/Generated.pm index dcb2721..1e35f76 100644 --- a/lib/Class/MOP/Method/Generated.pm +++ b/lib/Class/MOP/Method/Generated.pm @@ -6,38 +6,18 @@ use warnings; use Carp 'confess'; -our $VERSION = '0.77'; +our $VERSION = '0.78'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use base 'Class::MOP::Method'; -sub new { - my $class = shift; - my %options = @_; - - ($options{package_name} && $options{name}) - || confess "You must supply the package_name and name parameters $Class::MOP::Method::UPGRADE_ERROR_TEXT"; - - my $self = $class->_new(\%options); - - $self->initialize_body; - - return $self; -} - -sub _new { - my $class = shift; - my $options = @_ == 1 ? $_[0] : {@_}; - - $options->{is_inline} ||= 0; - $options->{body} ||= undef; +## accessors - bless $options, $class; +sub new { + confess __PACKAGE__ . " is an abstract base class, you must provide a constructor."; } -## accessors - sub is_inline { $_[0]{is_inline} } sub definition_context { $_[0]{definition_context} } @@ -49,8 +29,6 @@ sub initialize_body { sub _eval_closure { # my ($self, $captures, $sub_body) = @_; my $__captures = $_[1]; - - local $@; eval join( "\n", ( @@ -67,7 +45,6 @@ sub _eval_closure { ), $_[2] ); - die $@ if $@; } sub _add_line_directive { @@ -152,7 +129,7 @@ Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE -Copyright 2006-2008 by Infinity Interactive, Inc. +Copyright 2006-2009 by Infinity Interactive, Inc. L