X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMoose%2FUtil%2FTypeConstraints%2FOptimizedConstraints.pm;h=281189c350705458e06f4b2cb083d46e953461fa;hb=245478d5ee6b5343e4d591be811582963e177bef;hp=844783130be395154502c674bb2c09891c91d65b;hpb=75d2da3428d70afc00efb0f295fd0656a05d6b9f;p=gitmo%2FMoose.git diff --git a/lib/Moose/Util/TypeConstraints/OptimizedConstraints.pm b/lib/Moose/Util/TypeConstraints/OptimizedConstraints.pm index 8447831..281189c 100644 --- a/lib/Moose/Util/TypeConstraints/OptimizedConstraints.pm +++ b/lib/Moose/Util/TypeConstraints/OptimizedConstraints.pm @@ -4,9 +4,10 @@ use strict; use warnings; use Class::MOP; +use Moose::Deprecated; use Scalar::Util 'blessed', 'looks_like_number'; -our $VERSION = '0.77'; +our $VERSION = '1.19'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; @@ -14,13 +15,23 @@ sub Value { defined($_[0]) && !ref($_[0]) } sub Ref { ref($_[0]) } -sub Str { defined($_[0]) && !ref($_[0]) } +# We need to use a temporary here to flatten LVALUEs, for instance as in +# Str(substr($_,0,255)). +sub Str { + my $value = $_[0]; + defined($value) && ref(\$value) eq 'SCALAR' +} sub Num { !ref($_[0]) && looks_like_number($_[0]) } -sub Int { defined($_[0]) && !ref($_[0]) && $_[0] =~ /^-?[0-9]+$/ } +# using a temporary here because regex matching promotes an IV to a PV, +# and that confuses some things (like JSON.pm) +sub Int { + my $value = $_[0]; + defined($value) && !ref($value) && $value =~ /^-?[0-9]+$/ +} -sub ScalarRef { ref($_[0]) eq 'SCALAR' } +sub ScalarRef { ref($_[0]) eq 'SCALAR' || ref($_[0]) eq 'REF' } sub ArrayRef { ref($_[0]) eq 'ARRAY' } sub HashRef { ref($_[0]) eq 'HASH' } sub CodeRef { ref($_[0]) eq 'CODE' } @@ -31,7 +42,14 @@ sub FileHandle { ref($_[0]) eq 'GLOB' && Scalar::Util::openhandle($_[0]) or bles sub Object { blessed($_[0]) && blessed($_[0]) ne 'Regexp' } -sub Role { blessed($_[0]) && $_[0]->can('does') } +sub Role { + Moose::Deprecated::deprecated( + feature => 'Role type', + message => + 'The Role type has been deprecated. Maybe you meant to create a RoleName type?' + ); + blessed( $_[0] ) && $_[0]->can('does'); +} sub ClassName { return Class::MOP::is_class_loaded( $_[0] ); @@ -103,9 +121,7 @@ no user serviceable parts inside. =head1 BUGS -All complex software has bugs lurking in it, and this module is no -exception. If you find a bug please either email me, or add the bug -to cpan-RT. +See L for details on reporting bugs. =head1 AUTHOR