summaryrefslogtreecommitdiff
path: root/lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2015-06-06 17:50:16 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2015-06-06 17:50:16 +0000
commit5ac2026f7eed78958d69d051e7a8e993dcf51205 (patch)
tree298c3d2f08bdfe5689998b11892d72a897985be1 /lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm
downloadMoose-tarball-5ac2026f7eed78958d69d051e7a8e993dcf51205.tar.gz
Diffstat (limited to 'lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm')
-rw-r--r--lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm49
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm b/lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm
new file mode 100644
index 0000000..5b76867
--- /dev/null
+++ b/lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm
@@ -0,0 +1,49 @@
+package Moose::Exception::Role::EitherAttributeOrAttributeName;
+our $VERSION = '2.1405';
+
+use Moose::Util 'throw_exception';
+use Moose::Role;
+
+has 'attribute_name' => (
+ is => 'ro',
+ isa => 'Str',
+ lazy_build => 1
+);
+
+has 'attribute' => (
+ is => 'ro',
+ isa => 'Class::MOP::Attribute',
+ predicate => 'has_attribute'
+);
+
+has 'params' => (
+ is => 'ro',
+ isa => 'HashRef',
+ predicate => 'has_params',
+);
+
+sub _build_attribute_name {
+ my $self = shift;
+
+ if( !$self->has_attribute )
+ {
+ throw_exception("NeitherAttributeNorAttributeNameIsGiven");
+ }
+
+ return $self->attribute->name;
+}
+
+after "BUILD" => sub {
+ my $self = $_[0];
+
+ if( $self->has_attribute_name &&
+ $self->has_attribute &&
+ ( $self->attribute->name ne $self->attribute_name ) )
+ {
+ throw_exception( AttributeNamesDoNotMatch => attribute_name => $self->attribute_name,
+ attribute => $self->attribute
+ );
+ }
+};
+
+1;