summaryrefslogtreecommitdiff
path: root/lib/Moose/Exception/AttributeConflictInSummation.pm
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Moose/Exception/AttributeConflictInSummation.pm')
-rw-r--r--lib/Moose/Exception/AttributeConflictInSummation.pm27
1 files changed, 27 insertions, 0 deletions
diff --git a/lib/Moose/Exception/AttributeConflictInSummation.pm b/lib/Moose/Exception/AttributeConflictInSummation.pm
new file mode 100644
index 0000000..81ba5b7
--- /dev/null
+++ b/lib/Moose/Exception/AttributeConflictInSummation.pm
@@ -0,0 +1,27 @@
+package Moose::Exception::AttributeConflictInSummation;
+our $VERSION = '2.1405';
+
+use Moose;
+extends 'Moose::Exception';
+with 'Moose::Exception::Role::Role', 'Moose::Exception::Role::AttributeName';
+
+has 'second_role_name' => (
+ is => 'ro',
+ isa => 'Str',
+ required => 1,
+);
+
+sub _build_message {
+ my $self = shift;
+
+ my $role1 = $self->role_name;
+ my $role2 = $self->second_role_name;
+ my $attr_name = $self->attribute_name;
+
+ return "We have encountered an attribute conflict with '$attr_name'"
+ . " during role composition. "
+ . " This attribute is defined in both $role1 and $role2."
+ . " This is a fatal error and cannot be disambiguated.";
+}
+
+1;