X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FClassData.pm;h=76cdbeced4310fea45d7827c1b15ac4948bf4fe5;hb=88eee38e25dd1a991008fb5f61b848fcecb97ad0;hp=e7379d1ddf13126c9ab2450c6c28ad0c2ea4dec9;hpb=46d0346ddafe8e167c679cddef9834946598e689;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/ClassData.pm b/lib/Catalyst/ClassData.pm index e7379d1..76cdbec 100644 --- a/lib/Catalyst/ClassData.pm +++ b/lib/Catalyst/ClassData.pm @@ -13,7 +13,7 @@ sub mk_classdata { my $accessor = sub { my $meta = $_[0]->meta; if(@_ > 1){ - $meta->add_package_symbol($slot, \ $_[1]); + $meta->namespace->{$attribute} = \$_[1]; return $_[1]; } @@ -34,9 +34,17 @@ sub mk_classdata { unless ref $accessor eq 'CODE'; my $meta = $class->meta; + my $immutable_options; + if( $meta->is_immutable ){ + $immutable_options = $meta->get_immutable_options; + $meta->make_mutable; + } my $alias = "_${attribute}_accessor"; $meta->add_method($alias, $accessor); $meta->add_method($attribute, $accessor); + if(defined $immutable_options){ + $meta->make_immutable($immutable_options); + } $class->$attribute($_[2]) if(@_ > 2); return $accessor; }