diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-06-06 17:50:16 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-06-06 17:50:16 +0000 |
commit | 5ac2026f7eed78958d69d051e7a8e993dcf51205 (patch) | |
tree | 298c3d2f08bdfe5689998b11892d72a897985be1 /lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm | |
download | Moose-tarball-5ac2026f7eed78958d69d051e7a8e993dcf51205.tar.gz |
Moose-2.1405HEADMoose-2.1405master
Diffstat (limited to 'lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm')
-rw-r--r-- | lib/Moose/Exception/Role/EitherAttributeOrAttributeName.pm | 49 |
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; |