| Class-MOP documentation | Contained in the Class-MOP distribution. |
Class::MOP::Method::Generated - Abstract base class for generated methods
This is a Class::MOP::Method subclass which is subclassed by
Class::MOP::Method::Accessor and
Class::MOP::Method::Constructor.
It is not intended to be used directly.
Stevan Little <stevan@iinteractive.com>
Copyright 2006-2010 by Infinity Interactive, Inc.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| Class-MOP documentation | Contained in the Class-MOP distribution. |
package Class::MOP::Method::Generated; use strict; use warnings; use Carp 'confess'; our $VERSION = '1.12'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use base 'Class::MOP::Method'; ## accessors sub new { confess __PACKAGE__ . " is an abstract base class, you must provide a constructor."; } sub is_inline { $_[0]{is_inline} } sub definition_context { $_[0]{definition_context} } sub _initialize_body { confess "No body to initialize, " . __PACKAGE__ . " is an abstract base class"; } sub _eval_closure { my ($self, $__captures, $sub_body) = @_; my $code; my $e = do { local $@; local $SIG{__DIE__}; my $source = join "\n", ( map { /^([\@\%\$])/ or die "capture key should start with \@, \% or \$: $_"; q[my ] . $_ . q[ = ] . $1 . q[{$__captures->{'] . $_ . q['}};]; } keys %$__captures ), $sub_body; $self->_dump_source($source) if $ENV{MOP_PRINT_SOURCE}; $code = eval $source; $@; }; return ( $code, $e ); } sub _dump_source { my ( $self, $source ) = @_; my $output; if ( eval { require Perl::Tidy } ) { require File::Spec; my $rc_file = File::Spec->catfile( $INC{'Class/MOP/Method/Generated.pm'}, ('..') x 5, 'perltidyrc' ); my %p = ( source => \$source, destination => \$output, ); $p{perltidyrc} = $rc_file if -f $rc_file; Perl::Tidy::perltidy(%p); } else { $output = $source; } print STDERR "\n", $self->name, ":\n", $output, "\n"; } sub _add_line_directive { my ( $self, %args ) = @_; my ( $line, $file ); if ( my $ctx = ( $args{context} || $self->definition_context ) ) { $line = $ctx->{line}; if ( my $desc = $ctx->{description} ) { $file = "$desc defined at $ctx->{file}"; } else { $file = $ctx->{file}; } } else { ( $line, $file ) = ( 0, "generated method (unknown origin)" ); } my $code = $args{code}; # if it's an array of lines, join it up # don't use newlines so that the definition context is more meaningful $code = join(@$code, ' ') if ref $code; return qq{#line $line "$file"\n} . $code; } sub _compile_code { my ( $self, %args ) = @_; my $code = $self->_add_line_directive(%args); return $self->_eval_closure($args{environment}, $code); } 1; __END__