projects
/
project
/
luci.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
6202881
)
build/i18n-lua2po.pl: generate *.pot files if target language is unspecified, don...
author
Jo-Philipp Wich
<jow@openwrt.org>
Thu, 14 May 2009 20:16:00 +0000
(20:16 +0000)
committer
Jo-Philipp Wich
<jow@openwrt.org>
Thu, 14 May 2009 20:16:00 +0000
(20:16 +0000)
build/i18n-lua2po.pl
patch
|
blob
|
history
diff --git
a/build/i18n-lua2po.pl
b/build/i18n-lua2po.pl
index
262b427
..
a9bc3b4
100755
(executable)
--- a/
build/i18n-lua2po.pl
+++ b/
build/i18n-lua2po.pl
@@
-1,6
+1,6
@@
#!/usr/bin/perl
#!/usr/bin/perl
-@ARGV
== 3 || die "Usage: $0 <source-dir> <dest-dir> <target-language>
\n";
+@ARGV
>= 2 || die "Usage: $0 <source-dir> <dest-dir> [<target-language>]
\n";
my $source_dir = shift @ARGV;
my $target_dir = shift @ARGV;
my $source_dir = shift @ARGV;
my $target_dir = shift @ARGV;
@@
-17,13
+17,13
@@
if( ! -d $target_dir )
my %target_strings;
my %target_strings;
-if( open F, "find $source_dir -path '*/luasrc/i18n/*' -name '*.$target_lang.lua' |" )
+if(
$target_lang &&
open F, "find $source_dir -path '*/luasrc/i18n/*' -name '*.$target_lang.lua' |" )
{
while( chomp( my $file = readline F ) )
{
if( open L, "< $file" )
{
{
while( chomp( my $file = readline F ) )
{
if( open L, "< $file" )
{
- my ( $basename ) = $file =~ m{.+/([^/]+)\.
\w
+\.lua$};
+ my ( $basename ) = $file =~ m{.+/([^/]+)\.
[\w\-]
+\.lua$};
$target_strings{$basename} = { };
while( chomp( my $entry = readline L ) )
$target_strings{$basename} = { };
while( chomp( my $entry = readline L ) )
@@
-45,6
+45,7
@@
if( open F, "find $source_dir -path '*/luasrc/i18n/*' -name '*.$target_lang.lua'
if( $k && $v )
{
$v =~ s/"/\\"/g;
if( $k && $v )
{
$v =~ s/"/\\"/g;
+ $v =~ s/\\\\"/\\"/g;
$target_strings{$basename}{$k} = $v;
}
}
$target_strings{$basename}{$k} = $v;
}
}
@@
-59,16
+60,18
@@
if( open F, "find $source_dir -path '*/luasrc/i18n/*' -name '*.$target_lang.lua'
if( open F, "find . -path '*/luasrc/i18n/*' -name '*.$master_lang.lua' |" )
{
if( open F, "find . -path '*/luasrc/i18n/*' -name '*.$master_lang.lua' |" )
{
+ my $ext = $target_lang ? "$target_lang.po" : "pot";
+
while( chomp( my $file = readline F ) )
{
if( open L, "< $file" )
{
my ( $basename ) = $file =~ m{.+/([^/]+)\.\w+\.lua$};
while( chomp( my $file = readline F ) )
{
if( open L, "< $file" )
{
my ( $basename ) = $file =~ m{.+/([^/]+)\.\w+\.lua$};
- if( open T, "> $target_dir/$basename.$
target_lang.po
" )
+ if( open T, "> $target_dir/$basename.$
ext
" )
{
printf "Generating %-40s ",
{
printf "Generating %-40s ",
- "$target_dir/$basename.$
target_lang.po
";
+ "$target_dir/$basename.$
ext
";
printf T "# %s.%s.po\n# generated from %s\n\nmsgid \"\"\n" .
"msgstr \"Content-Type: text/plain; charset=UTF-8\"\n\n",
printf T "# %s.%s.po\n# generated from %s\n\nmsgid \"\"\n" .
"msgstr \"Content-Type: text/plain; charset=UTF-8\"\n\n",
@@
-93,10
+96,11
@@
if( open F, "find . -path '*/luasrc/i18n/*' -name '*.$master_lang.lua' |" )
if( $k && $v )
{
$v =~ s/"/\\"/g;
if( $k && $v )
{
$v =~ s/"/\\"/g;
+ $v =~ s/\\\\"/\\"/g;
printf T "#: %s:%d\n#. \"%s\"\nmsgid \"%s\"\nmsgstr \"%s\"\n\n",
$file, $., $v, $k,
( $target_strings{$basename} && $target_strings{$basename}{$k} )
printf T "#: %s:%d\n#. \"%s\"\nmsgid \"%s\"\nmsgstr \"%s\"\n\n",
$file, $., $v, $k,
( $target_strings{$basename} && $target_strings{$basename}{$k} )
- ? $target_strings{$basename}{$k} :
$v
;
+ ? $target_strings{$basename}{$k} :
""
;
}
}
}
}