return $METAS{$role} if exists $METAS{$role};
# make a subtype for each Moose class
- subtype $role
- => as 'Role'
- => where { Moose::Util::does_role($_, $role) }
- => optimize_as { blessed($_[0]) && Moose::Util::does_role($_[0], $role) }
- unless find_type_constraint($role);
+ role_type $role unless find_type_constraint($role);
my $meta;
if ($role->can('meta')) {
$meta->add_around_method_modifier($_, $code) for @_;
};
},
+ # see Moose.pm for discussion
super => sub {
- {
- no strict 'refs';
- $Moose::SUPER_SLOT{$CALLER} = \*{"${CALLER}::super"};
- }
- my $meta = _find_meta();
- return subname 'Moose::Role::super' => sub {};
+ return subname 'Moose::Role::super' => sub { return unless $Moose::SUPER_BODY; $Moose::SUPER_BODY->(@Moose::SUPER_ARGS) }
},
+ #next => sub {
+ # return subname 'Moose::Role::next' => sub { @_ = @Moose::SUPER_ARGS; goto \&next::method };
+ #},
override => sub {
my $meta = _find_meta();
return subname 'Moose::Role::override' => sub ($&) {
&& defined $_[1]->{into_level} ? caller( $_[1]->{into_level} )
: caller();
+ # this works because both pragmas set $^H (see perldoc perlvar)
+ # which affects the current compilation - i.e. the file who use'd
+ # us - which is why we don't need to do anything special to make
+ # it affect that file rather than this one (which is already compiled)
strict->import;
warnings->import;