X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FTest%2FValgrind%2FCommand%2FPerl.pm;h=7d50dbbd0bff2bedf0807d26442aef5715850562;hb=refs%2Ftags%2Frt109349;hp=55c8babe5bb48e99eace1bf5148dd600cd756900;hpb=8cacc78f5dbd91f8ff36075b44d923edd659541f;p=perl%2Fmodules%2FTest-Valgrind.git diff --git a/lib/Test/Valgrind/Command/Perl.pm b/lib/Test/Valgrind/Command/Perl.pm index 55c8bab..7d50dbb 100644 --- a/lib/Test/Valgrind/Command/Perl.pm +++ b/lib/Test/Valgrind/Command/Perl.pm @@ -9,11 +9,11 @@ Test::Valgrind::Command::Perl - A Test::Valgrind command that invokes perl. =head1 VERSION -Version 1.15 +Version 1.19 =cut -our $VERSION = '1.15'; +our $VERSION = '1.19'; =head1 DESCRIPTION @@ -22,6 +22,7 @@ It handles the suppression generation and sets the main command-line flags. =cut +use List::Util (); use Env::Sanctify (); use Test::Valgrind::Suppressions; @@ -47,7 +48,7 @@ The package constructor, which takes several options : =item * -The C option specifies which C executable will run the arugment list given in C. +The C option specifies which C executable will run the argument list given in C. Defaults to C<$^X>. @@ -194,7 +195,8 @@ sub check_suppressions_file { local $_; while (<$fh>) { - return 1 if /^\s*fun:Perl_/; + return 1 if /^\s*fun:(Perl|S|XS)_/ + or /^\s*obj:.*perl/; } close $fh; @@ -209,9 +211,40 @@ sub filter { return $report if $report->is_diag or not $report->isa('Test::Valgrind::Report::Suppressions'); - my $data = $report->data; - $data =~ s/[^\r\n]*\bPerl_runops_(?:standard|debug)\b.*//s; - $data = Test::Valgrind::Suppressions->strip_tail($session, $data); + my @frames = grep length, split /\n/, $report->data; + + # If we see the runloop, match from here. + my $top = List::Util::first(sub { + $frames[$_] =~ /^\s*fun:Perl_runops_(?:standard|debug)\b/ + }, 0 .. $#frames); + --$top if $top; + + unless (defined $top) { + # Otherwise, match from the latest Perl_ symbol. + $top = List::Util::first(sub { + $frames[$_] =~ /^\s*fun:Perl_/ + }, reverse 0 .. $#frames); + } + + unless (defined $top) { + # Otherwise, match from the latest S_ symbol. + $top = List::Util::first(sub { + $frames[$_] =~ /^\s*fun:S_/ + }, reverse 0 .. $#frames); + } + + unless (defined $top) { + # Otherwise, match from the latest XS_ symbol. + $top = List::Util::first(sub { + $frames[$_] =~ /^\s*fun:XS_/ + }, reverse 0 .. $#frames); + } + + $#frames = $top if defined $top; + + my $data = join "\n", @frames, ''; + + $data = Test::Valgrind::Suppressions->maybe_generalize($session, $data); $report->new( id => $report->id, @@ -256,7 +289,7 @@ You can find documentation for this module with the perldoc command. =head1 COPYRIGHT & LICENSE -Copyright 2009,2010,2011,2013,2015 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.