summaryrefslogtreecommitdiffstats
path: root/lib/Bread/Board/Declare/Meta/Role/Class.pm
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2011-02-21 16:04:51 -0600
committerJesse Luehrs <doy@tozt.net>2011-02-21 16:04:51 -0600
commitb274df4c9da24b117a22e287acd03b3fa87233a8 (patch)
tree602aba197c8752ea4253bc8fbb950fb373f92903 /lib/Bread/Board/Declare/Meta/Role/Class.pm
parent61839366b807e9e8f6818020508d765efed945b5 (diff)
downloadbread-board-declare-b274df4c9da24b117a22e287acd03b3fa87233a8.tar.gz
bread-board-declare-b274df4c9da24b117a22e287acd03b3fa87233a8.zip
rename MooseX::Bread::Board -> Bread::Board::Declare
Diffstat (limited to 'lib/Bread/Board/Declare/Meta/Role/Class.pm')
-rw-r--r--lib/Bread/Board/Declare/Meta/Role/Class.pm32
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/Bread/Board/Declare/Meta/Role/Class.pm b/lib/Bread/Board/Declare/Meta/Role/Class.pm
new file mode 100644
index 0000000..2869f7e
--- /dev/null
+++ b/lib/Bread/Board/Declare/Meta/Role/Class.pm
@@ -0,0 +1,32 @@
+package Bread::Board::Declare::Meta::Role::Class;
+use Moose::Role;
+
+use Bread::Board::Service;
+use List::MoreUtils qw(any);
+
+sub get_all_services {
+ my $self = shift;
+ return map { $_->associated_service }
+ grep { $_->has_associated_service }
+ grep { Moose::Util::does_role($_, 'Bread::Board::Declare::Meta::Role::Attribute') }
+ $self->get_all_attributes;
+}
+
+before superclasses => sub {
+ my $self = shift;
+
+ return unless @_;
+
+ die "Multiple inheritance is not supported for Bread::Board::Declare classes"
+ if @_ > 1;
+
+ return if $_[0]->isa('Bread::Board::Container');
+
+ die "Cannot inherit from " . join(', ', @_)
+ . " because Bread::Board::Declare classes must inherit"
+ . " from Bread::Board::Container";
+};
+
+no Moose::Role;
+
+1;