X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMoose%2FMeta%2FRole%2FApplication.pm;h=636dff7057da1b361718ef6e54b50791e4ecb4a4;hb=721a2ea053c8a9e6801ea562d365b5140ac5a868;hp=7274f704b373c010f0596c93b7a92121d41bddf9;hpb=1c9db35c77752fc918e23bee1613dc6567087dc5;p=gitmo%2FMoose.git
diff --git a/lib/Moose/Meta/Role/Application.pm b/lib/Moose/Meta/Role/Application.pm
index 7274f70..636dff7 100644
--- a/lib/Moose/Meta/Role/Application.pm
+++ b/lib/Moose/Meta/Role/Application.pm
@@ -4,37 +4,83 @@ use strict;
use warnings;
use metaclass;
-our $VERSION = '0.01';
+our $VERSION = '0.88';
+$VERSION = eval $VERSION;
our $AUTHORITY = 'cpan:STEVAN';
-# no need to get fancy here ...
-sub new { bless {} => (shift) }
+__PACKAGE__->meta->add_attribute('method_exclusions' => (
+ init_arg => 'excludes',
+ reader => 'get_method_exclusions',
+ default => sub { [] }
+));
+
+__PACKAGE__->meta->add_attribute('method_aliases' => (
+ init_arg => 'alias',
+ reader => 'get_method_aliases',
+ default => sub { {} }
+));
+
+sub new {
+ my ($class, %params) = @_;
+
+ if (exists $params{excludes}) {
+ # I wish we had coercion here :)
+ $params{excludes} = (ref $params{excludes} eq 'ARRAY'
+ ? $params{excludes}
+ : [ $params{excludes} ]);
+ }
+
+ $class->_new(\%params);
+}
+
+sub is_method_excluded {
+ my ($self, $method_name) = @_;
+ foreach (@{$self->get_method_exclusions}) {
+ return 1 if $_ eq $method_name;
+ }
+ return 0;
+}
+
+sub is_method_aliased {
+ my ($self, $method_name) = @_;
+ exists $self->get_method_aliases->{$method_name} ? 1 : 0
+}
+
+sub is_aliased_method {
+ my ($self, $method_name) = @_;
+ my %aliased_names = reverse %{$self->get_method_aliases};
+ exists $aliased_names{$method_name} ? 1 : 0;
+}
sub apply {
my $self = shift;
$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 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_before_method_modifiers { die "Abstract Method" }
-sub apply_around_method_modifiers { die "Abstract Method" }
-sub apply_after_method_modifiers { 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 { 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' => @_) }
+sub apply_after_method_modifiers { (shift)->apply_method_modifiers('after' => @_) }
1;
@@ -44,12 +90,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
@@ -58,11 +107,23 @@ This is the abstract base class for role applications.
=item B
+=item B
+
+=item B
+
+=item B
+
+=item B
+
+=item B
+
=item B
+=item B
+
=item B
-=item B
+=item B
=item B
@@ -92,7 +153,7 @@ Stevan Little Estevan@iinteractive.comE
=head1 COPYRIGHT AND LICENSE
-Copyright 2006, 2007 by Infinity Interactive, Inc.
+Copyright 2006-2009 by Infinity Interactive, Inc.
L