From b274df4c9da24b117a22e287acd03b3fa87233a8 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Mon, 21 Feb 2011 16:04:51 -0600 Subject: rename MooseX::Bread::Board -> Bread::Board::Declare --- lib/Bread/Board/Declare.pm | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 lib/Bread/Board/Declare.pm (limited to 'lib/Bread/Board/Declare.pm') diff --git a/lib/Bread/Board/Declare.pm b/lib/Bread/Board/Declare.pm new file mode 100644 index 0000000..51ec744 --- /dev/null +++ b/lib/Bread/Board/Declare.pm @@ -0,0 +1,36 @@ +package Bread::Board::Declare; +use Moose::Exporter; + +use Bread::Board (); + +my (undef, undef, $init_meta) = Moose::Exporter->build_import_methods( + install => ['import', 'unimport'], + class_metaroles => { + attribute => ['Bread::Board::Declare::Meta::Role::Attribute'], + class => ['Bread::Board::Declare::Meta::Role::Class'], + instance => ['Bread::Board::Declare::Meta::Role::Instance'], + }, + (Moose->VERSION >= 1.9900 + ? (role_metaroles => { + applied_attribute => + ['Bread::Board::Declare::Meta::Role::Attribute'], + }) + : ()), + base_class_roles => ['Bread::Board::Declare::Role::Object'], +); + +sub init_meta { + my $package = shift; + my %options = @_; + if (my $meta = Class::MOP::class_of($options{for_class})) { + if ($meta->isa('Class::MOP::Class')) { + my @supers = $meta->superclasses; + $meta->superclasses('Bread::Board::Container') + if @supers == 1 && $supers[0] eq 'Moose::Object'; + } + } + $package->$init_meta(%options); +} + + +1; -- cgit v1.2.3