X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse.pm;h=be0ee4b6533a45efe4b795ad02fdad502a12fd45;hb=949738a8e4009ad482721d7c11c5c3ad6fa61369;hp=0d5e4432de94a88e39f3f6122c540f7c6b0ec722;hpb=9090e5fe93ed204d746dfea6d09925ec54b194c4;p=gitmo%2FMouse.git diff --git a/lib/Mouse.pm b/lib/Mouse.pm index 0d5e443..be0ee4b 100644 --- a/lib/Mouse.pm +++ b/lib/Mouse.pm @@ -4,7 +4,7 @@ use warnings; use 5.006; use base 'Exporter'; -our $VERSION = '0.15'; +our $VERSION = '0.17'; BEGIN { if ($ENV{MOUSE_DEBUG}) { @@ -23,7 +23,7 @@ use Mouse::Meta::Class; use Mouse::Object; use Mouse::Util::TypeConstraints; -our @EXPORT = qw(extends has before after around blessed confess with); +our @EXPORT = qw(extends has before after around override super blessed confess with); sub extends { Mouse::Meta::Class->initialize(caller)->superclasses(@_) } @@ -77,6 +77,36 @@ sub with { Mouse::Util::apply_all_roles((caller)[0], @_); } +our $SUPER_PACKAGE; +our $SUPER_BODY; +our @SUPER_ARGS; + +sub super { + # This check avoids a recursion loop - see + # t/100_bugs/020_super_recursion.t + return if defined $SUPER_PACKAGE && $SUPER_PACKAGE ne caller(); + return unless $SUPER_BODY; $SUPER_BODY->(@SUPER_ARGS); +} + +sub override { + my $meta = Mouse::Meta::Class->initialize(caller); + my $pkg = $meta->name; + + my $name = shift; + my $code = shift; + + my $body = $pkg->can($name) + or confess "You cannot override '$name' because it has no super method"; + + $meta->add_method($name => sub { + local $SUPER_PACKAGE = $pkg; + local @SUPER_ARGS = @_; + local $SUPER_BODY = $body; + + $code->(@_); + }); +} + sub import { my $class = shift; @@ -214,11 +244,9 @@ Mouse aims to alleviate this by providing a subset of Moose's functionality, faster. In particular, L is missing only a few expert-level features. -We're also going as light on dependencies as possible. Most functions we use -from L are copied into this dist. L is required if -you'd like weak references; there's simply no way to do it from pure Perl. -L is required if you want support for L, -L, and L. +We're also going as light on dependencies as possible. +L or L is required if you want support +for L, L, and L. =head2 MOOSE COMPAT @@ -231,8 +259,7 @@ The idea is that, if you need the extra power, you should be able to run C on your codebase and have nothing break. To that end, nothingmuch has written L (part of this distribution) which will act as Mouse unless Moose is loaded, in which case it will act as Moose. - -Mouse also has the blessings of Moose's author, stevan. +L is a more high-tech L. =head2 MouseX