diff options
author | einhverfr <einhverfr@4979c152-3d1c-0410-bac9-87ea11338e46> | 2007-04-26 18:00:56 +0000 |
---|---|---|
committer | einhverfr <einhverfr@4979c152-3d1c-0410-bac9-87ea11338e46> | 2007-04-26 18:00:56 +0000 |
commit | 666fd833584fe2e3618a397fe9d9a9bdf4c5b94b (patch) | |
tree | 19c4444705fd7f7803e0d7b597659c11d7e85b73 /LedgerSMB/locales.pl | |
parent | 2edd2e4de0f08a0a5f23647ea715f279671a0b89 (diff) |
Doing a simple Perltidy commit so that I can evaluate differences between the branches and make sure patches are up to date
git-svn-id: https://ledger-smb.svn.sourceforge.net/svnroot/ledger-smb/trunk@1103 4979c152-3d1c-0410-bac9-87ea11338e46
Diffstat (limited to 'LedgerSMB/locales.pl')
-rwxr-xr-x | LedgerSMB/locales.pl | 537 |
1 files changed, 277 insertions, 260 deletions
diff --git a/LedgerSMB/locales.pl b/LedgerSMB/locales.pl index 0bfc2503..e4ade0d0 100755 --- a/LedgerSMB/locales.pl +++ b/LedgerSMB/locales.pl @@ -8,26 +8,30 @@ use FileHandle; use Getopt::Long; Getopt::Long::Configure('bundling'); -$basedir = "../.."; -$bindir = "$basedir/bin"; +$basedir = "../.."; +$bindir = "$basedir/bin"; $customdir = "$bindir/custom"; -$menufile = "menu.ini"; +$menufile = "menu.ini"; my $excludeCustom = 0; -my $buildAll = 0; -my $noMissing = 0; -my $goodOpt = 0; -$goodOpt = GetOptions ( - 'n' => \$excludeCustom, 'no-custom' => \$excludeCustom, - 'a' => \$buildAll, 'build-all' => \$buildAll, - 'm' => \$noMissing, 'no-missing' => \$noMissing); - -if (!$goodOpt) { - printf "Invalid options\n"; - exit 1; +my $buildAll = 0; +my $noMissing = 0; +my $goodOpt = 0; +$goodOpt = GetOptions( + 'n' => \$excludeCustom, + 'no-custom' => \$excludeCustom, + 'a' => \$buildAll, + 'build-all' => \$buildAll, + 'm' => \$noMissing, + 'no-missing' => \$noMissing +); + +if ( !$goodOpt ) { + printf "Invalid options\n"; + exit 1; } -open(FH, "LANGUAGE"); +open( FH, "LANGUAGE" ); $language = <FH>; close(FH); chomp $language; @@ -44,325 +48,338 @@ closedir DIR; @customfiles = () if ($excludeCustom); if ($excludeCustom) { - @menufiles = ($menufile); -} else { - opendir DIR, "$bindir" or die "$!"; - @menufiles = grep { /.*?_$menufile$/ } readdir DIR; - closedir DIR; + @menufiles = ($menufile); +} +else { + opendir DIR, "$bindir" or die "$!"; + @menufiles = grep { /.*?_$menufile$/ } readdir DIR; + closedir DIR; ## unshift @menufiles, $menufile; ## opendir DIR, "$customdir" or die "$!"; ## @menufiles = grep { /^$menufile$/ } readdir DIR; ## closedir DIR; - unshift @menufiles, $menufile; + unshift @menufiles, $menufile; } -if (-f "all") { - eval { require "all"; }; - %all = %{$self{texts}}; - %{$self{texts}} = (); -} else { - # build %all file from individual files - foreach $file (@progfiles) { - &scanfile("$bindir/$file"); - } +if ( -f "all" ) { + eval { require "all"; }; + %all = %{ $self{texts} }; + %{ $self{texts} } = (); } - +else { + + # build %all file from individual files + foreach $file (@progfiles) { + &scanfile("$bindir/$file"); + } +} + # remove the old missing file -if (-f 'missing') { - unlink "missing"; +if ( -f 'missing' ) { + unlink "missing"; } - + foreach $file (@progfiles) { - - next if -d "$bindir/$file"; - %locale = (); - %submit = (); - %subrt = (); - @missing = (); - %missing = (); - - &scanfile("$bindir/$file"); - - # scan custom_{module}.pl or {login}_{module}.pl files - foreach $customfile (@customfiles) { - if ($customfile =~ /_$file/) { - if (-f "$bindir/$customfile") { - &scanfile("$bindir/$customfile"); - } + + next if -d "$bindir/$file"; + %locale = (); + %submit = (); + %subrt = (); + @missing = (); + %missing = (); + + &scanfile("$bindir/$file"); + + # scan custom_{module}.pl or {login}_{module}.pl files + foreach $customfile (@customfiles) { + if ( $customfile =~ /_$file/ ) { + if ( -f "$bindir/$customfile" ) { + &scanfile("$bindir/$customfile"); + } + } } - } - - # if this is the menu.pl file - if ($file eq 'menu.pl') { - foreach $item (@menufiles) { - &scanmenu("$basedir/$item"); + + # if this is the menu.pl file + if ( $file eq 'menu.pl' ) { + foreach $item (@menufiles) { + &scanmenu("$basedir/$item"); + } } - } - - $file =~ s/\.pl//; - - if (-f "$file.missing") { - eval { require "$file.missing"; }; - unlink "$file.missing"; - - for (keys %$missing) { - $self{texts}{$_} ||= $missing->{$_}; + + $file =~ s/\.pl//; + + if ( -f "$file.missing" ) { + eval { require "$file.missing"; }; + unlink "$file.missing"; + + for ( keys %$missing ) { + $self{texts}{$_} ||= $missing->{$_}; + } } - } - open FH, '>', "$file" or die "$! : $file"; + open FH, '>', "$file" or die "$! : $file"; - if ($charset) { - print FH qq|\$self{charset} = '$charset';\n\n|; - } + if ($charset) { + print FH qq|\$self{charset} = '$charset';\n\n|; + } - print FH q|$self{texts} = { + print FH q|$self{texts} = { |; - foreach $key (sort keys %locale) { - $text = ($self{texts}{$key}) ? $self{texts}{$key} : $all{$key}; - $count++; - - $text =~ s/'/\\'/g; - $text =~ s/\\$/\\\\/; - - $keytext = $key; - $keytext =~ s/'/\\'/g; - $keytext =~ s/\\$/\\\\/; - - if (!$text) { - $notext++; - push @missing, $keytext; - next; + foreach $key ( sort keys %locale ) { + $text = ( $self{texts}{$key} ) ? $self{texts}{$key} : $all{$key}; + $count++; + + $text =~ s/'/\\'/g; + $text =~ s/\\$/\\\\/; + + $keytext = $key; + $keytext =~ s/'/\\'/g; + $keytext =~ s/\\$/\\\\/; + + if ( !$text ) { + $notext++; + push @missing, $keytext; + next; + } + + print FH qq| '$keytext'| + . ( ' ' x ( 27 - length($keytext) ) ) + . qq| => '$text',\n|; } - - print FH qq| '$keytext'|.(' ' x (27-length($keytext))).qq| => '$text',\n|; - } - print FH q|}; + print FH q|}; $self{subs} = { |; - - foreach $key (sort keys %subrt) { - $text = $key; - $text =~ s/'/\\'/g; - $text =~ s/\\$/\\\\/; - print FH qq| '$text'|.(' ' x (27-length($text))).qq| => '$text',\n|; - } - - foreach $key (sort keys %submit) { - $text = ($self{texts}{$key}) ? $self{texts}{$key} : $all{$key}; - next unless $text; - - $text =~ s/'/\\'/g; - $text =~ s/\\$/\\\\/; - - $english_sub = $key; - $english_sub =~ s/'/\\'/g; - $english_sub =~ s/\\$/\\\\/; - $english_sub = lc $key; - - $translated_sub = lc $text; - $english_sub =~ s/( |-|,|\/|\.$)/_/g; - $translated_sub =~ s/( |-|,|\/|\.$)/_/g; - print FH qq| '$translated_sub'|.(' ' x (27-length($translated_sub))).qq| => '$english_sub',\n|; - } - - print FH q|}; + + foreach $key ( sort keys %subrt ) { + $text = $key; + $text =~ s/'/\\'/g; + $text =~ s/\\$/\\\\/; + print FH qq| '$text'| + . ( ' ' x ( 27 - length($text) ) ) + . qq| => '$text',\n|; + } + + foreach $key ( sort keys %submit ) { + $text = ( $self{texts}{$key} ) ? $self{texts}{$key} : $all{$key}; + next unless $text; + + $text =~ s/'/\\'/g; + $text =~ s/\\$/\\\\/; + + $english_sub = $key; + $english_sub =~ s/'/\\'/g; + $english_sub =~ s/\\$/\\\\/; + $english_sub = lc $key; + + $translated_sub = lc $text; + $english_sub =~ s/( |-|,|\/|\.$)/_/g; + $translated_sub =~ s/( |-|,|\/|\.$)/_/g; + print FH qq| '$translated_sub'| + . ( ' ' x ( 27 - length($translated_sub) ) ) + . qq| => '$english_sub',\n|; + } + + print FH q|}; 1; |; - close FH; + close FH; - if (!$noMissing) { - if (@missing) { - open FH, '>', "$file.missing" or die "$! : missing"; + if ( !$noMissing ) { + if (@missing) { + open FH, '>', "$file.missing" or die "$! : missing"; - print FH qq|# module $file + print FH qq|# module $file # add the missing texts and run locales.pl to rebuild \$missing = { |; - foreach $text (@missing) { - $text =~ s/'/\\'/g; - $text =~ s/\\$/\\\\/; - print FH qq| '$text'|.(' ' x (27-length($text))).qq| => '',\n|; - } + foreach $text (@missing) { + $text =~ s/'/\\'/g; + $text =~ s/\\$/\\\\/; + print FH qq| '$text'| + . ( ' ' x ( 27 - length($text) ) ) + . qq| => '',\n|; + } - print FH q|}; + print FH q|}; 1; |; - close FH; - + close FH; + + } } - } - - # redo the all file - if ($buildAll) { - open FH, '>', "all" or die "$! : all"; + # redo the all file + if ($buildAll) { + open FH, '>', "all" or die "$! : all"; - print FH q|# These are all the texts to build the translations files. + print FH q|# These are all the texts to build the translations files. # to build unique strings edit the module files instead # this file is just a shortcut to build strings which are the same |; - if ($charset) { - print FH qq|\$self{charset} = '$charset';\n\n|; - } + if ($charset) { + print FH qq|\$self{charset} = '$charset';\n\n|; + } - print FH q| + print FH q| $self{texts} = { |; - foreach $key (sort keys %all) { - $keytext = $key; - $keytext =~ s/'/\\'/g; - $keytext =~ s/\\$/\\\\/; - - $text = $all{$key}; - $text =~ s/'/\\'/g; - $text =~ s/\\$/\\\\/; - print FH qq| '$keytext'|.(' ' x (27-length($keytext))).qq| => '$text',\n|; - } + foreach $key ( sort keys %all ) { + $keytext = $key; + $keytext =~ s/'/\\'/g; + $keytext =~ s/\\$/\\\\/; - print FH q|}; + $text = $all{$key}; + $text =~ s/'/\\'/g; + $text =~ s/\\$/\\\\/; + print FH qq| '$keytext'| + . ( ' ' x ( 27 - length($keytext) ) ) + . qq| => '$text',\n|; + } + + print FH q|}; 1; |; - close FH; - - } + close FH; + + } } -$per = sprintf("%.1f", ($count - $notext) / $count * 100); +$per = sprintf( "%.1f", ( $count - $notext ) / $count * 100 ); print "\n$language - ${per}%\n"; exit; -# eof +# eof sub scanfile { - my ($file, $level) = @_; - - my $fh = new FileHandle; - return unless (-e $file or $file !~ /custom/); - open $fh, '<', "$file" or die "$! : $file"; - - $file =~ s/\.pl//; - $file =~ s/$bindir\///; - - %temp = (); - for (keys %{$self{texts}}) { - $temp{$_} = $self{texts}{$_}; - } - - # read translation file if it exists - if (-f $file) { - eval { do "$file"; }; - for (keys %{$self{texts}}) { - $all{$_} ||= $self{texts}{$_}; - if ($level) { - $temp{$_} ||= $self{texts}{$_}; - } else { - $temp{$_} = $self{texts}{$_}; - } + my ( $file, $level ) = @_; + + my $fh = new FileHandle; + return unless ( -e $file or $file !~ /custom/ ); + open $fh, '<', "$file" or die "$! : $file"; + + $file =~ s/\.pl//; + $file =~ s/$bindir\///; + + %temp = (); + for ( keys %{ $self{texts} } ) { + $temp{$_} = $self{texts}{$_}; } - } - - %{$self{texts}} = (); - for (sort keys %temp) { - $self{texts}{$_} = $temp{$_}; - } - - - while (<$fh>) { - # is this another file - if (/require\s+\W.*\.pl/) { - my $newfile = $&; - $newfile =~ s/require\s+\W//; - $newfile =~ s/\$form->{path}\///; - &scanfile("$basedir/$newfile", 1) if $newfile !~ /_/; + + # read translation file if it exists + if ( -f $file ) { + eval { do "$file"; }; + for ( keys %{ $self{texts} } ) { + $all{$_} ||= $self{texts}{$_}; + if ($level) { + $temp{$_} ||= $self{texts}{$_}; + } + else { + $temp{$_} = $self{texts}{$_}; + } + } } - - # is this a sub ? - if (/^sub /) { - ($null, $subrt) = split / +/; - $subrt{$subrt} = 1; - next; + + %{ $self{texts} } = (); + for ( sort keys %temp ) { + $self{texts}{$_} = $temp{$_}; } - - my $rc = 1; - - while ($rc) { - if (/Locale/) { - if (!/^use /) { - my ($null, $country) = split /,/; - $country =~ s/^ +["']//; - $country =~ s/["'].*//; - } - } - - if (/\$locale->text.*?\W\)/) { - my $string = $&; - $string =~ s/\$locale->text\(\s*['"(q|qq)]['\/\\\|~]*//; - $string =~ s/\W\)+.*$//; - - # if there is no $ in the string record it - unless ($string =~ /\$\D.*/) { - # this guarantees one instance of string - $locale{$string} = 1; - - # is it a submit button before $locale-> - if (/type="?submit"?/i) { - $submit{$string} = 1; - } - } - } - - # exit loop if there are no more locales on this line - ($rc) = ($' =~ /\$locale->text/); - # strip text - s/^.*?\$locale->text.*?\)//; + + while (<$fh>) { + + # is this another file + if (/require\s+\W.*\.pl/) { + my $newfile = $&; + $newfile =~ s/require\s+\W//; + $newfile =~ s/\$form->{path}\///; + &scanfile( "$basedir/$newfile", 1 ) if $newfile !~ /_/; + } + + # is this a sub ? + if (/^sub /) { + ( $null, $subrt ) = split / +/; + $subrt{$subrt} = 1; + next; + } + + my $rc = 1; + + while ($rc) { + if (/Locale/) { + if ( !/^use / ) { + my ( $null, $country ) = split /,/; + $country =~ s/^ +["']//; + $country =~ s/["'].*//; + } + } + + if (/\$locale->text.*?\W\)/) { + my $string = $&; + $string =~ s/\$locale->text\(\s*['"(q|qq)]['\/\\\|~]*//; + $string =~ s/\W\)+.*$//; + + # if there is no $ in the string record it + unless ( $string =~ /\$\D.*/ ) { + + # this guarantees one instance of string + $locale{$string} = 1; + + # is it a submit button before $locale-> + if (/type="?submit"?/i) { + $submit{$string} = 1; + } + } + } + + # exit loop if there are no more locales on this line + ($rc) = ( $' =~ /\$locale->text/ ); + + # strip text + s/^.*?\$locale->text.*?\)//; + } } - } - close($fh); + close($fh); } - sub scanmenu { - my $file = shift; - - my $fh = new FileHandle; - open $fh, '<', "$file" or die "$! : $file"; - - my @a = grep /^\[/, <$fh>; - close($fh); - - # strip [] - grep { s/(\[|\])//g } @a; - - foreach my $item (@a) { - $item =~ s/ *$//; - @b = split /--/, $item; - foreach $string (@b) { - chomp $string; - if ($string !~ /^\s*$/) { - $locale{$string} = 1; - } + my $file = shift; + + my $fh = new FileHandle; + open $fh, '<', "$file" or die "$! : $file"; + + my @a = grep /^\[/, <$fh>; + close($fh); + + # strip [] + grep { s/(\[|\])//g } @a; + + foreach my $item (@a) { + $item =~ s/ *$//; + @b = split /--/, $item; + foreach $string (@b) { + chomp $string; + if ( $string !~ /^\s*$/ ) { + $locale{$string} = 1; + } + } } - } - -} +} |