From 5ea3d7d61698e071b8bebfb39ba8eafa9a5e8262 Mon Sep 17 00:00:00 2001 From: franck cuny Date: Thu, 4 Mar 2010 06:16:58 +0100 Subject: rewrite --- lib/MooseX/Privacy/Meta/Attribute/Protected.pm | 33 ++++++++++++++++++++++++-- 1 file changed, 31 insertions(+), 2 deletions(-) (limited to 'lib/MooseX/Privacy/Meta/Attribute/Protected.pm') diff --git a/lib/MooseX/Privacy/Meta/Attribute/Protected.pm b/lib/MooseX/Privacy/Meta/Attribute/Protected.pm index 408ab50..784f5e4 100644 --- a/lib/MooseX/Privacy/Meta/Attribute/Protected.pm +++ b/lib/MooseX/Privacy/Meta/Attribute/Protected.pm @@ -2,16 +2,24 @@ package MooseX::Privacy::Meta::Attribute::Protected; use Moose::Role; use Carp qw/confess/; +use MooseX::Types::Moose qw/Str ArrayRef/; sub _generate_accessor_method { - my $attr = (shift)->associated_attribute; + my $self = shift; + my $attr = $self->associated_attribute; + my $package_name = $attr->associated_class->name; + my $class = $attr->associated_class->name->meta; + if ( $class->meta->has_attribute('local_protected_attributes') ) { + $class->_push_protected_attribute( $attr->name ); + } return sub { my $self = shift; my $caller = ( scalar caller() ); confess "Attribute " . $attr->name . " is protected" - unless $caller eq $package_name || $caller->isa($package_name); + unless $caller eq $self->meta->name + or $caller->isa( $package_name ); $attr->set_value( $self, $_[0] ) if scalar(@_) == 1; $attr->set_value( $self, [@_] ) if scalar(@_) > 1; $attr->get_value($self); @@ -19,3 +27,24 @@ sub _generate_accessor_method { } 1; + +__END__ + +=head1 NAME + +MooseX::Privacy::Meta::Attribute::Protected + +=head1 SYNOPSIS + +=head1 AUTHOR + +franck cuny Efranck@lumberjaph.netE + +=head1 SEE ALSO + +=head1 LICENSE + +This library is free software; you can redistribute it and/or modify +it under the same terms as Perl itself. + +=cut -- cgit 1.4.1