X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FTest%2FValgrind%2FCommand.pm;h=4b046cc5a7b696b84e3545f02f23d6164df80778;hb=f2071d95aaaa4817e91cc33530deedc8d701d44d;hp=eb5a3476a2e83cc3cbc345dc1fc659b9ef89bc10;hpb=0e79c45af8d5eabe900280cc0e5467936467dee9;p=perl%2Fmodules%2FTest-Valgrind.git diff --git a/lib/Test/Valgrind/Command.pm b/lib/Test/Valgrind/Command.pm index eb5a347..4b046cc 100644 --- a/lib/Test/Valgrind/Command.pm +++ b/lib/Test/Valgrind/Command.pm @@ -9,25 +9,33 @@ Test::Valgrind::Command - Base class for Test::Valgrind commands. =head1 VERSION -Version 1.01 +Version 1.19 =cut -our $VERSION = '1.01'; +our $VERSION = '1.19'; =head1 DESCRIPTION This class is the base for L commands. -Commands gather information about the target of the analysis. They should also provide a default setup for generating suppressions. +Commands gather information about the target of the analysis. +They should also provide a default setup for generating suppressions. =cut -use base qw/Test::Valgrind::Carp/; +use Test::Valgrind::Util; + +use base qw; =head1 METHODS -=head2 C<< new command => $command, args => \@args >> +=head2 C + + my $tvc = Test::Valgrind::Command->new( + command => $command, + args => \@args, + ); Creates a new command object of type C<$command> by requiring and redispatching the method call to the module named C<$command> if it contains C<'::'> or to C otherwise. The class represented by C<$command> must inherit this class. @@ -42,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); } @@ -67,7 +75,9 @@ Defaults to return C, which skips suppression generation. sub new_trainer { } -=head2 C +=head2 C + + my @args = $tvc->args($session); Returns the list of command-specific arguments that are to be passed to C. @@ -77,7 +87,9 @@ Defaults to return the contents of the C option. sub args { @{$_[0]->{args} || []} } -=head2 C +=head2 C + + my $env = $tvc->env($session); This event is called in scalar context before the command is ran, and the returned value goes out of scope when the analysis ends. It's useful for e.g. setting up C<%ENV> for the child process by returning an L object, hence the name. @@ -88,7 +100,9 @@ Defaults to void. sub env { } -=head2 C +=head2 C + + my $tag = $tvc->suppressions_tag($session); Returns a identifier that will be used to pick up the right suppressions for running the command, or C to indicate that no special suppressions are needed. @@ -98,6 +112,31 @@ This method must be implemented when subclassing. sub suppressions_tag; +=head2 C + + my $supp_ok = $tvc->check_suppressions_file($file); + +Returns a boolean indicating whether the suppressions contained in C<$file> are compatible with the command. + +Defaults to true. + +=cut + +sub check_suppressions_file { 1 } + +=head2 C + + my $filtered_report = $tvc->filter($session, $report); + +The C<$session> calls this method after receiving a report from the tool and before forwarding it to the action. +You can either return a mangled C<$report> (which does not need to be a clone of the original) or C if you want the action to ignore it completely. + +Defaults to the identity function. + +=cut + +sub filter { $_[2] } + =head1 SEE ALSO L, L. @@ -121,7 +160,7 @@ You can find documentation for this module with the perldoc command. =head1 COPYRIGHT & LICENSE -Copyright 2009 Vincent Pit, all rights reserved. +Copyright 2009,2010,2011,2013,2015,2016 Vincent Pit, all rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.