1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
|
package Moose::Meta::Role::Method::Conflicting;
use strict;
use warnings;
use Moose::Util;
use base qw(Moose::Meta::Role::Method::Required);
our $VERSION = '1.09';
$VERSION = eval $VERSION;
our $AUTHORITY = 'cpan:STEVAN';
__PACKAGE__->meta->add_attribute('roles' => (
reader => 'roles',
required => 1,
));
sub roles_as_english_list {
my $self = shift;
Moose::Util::english_list( map { q{'} . $_ . q{'} } @{ $self->roles } );
}
1;
__END__
=pod
=head1 NAME
Moose::Meta::Role::Method::Conflicting - A Moose metaclass for conflicting methods in Roles
=head1 DESCRIPTION
=head1 INHERITANCE
C<Moose::Meta::Role::Method::Conflicting> is a subclass of
L<Moose::Meta::Role::Method::Required>.
=head1 METHODS
=over 4
=item B<< Moose::Meta::Role::Method::Conflicting->new(%options) >>
This creates a new type constraint based on the provided C<%options>:
=over 8
=item * name
The method name. This is required.
=item * roles
The list of role names that generated the conflict. This is required.
=back
=item B<< $method->name >>
Returns the conflicting method's name, as provided to the constructor.
=item B<< $method->roles >>
Returns the roles that generated this conflicting method, as provided to the
constructor.
=item B<< $method->roles_as_english_list >>
Returns the roles that generated this conflicting method as an English list.
=back
=head1 BUGS
See L<Moose/BUGS> for details on reporting bugs.
=head1 AUTHOR
Stevan Little E<lt>stevan@iinteractive.comE<gt>
=head1 COPYRIGHT AND LICENSE
Copyright 2006-2010 by Infinity Interactive, Inc.
L<http://www.iinteractive.com>
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=cut
|