X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse.pm;h=2be14aeb2b180d5b57b75cf0db37040d6042775e;hb=4216fc14597a0cb62cbb732fd12b77765b109145;hp=acac3f1de66b26af751c08e4795212a518a0e380;hpb=6beb7db6adf43757d8881da1c901532fbb382a48;p=gitmo%2FMouse.git diff --git a/lib/Mouse.pm b/lib/Mouse.pm index acac3f1..2be14ae 100644 --- a/lib/Mouse.pm +++ b/lib/Mouse.pm @@ -1,14 +1,23 @@ -#!/usr/bin/env perl package Mouse; use strict; use warnings; +use 5.006; use base 'Exporter'; -our $VERSION = '0.08'; +our $VERSION = '0.14'; use 5.006; +BEGIN { + if ($ENV{MOUSE_DEBUG}) { + *DEBUG = sub (){ 1 }; + } else { + *DEBUG = sub (){ 0 }; + } +} + use Carp 'confess'; -use Mouse::Util 'blessed'; +use Scalar::Util 'blessed'; +use Mouse::Util; use Mouse::Meta::Attribute; use Mouse::Meta::Class; @@ -66,17 +75,12 @@ sub around { } sub with { - my $meta = Mouse::Meta::Class->initialize(caller); - - my $role = shift; - - confess "Mouse::Role only supports 'with' on individual roles at a time" if @_; - - Mouse::load_class($role); - $role->meta->apply($meta); + Mouse::Util::apply_all_roles((caller)[0], @_); } sub import { + my $class = shift; + strict->import; warnings->import; @@ -90,7 +94,15 @@ sub import { no warnings 'redefine'; *{$caller.'::meta'} = sub { $meta }; - Mouse->export_to_level(1, @_); + if (@_) { + __PACKAGE__->export_to_level( 1, $class, @_); + } else { + # shortcut for the common case of no type character + no strict 'refs'; + for my $keyword (@EXPORT) { + *{ $caller . '::' . $keyword } = *{__PACKAGE__ . '::' . $keyword}; + } + } } sub unimport { @@ -110,6 +122,7 @@ sub load_class { confess "Invalid class name ($display)"; } + return 1 if $class eq 'Mouse::Object'; return 1 if is_class_loaded($class); (my $file = "$class.pm") =~ s{::}{/}g; @@ -299,9 +312,10 @@ Whether this attribute is required to have a value. If the attribute is lazy or has a builder, then providing a value for the attribute in the constructor is optional. -=item init_arg => Str +=item init_arg => Str | Undef -Allows you to use a different key name in the constructor. +Allows you to use a different key name in the constructor. If undef, the +attribue can't be passed to the constructor. =item default => Value | CodeRef @@ -359,6 +373,11 @@ context. In scalar context, the reference is returned (NOT the list length or bucket status). You must specify an appropriate type constraint to use auto_deref. +=item lazy_build => 0|1 + +Automatically define lazy => 1 as well as builder => "_build_$attr", clearer => +"clear_$attr', predicate => 'has_$attr' unless they are already defined. + =back =head2 confess error -> BOOM @@ -395,12 +414,16 @@ Returns whether this class is actually loaded or not. It uses a heuristic which involves checking for the existence of C<$VERSION>, C<@ISA>, and any locally-defined method. -=head1 AUTHOR +=head1 AUTHORS Shawn M Moore, C<< >> Yuval Kogman, C<< >> +tokuhirom + +Yappo + with plenty of code borrowed from L and L =head1 BUGS