X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=lib%2FMouse.pm;h=7cd88d574d0fbfefe1dd93f971edb6c6a54a22e2;hp=78d54eabf685f49633ba26008c0da0936d2215db;hb=506fb74dbff3e8f756230c643d8bff7b85ae9ca3;hpb=c9a3c0ed389e30d9d176ab198ecfb766cce0aa3c diff --git a/lib/Mouse.pm b/lib/Mouse.pm index 78d54ea..7cd88d5 100644 --- a/lib/Mouse.pm +++ b/lib/Mouse.pm @@ -3,9 +3,9 @@ use 5.006_002; use Mouse::Exporter; # enables strict and warnings -our $VERSION = '0.37_05'; +our $VERSION = '0.40_09'; -use Carp qw(confess); +use Carp qw(confess); use Scalar::Util qw(blessed); use Mouse::Util qw(load_class is_class_loaded get_code_package not_supported); @@ -30,26 +30,33 @@ Mouse::Exporter->setup_import_methods( ], ); -# XXX: for backward compatibility -our @EXPORT = qw( - extends with - has - before after around - override super - augment inner - blessed confess -); -sub extends { Mouse::Meta::Class->initialize(scalar caller)->superclasses(@_) } +sub extends { + Mouse::Meta::Class->initialize(scalar caller)->superclasses(@_); + return; +} + +sub with { + Mouse::Util::apply_all_roles(scalar(caller), @_); + return; +} sub has { my $meta = Mouse::Meta::Class->initialize(scalar caller); my $name = shift; - $meta->throw_error(q{Usage: has 'name' => ( key => value, ... )}) + $meta->throw_error(q{Usage: has 'name' => ( key => value, ... )}) if @_ % 2; # odd number of arguments - $meta->add_attribute($_ => @_) for ref($name) ? @{$name} : $name; + if(ref $name){ # has [qw(foo bar)] => (...) + for (@{$name}){ + $meta->add_attribute($_ => @_); + } + } + else{ # has foo => (...) + $meta->add_attribute($name => @_); + } + return; } sub before { @@ -60,6 +67,7 @@ sub before { for (@_) { $meta->add_before_method_modifier($_ => $code); } + return; } sub after { @@ -70,6 +78,7 @@ sub after { for (@_) { $meta->add_after_method_modifier($_ => $code); } + return; } sub around { @@ -80,10 +89,7 @@ sub around { for (@_) { $meta->add_around_method_modifier($_ => $code); } -} - -sub with { - Mouse::Util::apply_all_roles(scalar(caller), @_); + return; } our $SUPER_PACKAGE; @@ -122,6 +128,7 @@ sub inner { sub augment { #my($name, $method) = @_; Mouse::Meta::Class->initialize(scalar caller)->add_augment_method_modifier(@_); + return; } sub init_meta { @@ -160,7 +167,7 @@ Mouse - Moose minus the antlers =head1 VERSION -This document describes Mouse version 0.37_05 +This document describes Mouse version 0.40_09 =head1 SYNOPSIS @@ -202,9 +209,8 @@ latter, if possible. Mouse aims to alleviate this by providing a subset of Moose's functionality, faster. -We're also going as light on dependencies as possible. -L or L is required -if you want support for L, L, and L. +We're also going as light on dependencies as possible. Mouse currently has +B except for testing modules. =head2 MOOSE COMPATIBILITY @@ -224,6 +230,8 @@ Moose, if you run into weird errors, it would be worth running: to see if the bug is caused by Mouse. Moose's diagnostics and validation are also much better. +See also L for compatibility and incompatibility with Moose. + =head2 MouseX Please don't copy MooseX code to MouseX. If you need extensions, you really @@ -391,7 +399,7 @@ keywords (such as L) it will break loudly instead breaking subtly. We have a public git repository: - git clone git://jules.scsys.co.uk/gitmo/Mouse.git + git clone git://git.moose.perl.org/Mouse.git =head1 DEPENDENCIES @@ -399,15 +407,17 @@ Perl 5.6.2 or later. =head1 SEE ALSO +L + L L =head1 AUTHORS -Shawn M Moore, Esartak at gmail.comE +Shawn M Moore Esartak at gmail.comE -Yuval Kogman, Enothingmuch at woobling.orgE +Yuval Kogman Enothingmuch at woobling.orgE tokuhirom