X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse%2FObject.pm;h=6e43b02a920a3e0319fbf0905654594a3ebcce24;hb=c73a0a96299636e25c1a283ed45b6052ceda35eb;hp=20748e99292e3704531c98773733c323e5a06c15;hpb=06a970ab9fb60a4cac5e3f1774cf9a2914c94cc1;p=gitmo%2FMouse.git diff --git a/lib/Mouse/Object.pm b/lib/Mouse/Object.pm index 20748e9..6e43b02 100644 --- a/lib/Mouse/Object.pm +++ b/lib/Mouse/Object.pm @@ -4,7 +4,7 @@ use Mouse::Util qw(does dump); # enables strict and warnings sub new { my $class = shift; - $class->throw_error('Cannot call new() on an instance') if ref $class; + $class->meta->throw_error('Cannot call new() on an instance') if ref $class; my $args = $class->BUILDARGS(@_); @@ -51,8 +51,11 @@ sub BUILDALL { return unless $self->can('BUILD'); for my $class (reverse $self->meta->linearized_isa) { - my $build = do{ no strict 'refs'; *{ $class . '::BUILD' }{CODE} } - or next; + my $build = do{ + no strict 'refs'; + no warnings 'once'; + *{ $class . '::BUILD' }{CODE}; + } or next; $self->$build(@_); } @@ -71,8 +74,11 @@ sub DEMOLISHALL { # that time (at least tests suggest so ;) foreach my $class (@{ Mouse::Util::get_linear_isa(ref $self) }) { - my $demolish = do{ no strict 'refs'; *{ $class . '::DEMOLISH'}{CODE} } - or next; + my $demolish = do{ + no strict 'refs'; + no warnings 'once'; + *{ $class . '::DEMOLISH'}{CODE}; + } or next; $self->$demolish(); } @@ -89,7 +95,7 @@ Mouse::Object - The base object for Mouse classes =head1 VERSION -This document describes Mouse version 0.38 +This document describes Mouse version 0.39 =head1 METHODS