From fa674176fde42e8011f9716e2b270bd5a95d983f Mon Sep 17 00:00:00 2001 From: Pavel Sanda Date: Wed, 6 Apr 2011 10:17:51 +0000 Subject: [PATCH] * pocheck.pl, allow synoptical check for critical bugs in translations. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@38275 a592a061-630c-0410-9148-cb99ea01b6c8 --- po/pocheck.pl | 32 +++++++++++++++++++------------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/po/pocheck.pl b/po/pocheck.pl index 53b2b6fa93..df25fdad3b 100755 --- a/po/pocheck.pl +++ b/po/pocheck.pl @@ -27,12 +27,13 @@ options is given, in which case we checks only for those requested. -s: Check for space at end -t: Check for uniform translation These options can be given with or without other options. --f: Ignore fuzzy translations. +-f: Ignore fuzzy translations -w: Only report summary total of errors +-i: Silent mode, report only errors EOT my %options; -getopts(":hacfmpqstw", \%options); +getopts(":hacfmpqstwi", \%options); if (defined($options{h})) { print $usage; @@ -43,6 +44,8 @@ my $only_total = defined($options{w}); delete $options{w} if $only_total; my $ignore_fuzzy = defined($options{f}); delete $options{f} if $ignore_fuzzy; +my $silent_mode = defined($options{i}); +delete $options{i} if $silent_mode; my $check_args = (!%options or defined($options{a})); my $check_colons = (!%options or defined($options{c})); @@ -56,7 +59,9 @@ my %trans; foreach my $pofilename ( @ARGV ) { my %bad; - print "Processing po file '$pofilename'...\n"; + if (!$silent_mode) { + print "Processing po file '$pofilename'...\n"; + } open( INPUT, "<$pofilename" ) || die "Cannot read po file '$pofilename'"; @@ -110,7 +115,7 @@ foreach my $pofilename ( @ARGV ) { my $n = 0; foreach my $arg (@argstrs) { $n = $arg if $arg > $n; } if ($n <= 0) { - print "Line $linenum: Problem finding arguments in:\n $msgid!\n" + print "$pofilename, line $linenum: Problem finding arguments in:\n $msgid!\n" unless $only_total; ++$bad{"Missing arguments"}; $warn++; @@ -118,7 +123,7 @@ foreach my $pofilename ( @ARGV ) { foreach my $i (1..$n) { my $arg = "%$i\\\$s"; if ( $msgstr !~ m/$arg/ ) { - print "Line $linenum: Missing argument `$arg'\n '$msgid' ==> '$msgstr'\n" + print "$pofilename, line $linenum: Missing argument `$arg'\n '$msgid' ==> '$msgstr'\n" unless $only_total; ++$bad{"Missing arguments"}; $warn++; @@ -220,14 +225,15 @@ foreach my $pofilename ( @ARGV ) { } } } - - if ($warn) { - while (my ($k, $v) = each %bad) { print "$k: $v\n"; } - if (scalar(keys %bad) > 1) { - print "Total warnings: $warn\n"; + if (!$silent_mode) { + if ($warn) { + while (my ($k, $v) = each %bad) { print "$k: $v\n"; } + if (scalar(keys %bad) > 1) { + print "Total warnings: $warn\n"; + } + } else { + print "No warnings!\n"; } - } else { - print "No warnings!\n"; + print "\n"; } - print "\n"; }