bump version to 0.73_01
[gitmo/Moose.git] / lib / Moose / Util / TypeConstraints / OptimizedConstraints.pm
index 9fafbf4..b2d3656 100644 (file)
@@ -3,9 +3,10 @@ package Moose::Util::TypeConstraints::OptimizedConstraints;
 use strict;
 use warnings;
 
+use Class::MOP;
 use Scalar::Util 'blessed', 'looks_like_number';
 
-our $VERSION   = '0.55_04';
+our $VERSION   = '0.73_01';
 $VERSION = eval $VERSION;
 our $AUTHORITY = 'cpan:STEVAN';
 
@@ -33,31 +34,12 @@ sub Object { blessed($_[0]) && blessed($_[0]) ne 'Regexp' }
 sub Role { blessed($_[0]) && $_[0]->can('does') }
 
 sub ClassName {
-    return 0 if ref($_[0]) || !defined($_[0]) || !length($_[0]);
-
-    # walk the symbol table tree to avoid autovififying
-    # \*{${main::}{"Foo::"}} == \*main::Foo::
-
-    my $pack = \*::;
-    foreach my $part (split('::', $_[0])) {
-        return 0 unless exists ${$$pack}{"${part}::"};
-        $pack = \*{${$$pack}{"${part}::"}};
-    }
-
-    # check for $VERSION or @ISA
-    return 1 if exists ${$$pack}{VERSION}
-             && defined *{${$$pack}{VERSION}}{SCALAR};
-    return 1 if exists ${$$pack}{ISA}
-             && defined *{${$$pack}{ISA}}{ARRAY};
-
-    # check for any method
-    foreach ( keys %{$$pack} ) {
-        next if substr($_, -2, 2) eq '::';
-        return 1 if defined *{${$$pack}{$_}}{CODE};
-    }
-
-    # fail
-    return 0;
+    return Class::MOP::is_class_loaded( $_[0] );
+}
+
+sub RoleName {
+    ClassName($_[0])
+    && (Class::MOP::class_of($_[0]) || return)->isa('Moose::Meta::Role')
 }
 
 # NOTE:
@@ -85,35 +67,37 @@ no user serviceable parts inside.
 
 =over 4
 
-=item Value
+=item C<Value>
+
+=item C<Ref>
 
-=item Ref
+=item C<Str>
 
-=item Str
+=item C<Num>
 
-=item Num
+=item C<Int>
 
-=item Int
+=item C<ScalarRef>
 
-=item ScalarRef
+=item C<ArrayRef>
 
-=item ArrayRef
+=item C<HashRef>
 
-=item HashRef
+=item C<CodeRef>
 
-=item CodeRef
+=item C<RegexpRef>
 
-=item RegexpRef
+=item C<GlobRef>
 
-=item GlobRef
+=item C<FileHandle>
 
-=item FileHandle
+=item C<Object>
 
-=item Object
+=item C<Role>
 
-=item Role
+=item C<ClassName>
 
-=item ClassName
+=item C<RoleName>
 
 =back
 
@@ -129,7 +113,7 @@ Yuval Kogman E<lt>nothingmuch@cpan.orgE<gt>
 
 =head1 COPYRIGHT AND LICENSE
 
-Copyright 2007-2008 by Infinity Interactive, Inc.
+Copyright 2007-2009 by Infinity Interactive, Inc.
 
 L<http://www.iinteractive.com>