X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMoose%2FMeta%2FRole%2FApplication.pm;h=f8902fa0ae80b6123e022b11703d0164bc4e1545;hb=ae7820b1b884344a7ee90d94b484ca46459eb7b1;hp=74abb3397d03d86b955a916b18319f859b472dd3;hpb=3e19778d44d48d46fbbf0c32c10ee9b11371225d;p=gitmo%2FMoose.git diff --git a/lib/Moose/Meta/Role/Application.pm b/lib/Moose/Meta/Role/Application.pm index 74abb33..f8902fa 100644 --- a/lib/Moose/Meta/Role/Application.pm +++ b/lib/Moose/Meta/Role/Application.pm @@ -4,32 +4,43 @@ use strict; use warnings; use metaclass; -our $VERSION = '0.01'; +our $VERSION = '1.06'; +$VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; __PACKAGE__->meta->add_attribute('method_exclusions' => ( - init_arg => 'excludes', + init_arg => '-excludes', reader => 'get_method_exclusions', default => sub { [] } )); __PACKAGE__->meta->add_attribute('method_aliases' => ( - init_arg => 'alias', + init_arg => '-alias', reader => 'get_method_aliases', default => sub { {} } )); -sub new { +sub new { my ($class, %params) = @_; - - if (exists $params{excludes}) { + + if ( exists $params{excludes} && !exists $params{'-excludes'} ) { + $params{'-excludes'} = delete $params{excludes}; + } + if ( exists $params{alias} && !exists $params{'-alias'} ) { + $params{'-alias'} = delete $params{alias}; + } + + if ( exists $params{'-excludes'} ) { + # I wish we had coercion here :) - $params{excludes} = (ref $params{excludes} eq 'ARRAY' - ? $params{excludes} - : [ $params{excludes} ]); + $params{'-excludes'} = ( + ref $params{'-excludes'} eq 'ARRAY' + ? $params{'-excludes'} + : [ $params{'-excludes'} ] + ); } - - $class->meta->new_object(%params); + + $class->_new(\%params); } sub is_method_excluded { @@ -57,25 +68,25 @@ sub apply { $self->check_role_exclusions(@_); $self->check_required_methods(@_); $self->check_required_attributes(@_); - + $self->apply_attributes(@_); - $self->apply_methods(@_); - + $self->apply_methods(@_); + $self->apply_override_method_modifiers(@_); - + $self->apply_before_method_modifiers(@_); $self->apply_around_method_modifiers(@_); $self->apply_after_method_modifiers(@_); } -sub check_role_exclusions { die "Abstract Method" } -sub check_required_methods { die "Abstract Method" } -sub check_required_attributes { die "Abstract Method" } +sub check_role_exclusions { Carp::croak "Abstract Method" } +sub check_required_methods { Carp::croak "Abstract Method" } +sub check_required_attributes { Carp::croak "Abstract Method" } -sub apply_attributes { die "Abstract Method" } -sub apply_methods { die "Abstract Method" } -sub apply_override_method_modifiers { die "Abstract Method" } -sub apply_method_modifiers { die "Abstract Method" } +sub apply_attributes { Carp::croak "Abstract Method" } +sub apply_methods { Carp::croak "Abstract Method" } +sub apply_override_method_modifiers { Carp::croak "Abstract Method" } +sub apply_method_modifiers { Carp::croak "Abstract Method" } sub apply_before_method_modifiers { (shift)->apply_method_modifiers('before' => @_) } sub apply_around_method_modifiers { (shift)->apply_method_modifiers('around' => @_) } @@ -89,12 +100,15 @@ __END__ =head1 NAME -Moose::Meta::Role::Application +Moose::Meta::Role::Application - A base class for role application =head1 DESCRIPTION This is the abstract base class for role applications. +The API for this class and its subclasses still needs some +consideration, and is intentionally not yet documented. + =head2 METHODS =over 4 @@ -139,9 +153,7 @@ This is the abstract base class for role applications. =head1 BUGS -All complex software has bugs lurking in it, and this module is no -exception. If you find a bug please either email me, or add the bug -to cpan-RT. +See L for details on reporting bugs. =head1 AUTHOR @@ -149,7 +161,7 @@ Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE -Copyright 2006-2008 by Infinity Interactive, Inc. +Copyright 2006-2010 by Infinity Interactive, Inc. L