diff options
author | Friendika <info@friendika.com> | 2011-03-18 05:07:42 -0700 |
---|---|---|
committer | Friendika <info@friendika.com> | 2011-03-18 05:07:42 -0700 |
commit | 9838245c6c9b2e311650b53a1c3aa1ef778ef935 (patch) | |
tree | ceb9f5edd50cd039e28362a59c4c2d354bb88e67 /util/po2php.php | |
parent | 43234a667878327a825914070884161c6d57271e (diff) | |
parent | e307846c2d89cf450ed2e7ddf8f325f5f4581f8f (diff) | |
download | volse-hubzilla-9838245c6c9b2e311650b53a1c3aa1ef778ef935.tar.gz volse-hubzilla-9838245c6c9b2e311650b53a1c3aa1ef778ef935.tar.bz2 volse-hubzilla-9838245c6c9b2e311650b53a1c3aa1ef778ef935.zip |
Merge branch 'gettext' of https://github.com/fabrixxm/friendika into fabrixxm-gettext
Diffstat (limited to 'util/po2php.php')
-rw-r--r-- | util/po2php.php | 103 |
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 |