X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=util%2Fpo2php.php;h=c703172af76acedc30ab5d87928af5d8282e9090;hb=9f4b89726176f9596cf3330a68cfab8cab5ab361;hp=15ee1cd2c22184ca7e0cea25bc6a6dba2b08ff60;hpb=89781ba428f553e8eb4f415832e7e575adf141e0;p=friendica.git diff --git a/util/po2php.php b/util/po2php.php index 15ee1cd2c2..c703172af7 100644 --- a/util/po2php.php +++ b/util/po2php.php @@ -1,17 +1,25 @@ \n\n"; + print "Usage: ".$argv[0]." \n\n"; return; } - $mofile = $argv[1]; - $outfile = dirname($mofile)."/strings.php"; - - if (!file_exists($mofile)){ - print "Unable to find '$mofile'\n"; + $pofile = $argv[1]; + $outfile = dirname($pofile)."/strings.php"; + + if(strstr($outfile,'util')) + $lang = 'en'; + else + $lang = str_replace('-','_',basename(dirname($pofile))); + + + + if (!file_exists($pofile)){ + print "Unable to find '$pofile'\n"; return; } @@ -19,48 +27,90 @@ function po2php_run($argv, $argc) { $out="strings['.$k.'] = '; - } else { - $k = ""; - } - } + + if ($k!="" && substr($l,0,7)=="msgstr "){ - $v = substr($l,7,$len-8); - $out .= $v; + if ($ink) { $ink = False; $out .= '$a->strings["'.$k.'"] = '; } + if ($inv) { $inv = False; $out .= '"'.$v.'"'; } + + $v = substr($l,8,$len-10); + $v = preg_replace_callback($escape_s_exp,'escape_s',$v); + $inv = True; + //$out .= $v; } if ($k!="" && substr($l,0,7)=="msgstr["){ + if ($ink) { $ink = False; $out .= '$a->strings["'.$k.'"] = '; } + if ($inv) { $inv = False; $out .= '"'.$v.'"'; } + if (!$arr) { $arr=True; $out .= "array(\n"; } $match=Array(); preg_match("|\[([0-9]*)\] (.*)|", $l, $match); - $out .= "\t". $match[1]." => ". $match[2] .",\n"; + $out .= "\t". + preg_replace_callback($escape_s_exp,'escape_s',$match[1]) + ." => " + .preg_replace_callback($escape_s_exp,'escape_s',$match[2]) .",\n"; + } + + if (substr($l,0,6)=="msgid_") { $ink = False; $out .= '$a->strings["'.$k.'"] = '; }; + + + if ($ink) { + $k .= trim($l,"\"\r\n"); + $k = preg_replace_callback($escape_s_exp,'escape_s',$k); + //$out .= '$a->strings['.$k.'] = '; } - } + if (substr($l,0,6)=="msgid "){ + if ($inv) { $inv = False; $out .= '"'.$v.'"'; } + if ($k!="") $out .= $arr?");\n":";\n"; + $arr=False; + $k = str_replace("msgid ","",$l); + if ($k != '""' ) { + $k = trim($k,"\"\r\n"); + } else { + $k = ""; + } + + $k = preg_replace_callback($escape_s_exp,'escape_s',$k); + $ink = True; + } + + if ($inv && substr($l,0,6)!="msgstr") { + $v .= trim($l,"\"\r\n"); + $v = preg_replace_callback($escape_s_exp,'escape_s',$v); + //$out .= '$a->strings['.$k.'] = '; + } + + } + + if ($inv) { $inv = False; $out .= '"'.$v.'"'; } if ($k!="") $out .= $arr?");\n":";\n"; file_put_contents($outfile, $out); @@ -69,4 +119,4 @@ function po2php_run($argv, $argc) { if (array_search(__file__,get_included_files())===0){ po2php_run($argv,$argc); -} \ No newline at end of file +}