This commit is contained in:
43
CPAN/Moose/Exception/OverrideConflictInComposition.pm
Normal file
43
CPAN/Moose/Exception/OverrideConflictInComposition.pm
Normal file
@@ -0,0 +1,43 @@
|
||||
package Moose::Exception::OverrideConflictInComposition;
|
||||
our $VERSION = '2.2207';
|
||||
|
||||
use Moose;
|
||||
extends 'Moose::Exception';
|
||||
with 'Moose::Exception::Role::Role';
|
||||
|
||||
has 'role_being_applied_name' => (
|
||||
is => 'ro',
|
||||
isa => 'Str',
|
||||
required => 1
|
||||
);
|
||||
|
||||
has 'method_name' => (
|
||||
is => 'ro',
|
||||
isa => 'Str',
|
||||
required => 1
|
||||
);
|
||||
|
||||
has 'two_overrides_found' => (
|
||||
is => 'ro',
|
||||
isa => 'Bool',
|
||||
required => 1,
|
||||
default => 0
|
||||
);
|
||||
|
||||
sub _build_message {
|
||||
my $self = shift;
|
||||
|
||||
if( $self->two_overrides_found ) {
|
||||
return "Role '" . $self->role_being_applied_name . "' has encountered an 'override' method conflict " .
|
||||
"during composition (Two 'override' methods of the same name encountered). " .
|
||||
"This is a fatal error.";
|
||||
}
|
||||
else {
|
||||
return "Role '".$self->role_being_applied_name."' has encountered an 'override' method conflict ".
|
||||
"during composition (A local method of the same name as been found). ".
|
||||
"This is a fatal error.";
|
||||
}
|
||||
}
|
||||
|
||||
__PACKAGE__->meta->make_immutable;
|
||||
1;
|
||||
Reference in New Issue
Block a user