X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=lib%2FMouse%2FUtil.pm;h=25de2abf4084b23f24f29efd251a640d118d4108;hp=ff39422f74aa334df4cb293b4ef2d9b8a9e673c0;hb=23264b5b200f08d7258efc1509846d0a161194e1;hpb=cd2b92018095c8d3bc88f46cef5f5a0a11e0bf3b diff --git a/lib/Mouse/Util.pm b/lib/Mouse/Util.pm index ff39422..25de2ab 100644 --- a/lib/Mouse/Util.pm +++ b/lib/Mouse/Util.pm @@ -8,9 +8,6 @@ use B (); our @EXPORT_OK = qw( get_linear_isa apply_all_roles - version - authority - identifier get_code_info ); our %EXPORT_TAGS = ( @@ -63,31 +60,17 @@ BEGIN { sub get_code_info($) { my ($coderef) = @_; ref($coderef) or return; + my $cv = B::svref_2object($coderef); $cv->isa('B::CV') or return; my $gv = $cv->GV; - # bail out if GV is undefined - $gv->isa('B::SPECIAL') and return; + $gv->isa('B::GV') or return; return ($gv->STASH->NAME, $gv->NAME); } } -{ # adapted from Class::MOP::Module - - sub version { no strict 'refs'; ${shift->name.'::VERSION'} } - sub authority { no strict 'refs'; ${shift->name.'::AUTHORITY'} } - sub identifier { - my $self = shift; - join '-' => ( - $self->name, - ($self->version || ()), - ($self->authority || ()), - ); - } -} - # taken from Class/MOP.pm { my %cache; @@ -134,16 +117,14 @@ sub load_first_existing_class { my @classes = @_ or return; - foreach my $class (@classes) { + my $found; + my %exceptions; + for my $class (@classes) { unless ( _is_valid_class_name($class) ) { my $display = defined($class) ? $class : 'undef'; confess "Invalid class name ($display)"; } - } - my $found; - my %exceptions; - for my $class (@classes) { my $e = _try_load_one_class($class); if ($e) { @@ -213,7 +194,7 @@ sub apply_all_roles { else { Mouse::Meta::Role->combine_apply($meta, @roles); } - + return; } 1;