wp/wp-includes/pomo/translations.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 5 5e2f62d02dcd
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * Class for a set of entries for translation and their associated headers
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * @version $Id: translations.php 718 2012-10-31 00:32:02Z nbachiyski $
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * @package pomo
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * @subpackage translations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
require_once dirname(__FILE__) . '/entry.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
if ( !class_exists( 'Translations' ) ):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
class Translations {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
	var $entries = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
	var $headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
	 * Add entry to the PO structure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
	 * @param object &$entry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
	 * @return bool true on success, false if the entry doesn't have a key
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
	function add_entry($entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
		if (is_array($entry)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
			$entry = new Translation_Entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
		$key = $entry->key();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
		if (false === $key) return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
		$this->entries[$key] = &$entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
	function add_entry_or_merge($entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
		if (is_array($entry)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
			$entry = new Translation_Entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
		$key = $entry->key();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
		if (false === $key) return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
		if (isset($this->entries[$key]))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
			$this->entries[$key]->merge_with($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
			$this->entries[$key] = &$entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
	 * Sets $header PO header to $value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
	 * If the header already exists, it will be overwritten
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
	 * TODO: this should be out of this class, it is gettext specific
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
	 * @param string $header header name, without trailing :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
	 * @param string $value header value, without trailing \n
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	function set_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
		$this->headers[$header] = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
	function set_headers($headers) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
		foreach($headers as $header => $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
			$this->set_header($header, $value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
	function get_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
		return isset($this->headers[$header])? $this->headers[$header] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
	function translate_entry(&$entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
		$key = $entry->key();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
		return isset($this->entries[$key])? $this->entries[$key] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
	function translate($singular, $context=null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
		$entry = new Translation_Entry(array('singular' => $singular, 'context' => $context));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
		$translated = $this->translate_entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
		return ($translated && !empty($translated->translations))? $translated->translations[0] : $singular;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
	 * Given the number of items, returns the 0-based index of the plural form to use
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
	 * Here, in the base Translations class, the common logic for English is implemented:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
	 * 	0 if there is one element, 1 otherwise
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
	 * This function should be overrided by the sub-classes. For example MO/PO can derive the logic
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
	 * from their headers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
	 * @param integer $count number of items
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
	function select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
		return 1 == $count? 0 : 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
	function get_plural_forms_count() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
		return 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
	function translate_plural($singular, $plural, $count, $context = null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
		$entry = new Translation_Entry(array('singular' => $singular, 'plural' => $plural, 'context' => $context));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
		$translated = $this->translate_entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
		$index = $this->select_plural_form($count);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
		$total_plural_forms = $this->get_plural_forms_count();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
		if ($translated && 0 <= $index && $index < $total_plural_forms &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
				is_array($translated->translations) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
				isset($translated->translations[$index]))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
			return $translated->translations[$index];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
			return 1 == $count? $singular : $plural;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
	 * Merge $other in the current object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
	 * @param Object &$other Another Translation object, whose translations will be merged in this one
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
	 * @return void
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
	 **/
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
	function merge_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
		foreach( $other->entries as $entry ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
			$this->entries[$entry->key()] = $entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
	function merge_originals_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
		foreach( $other->entries as $entry ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
			if ( !isset( $this->entries[$entry->key()] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
				$this->entries[$entry->key()] = $entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
				$this->entries[$entry->key()]->merge_with($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
class Gettext_Translations extends Translations {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
	 * The gettext implementation of select_plural_form.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
	 * It lives in this class, because there are more than one descendand, which will use it and
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
	 * they can't share it effectively.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
	function gettext_select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
		if (!isset($this->_gettext_select_plural_form) || is_null($this->_gettext_select_plural_form)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
			list( $nplurals, $expression ) = $this->nplurals_and_expression_from_header($this->get_header('Plural-Forms'));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
			$this->_nplurals = $nplurals;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
			$this->_gettext_select_plural_form = $this->make_plural_form_function($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
		return call_user_func($this->_gettext_select_plural_form, $count);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
	function nplurals_and_expression_from_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
		if (preg_match('/^\s*nplurals\s*=\s*(\d+)\s*;\s+plural\s*=\s*(.+)$/', $header, $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
			$nplurals = (int)$matches[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
			$expression = trim($this->parenthesize_plural_exression($matches[2]));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
			return array($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
			return array(2, 'n != 1');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	 * Makes a function, which will return the right translation index, according to the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
	 * plural forms header
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
	function make_plural_form_function($nplurals, $expression) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
		$expression = str_replace('n', '$n', $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
		$func_body = "
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
			\$index = (int)($expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
			return (\$index < $nplurals)? \$index : $nplurals - 1;";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
		return create_function('$n', $func_body);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
	 * Adds parantheses to the inner parts of ternary operators in
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
	 * plural expressions, because PHP evaluates ternary oerators from left to right
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
	 * @param string $expression the expression without parentheses
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
	 * @return string the expression with parentheses added
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
	function parenthesize_plural_exression($expression) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
		$expression .= ';';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
		$res = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
		$depth = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
		for ($i = 0; $i < strlen($expression); ++$i) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
			$char = $expression[$i];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
			switch ($char) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
				case '?':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
					$res .= ' ? (';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
					$depth++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
				case ':':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
					$res .= ') : (';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
				case ';':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
					$res .= str_repeat(')', $depth) . ';';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
					$depth= 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
				default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
					$res .= $char;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
		return rtrim($res, ';');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
	function make_headers($translation) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
		$headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
		// sometimes \ns are used instead of real new lines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
		$translation = str_replace('\n', "\n", $translation);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
		$lines = explode("\n", $translation);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
		foreach($lines as $line) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
			$parts = explode(':', $line, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
			if (!isset($parts[1])) continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
			$headers[trim($parts[0])] = trim($parts[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
		return $headers;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
	function set_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
		parent::set_header($header, $value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
		if ('Plural-Forms' == $header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
			list( $nplurals, $expression ) = $this->nplurals_and_expression_from_header($this->get_header('Plural-Forms'));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
			$this->_nplurals = $nplurals;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
			$this->_gettext_select_plural_form = $this->make_plural_form_function($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
if ( !class_exists( 'NOOP_Translations' ) ):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
 * Provides the same interface as Translations, but doesn't do anything
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
class NOOP_Translations {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
	var $entries = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
	var $headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
	function add_entry($entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
	function set_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
	function set_headers($headers) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
	function get_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
	function translate_entry(&$entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
	function translate($singular, $context=null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
		return $singular;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
	function select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
		return 1 == $count? 0 : 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
	function get_plural_forms_count() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
		return 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
	function translate_plural($singular, $plural, $count, $context = null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
			return 1 == $count? $singular : $plural;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
	function merge_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
endif;