aboutsummaryrefslogtreecommitdiffstats
path: root/util/po2php.php
diff options
context:
space:
mode:
authorTobias Diekershoff <tobias.diekershoff@gmx.net>2011-03-18 18:07:37 +0100
committerTobias Diekershoff <tobias.diekershoff@gmx.net>2011-03-18 18:07:37 +0100
commit878bdeccfd66b7b8229fd761c23ba13bc51c7454 (patch)
tree6b881c4f71389ef6aa49776e8b99ac65f30f4ec2 /util/po2php.php
parentf4f5095e19badcc85453182b86bff97f57228257 (diff)
parent9838245c6c9b2e311650b53a1c3aa1ef778ef935 (diff)
downloadvolse-hubzilla-878bdeccfd66b7b8229fd761c23ba13bc51c7454.tar.gz
volse-hubzilla-878bdeccfd66b7b8229fd761c23ba13bc51c7454.tar.bz2
volse-hubzilla-878bdeccfd66b7b8229fd761c23ba13bc51c7454.zip
Merge branch 'master' of git://github.com/friendika/friendika
Diffstat (limited to 'util/po2php.php')
-rw-r--r--util/po2php.php103
1 files changed, 103 insertions, 0 deletions
diff --git a/util/po2php.php b/util/po2php.php
new file mode 100644
index 000000000..66edd290c
--- /dev/null
+++ b/util/po2php.php
@@ -0,0 +1,103 @@
+<?php
+
+
+function po2php_run($argv, $argc) {
+
+ if ($argc!=2) {
+ print "Usage: ".$argv[0]." <file.po>\n\n";
+ return;
+ }
+
+ $pofile = $argv[1];
+ $outfile = dirname($pofile)."/strings.php";
+
+ if (!file_exists($pofile)){
+ print "Unable to find '$pofile'\n";
+ return;
+ }
+
+ print "Out to '$outfile'\n";
+
+ $out="<?php\n\n";
+
+ $infile = file($pofile);
+ $k="";
+ $v="";
+ $arr = False;
+ $ink = False;
+ $inv = False;
+ foreach ($infile as $l) {
+ $len = strlen($l);
+ if ($l[0]=="#") $l="";
+ if (substr($l,0,15)=='"Plural-Forms: '){
+ $match=Array();
+ preg_match("|nplurals=([0-9]*); plural=(.*);|", $l, $match);
+ $cond = str_replace('n','$n',$match[2]);
+ $out .= 'function string_plural_select($n){'."\n";
+ $out .= ' return '.$cond.';'."\n";
+ $out .= '}'."\n";
+ }
+
+
+
+
+ if ($k!="" && substr($l,0,7)=="msgstr "){
+ if ($ink) { $ink = False; $out .= '$a->strings["'.$k.'"] = '; }
+ if ($inv) { $inv = False; $out .= '"'.$v.'"'; }
+
+ $v = substr($l,8,$len-10);
+ $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";
+ }
+
+ if (substr($l,0,6)=="msgid_") { $ink = False; $out .= '$a->strings["'.$k.'"] = '; };
+
+
+ if ($ink) {
+ $k .= trim($l,"\"\r\n");
+ //$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 = "";
+ }
+ $ink = True;
+ }
+
+ if ($inv && substr($l,0,6)!="msgstr") {
+ $v .= trim($l,"\"\r\n");
+ //$out .= '$a->strings['.$k.'] = ';
+ }
+
+
+ }
+
+ if ($inv) { $inv = False; $out .= '"'.$v.'"'; }
+ if ($k!="") $out .= $arr?");\n":";\n";
+
+ file_put_contents($outfile, $out);
+
+}
+
+if (array_search(__file__,get_included_files())===0){
+ po2php_run($argv,$argc);
+} \ No newline at end of file