X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FTest%2FValgrind%2FCommand.pm;h=b871cc57f3d58532044c3692eb59ff53a2bf465e;hb=3a312e2c6e7fdc7be70dcc8ccca604e7c62699f5;hp=a305ed65b361143bbad8f530974891dfb1d26fa4;hpb=8cacc78f5dbd91f8ff36075b44d923edd659541f;p=perl%2Fmodules%2FTest-Valgrind.git diff --git a/lib/Test/Valgrind/Command.pm b/lib/Test/Valgrind/Command.pm index a305ed6..b871cc5 100644 --- a/lib/Test/Valgrind/Command.pm +++ b/lib/Test/Valgrind/Command.pm @@ -9,11 +9,11 @@ Test::Valgrind::Command - Base class for Test::Valgrind commands. =head1 VERSION -Version 1.15 +Version 1.16 =cut -our $VERSION = '1.15'; +our $VERSION = '1.16'; =head1 DESCRIPTION @@ -24,6 +24,8 @@ They should also provide a default setup for generating suppressions. =cut +use Test::Valgrind::Util; + use base qw; =head1 METHODS @@ -48,10 +50,10 @@ sub new { my %args = @_; - if ($class eq __PACKAGE__ and my $cmd = delete $args{command}) { - $cmd =~ s/[^\w:]//g; - $cmd = __PACKAGE__ . "::$cmd" if $cmd !~ /::/; - $class->_croak("Couldn't load command $cmd: $@") unless eval "require $cmd;1"; + my $cmd = delete $args{command}; + if ($class eq __PACKAGE__ and defined $cmd) { + ($cmd, my $msg) = Test::Valgrind::Util::validate_subclass($cmd); + $class->_croak($msg) unless defined $cmd; return $cmd->new(%args); }