package SVK::Log::Filter::Grep; use strict; use warnings; use SVK::I18N; use base qw( SVK::Log::Filter::Selection ); sub setup { my ($self) = @_; my $search = $self->{argument}; my $rx = eval "qr{$search}i" or die loc( "Grep: Invalid regular expression '%1'.\n", $search ); $self->{pattern} = $rx; } sub revision { my ($self, $args) = @_; my $log = $args->{props}{'svn:log'}; $self->pipeline('next') if $log !~ m/$self->{pattern}/; } 1; __END__ =head1 SYNOPSIS SVK::Log::Filter::Grep - search log messages for a given pattern =head1 DESCRIPTION The Grep filter requires a single Perl pattern (regular expression) as its argument. The pattern is then applied to the svn:log property of each revision it receives. If the pattern matches, the revision is allowed to continue down the pipeline. If the pattern fails to match, the pipeline immediately skips to the next revision. The pattern is applied with the /i modifier (case insensitivity). If you want case-sensitivity or other modifications to the behavior of your pattern, you must use the "(?imsx-imsx)" extended pattern (see "perldoc perlre" for details). For example, to search for log messages that match exactly the characters "foo" you might use svk log --filter "grep (?-i)foo" However, to search for "foo" without regards for case, one might try svk log --filter "grep foo" The result of any capturing parentheses inside the pattern are B available. If demand dictates, the Grep filter could be modified to place the captured value somewhere in the stash for other filters to access. If the pattern contains a pipe character ('|'), it must be escaped by preceding it with a '\' character. Otherwise, the portion of the pattern after the pipe character is interpreted as the name of a log filter. =head1 STASH/PROPERTY MODIFICATIONS Grep leaves all properties and the stash intact. =head1 AUTHORS Michael Hendricks Emichael@ndrix.orgE =head1 COPYRIGHT Copyright 2003-2006 by Chia-liang Kao Eclkao@clkao.orgE. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See L =cut