X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse.pm;h=ba791a96aeefee869acdfc316b5eccf0dadd402f;hb=ea6dc3a5b84bb831e5c750e9fc402050d83c6135;hp=be0ee4b6533a45efe4b795ad02fdad502a12fd45;hpb=949738a8e4009ad482721d7c11c5c3ad6fa61369;p=gitmo%2FMouse.git diff --git a/lib/Mouse.pm b/lib/Mouse.pm index be0ee4b..ba791a9 100644 --- a/lib/Mouse.pm +++ b/lib/Mouse.pm @@ -4,15 +4,7 @@ use warnings; use 5.006; use base 'Exporter'; -our $VERSION = '0.17'; - -BEGIN { - if ($ENV{MOUSE_DEBUG}) { - *DEBUG = sub (){ 1 }; - } else { - *DEBUG = sub (){ 0 }; - } -} +our $VERSION = '0.20'; use Carp 'confess'; use Scalar::Util 'blessed'; @@ -29,18 +21,7 @@ sub extends { Mouse::Meta::Class->initialize(caller)->superclasses(@_) } sub has { my $meta = Mouse::Meta::Class->initialize(caller); - - my $names = shift; - $names = [$names] if !ref($names); - - for my $name (@$names) { - if ($name =~ s/^\+//) { - Mouse::Meta::Attribute->clone_parent($meta, $name, @_); - } - else { - Mouse::Meta::Attribute->create($meta, $name, @_); - } - } + $meta->add_attribute(@_); } sub before { @@ -113,7 +94,16 @@ sub import { strict->import; warnings->import; - my $caller = caller; + my $opts = do { + if (ref($_[0]) && ref($_[0]) eq 'HASH') { + shift @_; + } else { + +{ }; + } + }; + my $level = delete $opts->{into_level}; + $level = 0 unless defined $level; + my $caller = caller($level); # we should never export to main if ($caller eq 'main') { @@ -125,12 +115,15 @@ sub import { $meta->superclasses('Mouse::Object') unless $meta->superclasses; + # make a subtype for each Mouse class + class_type($caller) unless find_type_constraint($caller); + no strict 'refs'; no warnings 'redefine'; *{$caller.'::meta'} = sub { $meta }; if (@_) { - __PACKAGE__->export_to_level( 1, $class, @_); + __PACKAGE__->export_to_level( $level+1, $class, @_); } else { # shortcut for the common case of no type character no strict 'refs'; @@ -437,6 +430,8 @@ tokuhirom Yappo +wu-lee + with plenty of code borrowed from L and L =head1 BUGS