Sync POMO with GlotPress
See http://glotpress.trac.wordpress.org/browser/trunk/pomo/ git-svn-id: https://develop.svn.wordpress.org/trunk@22349 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
794c7f6b1c
commit
1a9ffb97a7
@ -2,7 +2,7 @@
|
|||||||
/**
|
/**
|
||||||
* Contains Translation_Entry class
|
* Contains Translation_Entry class
|
||||||
*
|
*
|
||||||
* @version $Id: entry.php 621 2011-06-13 12:21:50Z nbachiyski $
|
* @version $Id: entry.php 718 2012-10-31 00:32:02Z nbachiyski $
|
||||||
* @package pomo
|
* @package pomo
|
||||||
* @subpackage entry
|
* @subpackage entry
|
||||||
*/
|
*/
|
||||||
@ -65,14 +65,14 @@ class Translation_Entry {
|
|||||||
// prepend context and EOT, like in MO files
|
// prepend context and EOT, like in MO files
|
||||||
return is_null($this->context)? $this->singular : $this->context.chr(4).$this->singular;
|
return is_null($this->context)? $this->singular : $this->context.chr(4).$this->singular;
|
||||||
}
|
}
|
||||||
|
|
||||||
function merge_with(&$other) {
|
function merge_with(&$other) {
|
||||||
$this->flags = array_unique( array_merge( $this->flags, $other->flags ) );
|
$this->flags = array_unique( array_merge( $this->flags, $other->flags ) );
|
||||||
$this->references = array_unique( array_merge( $this->references, $other->references ) );
|
$this->references = array_unique( array_merge( $this->references, $other->references ) );
|
||||||
if ( $this->extracted_comments != $other->extracted_comments ) {
|
if ( $this->extracted_comments != $other->extracted_comments ) {
|
||||||
$this->extracted_comments .= $other->extracted_comments;
|
$this->extracted_comments .= $other->extracted_comments;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
endif;
|
endif;
|
@ -2,7 +2,7 @@
|
|||||||
/**
|
/**
|
||||||
* Class for working with MO files
|
* Class for working with MO files
|
||||||
*
|
*
|
||||||
* @version $Id: mo.php 602 2011-01-30 12:43:29Z nbachiyski $
|
* @version $Id: mo.php 718 2012-10-31 00:32:02Z nbachiyski $
|
||||||
* @package pomo
|
* @package pomo
|
||||||
* @subpackage mo
|
* @subpackage mo
|
||||||
*/
|
*/
|
||||||
@ -34,7 +34,7 @@ class MO extends Gettext_Translations {
|
|||||||
fclose($fh);
|
fclose($fh);
|
||||||
return $res;
|
return $res;
|
||||||
}
|
}
|
||||||
|
|
||||||
function export() {
|
function export() {
|
||||||
$tmp_fh = fopen("php://temp", 'r+');
|
$tmp_fh = fopen("php://temp", 'r+');
|
||||||
if ( !$tmp_fh ) return false;
|
if ( !$tmp_fh ) return false;
|
||||||
@ -42,9 +42,21 @@ class MO extends Gettext_Translations {
|
|||||||
rewind( $tmp_fh );
|
rewind( $tmp_fh );
|
||||||
return stream_get_contents( $tmp_fh );
|
return stream_get_contents( $tmp_fh );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function is_entry_good_for_export( $entry ) {
|
||||||
|
if ( empty( $entry->translations ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !array_filter( $entry->translations ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
function export_to_file_handle($fh) {
|
function export_to_file_handle($fh) {
|
||||||
$entries = array_filter($this->entries, create_function('$e', 'return !empty($e->translations);'));
|
$entries = array_filter( $this->entries, array( $this, 'is_entry_good_for_export' ) );
|
||||||
ksort($entries);
|
ksort($entries);
|
||||||
$magic = 0x950412de;
|
$magic = 0x950412de;
|
||||||
$revision = 0;
|
$revision = 0;
|
||||||
@ -57,7 +69,7 @@ class MO extends Gettext_Translations {
|
|||||||
fwrite($fh, pack('V*', $magic, $revision, $total, $originals_lenghts_addr,
|
fwrite($fh, pack('V*', $magic, $revision, $total, $originals_lenghts_addr,
|
||||||
$translations_lenghts_addr, $size_of_hash, $hash_addr));
|
$translations_lenghts_addr, $size_of_hash, $hash_addr));
|
||||||
fseek($fh, $originals_lenghts_addr);
|
fseek($fh, $originals_lenghts_addr);
|
||||||
|
|
||||||
// headers' msgid is an empty string
|
// headers' msgid is an empty string
|
||||||
fwrite($fh, pack('VV', 0, $current_addr));
|
fwrite($fh, pack('VV', 0, $current_addr));
|
||||||
$current_addr++;
|
$current_addr++;
|
||||||
@ -69,24 +81,24 @@ class MO extends Gettext_Translations {
|
|||||||
fwrite($fh, pack('VV', $length, $current_addr));
|
fwrite($fh, pack('VV', $length, $current_addr));
|
||||||
$current_addr += $length + 1; // account for the NULL byte after
|
$current_addr += $length + 1; // account for the NULL byte after
|
||||||
}
|
}
|
||||||
|
|
||||||
$exported_headers = $this->export_headers();
|
$exported_headers = $this->export_headers();
|
||||||
fwrite($fh, pack('VV', strlen($exported_headers), $current_addr));
|
fwrite($fh, pack('VV', strlen($exported_headers), $current_addr));
|
||||||
$current_addr += strlen($exported_headers) + 1;
|
$current_addr += strlen($exported_headers) + 1;
|
||||||
$translations_table = $exported_headers . chr(0);
|
$translations_table = $exported_headers . chr(0);
|
||||||
|
|
||||||
foreach($entries as $entry) {
|
foreach($entries as $entry) {
|
||||||
$translations_table .= $this->export_translations($entry) . chr(0);
|
$translations_table .= $this->export_translations($entry) . chr(0);
|
||||||
$length = strlen($this->export_translations($entry));
|
$length = strlen($this->export_translations($entry));
|
||||||
fwrite($fh, pack('VV', $length, $current_addr));
|
fwrite($fh, pack('VV', $length, $current_addr));
|
||||||
$current_addr += $length + 1;
|
$current_addr += $length + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
fwrite($fh, $originals_table);
|
fwrite($fh, $originals_table);
|
||||||
fwrite($fh, $translations_table);
|
fwrite($fh, $translations_table);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function export_original($entry) {
|
function export_original($entry) {
|
||||||
//TODO: warnings for control characters
|
//TODO: warnings for control characters
|
||||||
$exported = $entry->singular;
|
$exported = $entry->singular;
|
||||||
@ -94,12 +106,12 @@ class MO extends Gettext_Translations {
|
|||||||
if (!is_null($entry->context)) $exported = $entry->context . chr(4) . $exported;
|
if (!is_null($entry->context)) $exported = $entry->context . chr(4) . $exported;
|
||||||
return $exported;
|
return $exported;
|
||||||
}
|
}
|
||||||
|
|
||||||
function export_translations($entry) {
|
function export_translations($entry) {
|
||||||
//TODO: warnings for control characters
|
//TODO: warnings for control characters
|
||||||
return implode(chr(0), $entry->translations);
|
return implode(chr(0), $entry->translations);
|
||||||
}
|
}
|
||||||
|
|
||||||
function export_headers() {
|
function export_headers() {
|
||||||
$exported = '';
|
$exported = '';
|
||||||
foreach($this->headers as $header => $value) {
|
foreach($this->headers as $header => $value) {
|
||||||
@ -195,8 +207,7 @@ class MO extends Gettext_Translations {
|
|||||||
$translation = $reader->substr( $strings, $t['pos'], $t['length'] );
|
$translation = $reader->substr( $strings, $t['pos'], $t['length'] );
|
||||||
|
|
||||||
if ('' === $original) {
|
if ('' === $original) {
|
||||||
$headers = $this->make_headers($translation);
|
$this->set_headers($this->make_headers($translation));
|
||||||
$this->set_headers($headers);
|
|
||||||
} else {
|
} else {
|
||||||
$entry = &$this->make_entry($original, $translation);
|
$entry = &$this->make_entry($original, $translation);
|
||||||
$this->entries[$entry->key()] = &$entry;
|
$this->entries[$entry->key()] = &$entry;
|
||||||
@ -208,7 +219,7 @@ class MO extends Gettext_Translations {
|
|||||||
/**
|
/**
|
||||||
* Build a Translation_Entry from original string and translation strings,
|
* Build a Translation_Entry from original string and translation strings,
|
||||||
* found in a MO file
|
* found in a MO file
|
||||||
*
|
*
|
||||||
* @static
|
* @static
|
||||||
* @param string $original original string to translate from MO file. Might contain
|
* @param string $original original string to translate from MO file. Might contain
|
||||||
* 0x04 as context separator or 0x00 as singular/plural separator
|
* 0x04 as context separator or 0x00 as singular/plural separator
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/**
|
/**
|
||||||
* Class for working with PO files
|
* Class for working with PO files
|
||||||
*
|
*
|
||||||
* @version $Id: po.php 589 2010-12-18 01:40:57Z nbachiyski $
|
* @version $Id: po.php 718 2012-10-31 00:32:02Z nbachiyski $
|
||||||
* @package pomo
|
* @package pomo
|
||||||
* @subpackage po
|
* @subpackage po
|
||||||
*/
|
*/
|
||||||
@ -18,7 +18,7 @@ ini_set('auto_detect_line_endings', 1);
|
|||||||
*/
|
*/
|
||||||
if ( !class_exists( 'PO' ) ):
|
if ( !class_exists( 'PO' ) ):
|
||||||
class PO extends Gettext_Translations {
|
class PO extends Gettext_Translations {
|
||||||
|
|
||||||
var $comments_before_headers = '';
|
var $comments_before_headers = '';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -80,10 +80,10 @@ class PO extends Gettext_Translations {
|
|||||||
if (false === $res) return false;
|
if (false === $res) return false;
|
||||||
return fclose($fh);
|
return fclose($fh);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Text to include as a comment before the start of the PO contents
|
* Text to include as a comment before the start of the PO contents
|
||||||
*
|
*
|
||||||
* Doesn't need to include # in the beginning of lines, these are added automatically
|
* Doesn't need to include # in the beginning of lines, these are added automatically
|
||||||
*/
|
*/
|
||||||
function set_comment_before_headers( $text ) {
|
function set_comment_before_headers( $text ) {
|
||||||
@ -120,10 +120,10 @@ class PO extends Gettext_Translations {
|
|||||||
$po = str_replace("$newline$quote$quote", '', $po);
|
$po = str_replace("$newline$quote$quote", '', $po);
|
||||||
return $po;
|
return $po;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gives back the original string from a PO-formatted string
|
* Gives back the original string from a PO-formatted string
|
||||||
*
|
*
|
||||||
* @static
|
* @static
|
||||||
* @param string $string PO-formatted string
|
* @param string $string PO-formatted string
|
||||||
* @return string enascaped string
|
* @return string enascaped string
|
||||||
@ -153,7 +153,7 @@ class PO extends Gettext_Translations {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Inserts $with in the beginning of every new line of $string and
|
* Inserts $with in the beginning of every new line of $string and
|
||||||
* returns the modified string
|
* returns the modified string
|
||||||
*
|
*
|
||||||
* @static
|
* @static
|
||||||
@ -229,9 +229,15 @@ class PO extends Gettext_Translations {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
PO::read_line($f, 'clear');
|
PO::read_line($f, 'clear');
|
||||||
return $res !== false;
|
if ( false === $res ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ( ! $this->headers && ! $this->entries ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function read_entry($f, $lineno = 0) {
|
function read_entry($f, $lineno = 0) {
|
||||||
$entry = new Translation_Entry();
|
$entry = new Translation_Entry();
|
||||||
// where were we in the last step
|
// where were we in the last step
|
||||||
@ -336,7 +342,7 @@ class PO extends Gettext_Translations {
|
|||||||
}
|
}
|
||||||
return array('entry' => $entry, 'lineno' => $lineno);
|
return array('entry' => $entry, 'lineno' => $lineno);
|
||||||
}
|
}
|
||||||
|
|
||||||
function read_line($f, $action = 'read') {
|
function read_line($f, $action = 'read') {
|
||||||
static $last_line = '';
|
static $last_line = '';
|
||||||
static $use_last_line = false;
|
static $use_last_line = false;
|
||||||
@ -349,11 +355,12 @@ class PO extends Gettext_Translations {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
$line = $use_last_line? $last_line : fgets($f);
|
$line = $use_last_line? $last_line : fgets($f);
|
||||||
|
$line = gp_endswith( $line, "\r\n" )? rtrim( $line, "\r\n" ) . "\n" : $line;
|
||||||
$last_line = $line;
|
$last_line = $line;
|
||||||
$use_last_line = false;
|
$use_last_line = false;
|
||||||
return $line;
|
return $line;
|
||||||
}
|
}
|
||||||
|
|
||||||
function add_comment_to_entry(&$entry, $po_comment_line) {
|
function add_comment_to_entry(&$entry, $po_comment_line) {
|
||||||
$first_two = substr($po_comment_line, 0, 2);
|
$first_two = substr($po_comment_line, 0, 2);
|
||||||
$comment = trim(substr($po_comment_line, 2));
|
$comment = trim(substr($po_comment_line, 2));
|
||||||
@ -367,7 +374,7 @@ class PO extends Gettext_Translations {
|
|||||||
$entry->translator_comments = trim($entry->translator_comments . "\n" . $comment);
|
$entry->translator_comments = trim($entry->translator_comments . "\n" . $comment);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function trim_quotes($s) {
|
function trim_quotes($s) {
|
||||||
if ( substr($s, 0, 1) == '"') $s = substr($s, 1);
|
if ( substr($s, 0, 1) == '"') $s = substr($s, 1);
|
||||||
if ( substr($s, -1, 1) == '"') $s = substr($s, 0, -1);
|
if ( substr($s, -1, 1) == '"') $s = substr($s, 0, -1);
|
||||||
|
@ -3,22 +3,22 @@
|
|||||||
* Classes, which help reading streams of data from files.
|
* Classes, which help reading streams of data from files.
|
||||||
* Based on the classes from Danilo Segan <danilo@kvota.net>
|
* Based on the classes from Danilo Segan <danilo@kvota.net>
|
||||||
*
|
*
|
||||||
* @version $Id: streams.php 597 2011-01-16 20:14:36Z nbachiyski $
|
* @version $Id: streams.php 718 2012-10-31 00:32:02Z nbachiyski $
|
||||||
* @package pomo
|
* @package pomo
|
||||||
* @subpackage streams
|
* @subpackage streams
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if ( !class_exists( 'POMO_Reader' ) ):
|
if ( !class_exists( 'POMO_Reader' ) ):
|
||||||
class POMO_Reader {
|
class POMO_Reader {
|
||||||
|
|
||||||
var $endian = 'little';
|
var $endian = 'little';
|
||||||
var $_post = '';
|
var $_post = '';
|
||||||
|
|
||||||
function POMO_Reader() {
|
function POMO_Reader() {
|
||||||
$this->is_overloaded = ((ini_get("mbstring.func_overload") & 2) != 0) && function_exists('mb_substr');
|
$this->is_overloaded = ((ini_get("mbstring.func_overload") & 2) != 0) && function_exists('mb_substr');
|
||||||
$this->_pos = 0;
|
$this->_pos = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the endianness of the file.
|
* Sets the endianness of the file.
|
||||||
*
|
*
|
||||||
@ -57,8 +57,8 @@ class POMO_Reader {
|
|||||||
$endian_letter = ('big' == $this->endian)? 'N' : 'V';
|
$endian_letter = ('big' == $this->endian)? 'N' : 'V';
|
||||||
return unpack($endian_letter.$count, $bytes);
|
return unpack($endian_letter.$count, $bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function substr($string, $start, $length) {
|
function substr($string, $start, $length) {
|
||||||
if ($this->is_overloaded) {
|
if ($this->is_overloaded) {
|
||||||
return mb_substr($string, $start, $length, 'ascii');
|
return mb_substr($string, $start, $length, 'ascii');
|
||||||
@ -66,7 +66,7 @@ class POMO_Reader {
|
|||||||
return substr($string, $start, $length);
|
return substr($string, $start, $length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function strlen($string) {
|
function strlen($string) {
|
||||||
if ($this->is_overloaded) {
|
if ($this->is_overloaded) {
|
||||||
return mb_strlen($string, 'ascii');
|
return mb_strlen($string, 'ascii');
|
||||||
@ -74,7 +74,7 @@ class POMO_Reader {
|
|||||||
return strlen($string);
|
return strlen($string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function str_split($string, $chunk_size) {
|
function str_split($string, $chunk_size) {
|
||||||
if (!function_exists('str_split')) {
|
if (!function_exists('str_split')) {
|
||||||
$length = $this->strlen($string);
|
$length = $this->strlen($string);
|
||||||
@ -86,8 +86,8 @@ class POMO_Reader {
|
|||||||
return str_split( $string, $chunk_size );
|
return str_split( $string, $chunk_size );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function pos() {
|
function pos() {
|
||||||
return $this->_pos;
|
return $this->_pos;
|
||||||
}
|
}
|
||||||
@ -95,7 +95,7 @@ class POMO_Reader {
|
|||||||
function is_resource() {
|
function is_resource() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function close() {
|
function close() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -108,11 +108,11 @@ class POMO_FileReader extends POMO_Reader {
|
|||||||
parent::POMO_Reader();
|
parent::POMO_Reader();
|
||||||
$this->_f = fopen($filename, 'rb');
|
$this->_f = fopen($filename, 'rb');
|
||||||
}
|
}
|
||||||
|
|
||||||
function read($bytes) {
|
function read($bytes) {
|
||||||
return fread($this->_f, $bytes);
|
return fread($this->_f, $bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
function seekto($pos) {
|
function seekto($pos) {
|
||||||
if ( -1 == fseek($this->_f, $pos, SEEK_SET)) {
|
if ( -1 == fseek($this->_f, $pos, SEEK_SET)) {
|
||||||
return false;
|
return false;
|
||||||
@ -120,19 +120,19 @@ class POMO_FileReader extends POMO_Reader {
|
|||||||
$this->_pos = $pos;
|
$this->_pos = $pos;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function is_resource() {
|
function is_resource() {
|
||||||
return is_resource($this->_f);
|
return is_resource($this->_f);
|
||||||
}
|
}
|
||||||
|
|
||||||
function feof() {
|
function feof() {
|
||||||
return feof($this->_f);
|
return feof($this->_f);
|
||||||
}
|
}
|
||||||
|
|
||||||
function close() {
|
function close() {
|
||||||
return fclose($this->_f);
|
return fclose($this->_f);
|
||||||
}
|
}
|
||||||
|
|
||||||
function read_all() {
|
function read_all() {
|
||||||
$all = '';
|
$all = '';
|
||||||
while ( !$this->feof() )
|
while ( !$this->feof() )
|
||||||
@ -148,9 +148,9 @@ if ( !class_exists( 'POMO_StringReader' ) ):
|
|||||||
* of a physical file.
|
* of a physical file.
|
||||||
*/
|
*/
|
||||||
class POMO_StringReader extends POMO_Reader {
|
class POMO_StringReader extends POMO_Reader {
|
||||||
|
|
||||||
var $_str = '';
|
var $_str = '';
|
||||||
|
|
||||||
function POMO_StringReader($str = '') {
|
function POMO_StringReader($str = '') {
|
||||||
parent::POMO_Reader();
|
parent::POMO_Reader();
|
||||||
$this->_str = $str;
|
$this->_str = $str;
|
||||||
@ -178,7 +178,7 @@ class POMO_StringReader extends POMO_Reader {
|
|||||||
function read_all() {
|
function read_all() {
|
||||||
return $this->substr($this->_str, $this->_pos, $this->strlen($this->_str));
|
return $this->substr($this->_str, $this->_pos, $this->strlen($this->_str));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
endif;
|
endif;
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/**
|
/**
|
||||||
* Class for a set of entries for translation and their associated headers
|
* Class for a set of entries for translation and their associated headers
|
||||||
*
|
*
|
||||||
* @version $Id: translations.php 590 2010-12-20 19:58:37Z nbachiyski $
|
* @version $Id: translations.php 718 2012-10-31 00:32:02Z nbachiyski $
|
||||||
* @package pomo
|
* @package pomo
|
||||||
* @subpackage translations
|
* @subpackage translations
|
||||||
*/
|
*/
|
||||||
@ -29,7 +29,7 @@ class Translations {
|
|||||||
$this->entries[$key] = &$entry;
|
$this->entries[$key] = &$entry;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function add_entry_or_merge($entry) {
|
function add_entry_or_merge($entry) {
|
||||||
if (is_array($entry)) {
|
if (is_array($entry)) {
|
||||||
$entry = new Translation_Entry($entry);
|
$entry = new Translation_Entry($entry);
|
||||||
@ -81,7 +81,7 @@ class Translations {
|
|||||||
/**
|
/**
|
||||||
* Given the number of items, returns the 0-based index of the plural form to use
|
* Given the number of items, returns the 0-based index of the plural form to use
|
||||||
*
|
*
|
||||||
* Here, in the base Translations class, the common logic for English is implemented:
|
* Here, in the base Translations class, the common logic for English is implmented:
|
||||||
* 0 if there is one element, 1 otherwise
|
* 0 if there is one element, 1 otherwise
|
||||||
*
|
*
|
||||||
* This function should be overrided by the sub-classes. For example MO/PO can derive the logic
|
* This function should be overrided by the sub-classes. For example MO/PO can derive the logic
|
||||||
@ -121,7 +121,7 @@ class Translations {
|
|||||||
$this->entries[$entry->key()] = $entry;
|
$this->entries[$entry->key()] = $entry;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function merge_originals_with(&$other) {
|
function merge_originals_with(&$other) {
|
||||||
foreach( $other->entries as $entry ) {
|
foreach( $other->entries as $entry ) {
|
||||||
if ( !isset( $this->entries[$entry->key()] ) )
|
if ( !isset( $this->entries[$entry->key()] ) )
|
||||||
@ -148,7 +148,7 @@ class Gettext_Translations extends Translations {
|
|||||||
}
|
}
|
||||||
return call_user_func($this->_gettext_select_plural_form, $count);
|
return call_user_func($this->_gettext_select_plural_form, $count);
|
||||||
}
|
}
|
||||||
|
|
||||||
function nplurals_and_expression_from_header($header) {
|
function nplurals_and_expression_from_header($header) {
|
||||||
if (preg_match('/^\s*nplurals\s*=\s*(\d+)\s*;\s+plural\s*=\s*(.+)$/', $header, $matches)) {
|
if (preg_match('/^\s*nplurals\s*=\s*(\d+)\s*;\s+plural\s*=\s*(.+)$/', $header, $matches)) {
|
||||||
$nplurals = (int)$matches[1];
|
$nplurals = (int)$matches[1];
|
||||||
@ -174,7 +174,7 @@ class Gettext_Translations extends Translations {
|
|||||||
/**
|
/**
|
||||||
* Adds parantheses to the inner parts of ternary operators in
|
* Adds parantheses to the inner parts of ternary operators in
|
||||||
* plural expressions, because PHP evaluates ternary oerators from left to right
|
* plural expressions, because PHP evaluates ternary oerators from left to right
|
||||||
*
|
*
|
||||||
* @param string $expression the expression without parentheses
|
* @param string $expression the expression without parentheses
|
||||||
* @return string the expression with parentheses added
|
* @return string the expression with parentheses added
|
||||||
*/
|
*/
|
||||||
@ -202,7 +202,7 @@ class Gettext_Translations extends Translations {
|
|||||||
}
|
}
|
||||||
return rtrim($res, ';');
|
return rtrim($res, ';');
|
||||||
}
|
}
|
||||||
|
|
||||||
function make_headers($translation) {
|
function make_headers($translation) {
|
||||||
$headers = array();
|
$headers = array();
|
||||||
// sometimes \ns are used instead of real new lines
|
// sometimes \ns are used instead of real new lines
|
||||||
@ -215,7 +215,7 @@ class Gettext_Translations extends Translations {
|
|||||||
}
|
}
|
||||||
return $headers;
|
return $headers;
|
||||||
}
|
}
|
||||||
|
|
||||||
function set_header($header, $value) {
|
function set_header($header, $value) {
|
||||||
parent::set_header($header, $value);
|
parent::set_header($header, $value);
|
||||||
if ('Plural-Forms' == $header) {
|
if ('Plural-Forms' == $header) {
|
||||||
@ -234,7 +234,7 @@ if ( !class_exists( 'NOOP_Translations' ) ):
|
|||||||
class NOOP_Translations {
|
class NOOP_Translations {
|
||||||
var $entries = array();
|
var $entries = array();
|
||||||
var $headers = array();
|
var $headers = array();
|
||||||
|
|
||||||
function add_entry($entry) {
|
function add_entry($entry) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user