wp/wp-includes/pomo/translations.php
author ymh <ymh.work@gmail.com>
Tue, 09 Jun 2015 03:35:32 +0200
changeset 5 5e2f62d02dcd
parent 0 d970ebf37754
child 7 cf61fcea0001
permissions -rw-r--r--
upgrade wordpress + plugins
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
	 *
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    20
	 * @param array|Translation_Entry &$entry
0
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
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    33
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    34
	 * @param array|Translation_Entry $entry
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    35
	 * @return bool
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    36
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
	function add_entry_or_merge($entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
		if (is_array($entry)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
			$entry = new Translation_Entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
		$key = $entry->key();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
		if (false === $key) return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
		if (isset($this->entries[$key]))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
			$this->entries[$key]->merge_with($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
			$this->entries[$key] = &$entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
	 * Sets $header PO header to $value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
	 * If the header already exists, it will be overwritten
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
	 * TODO: this should be out of this class, it is gettext specific
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
	 * @param string $header header name, without trailing :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
	 * @param string $value header value, without trailing \n
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_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
		$this->headers[$header] = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    64
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    65
	 * @param array $headers
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    66
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
	function set_headers($headers) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
		foreach($headers as $header => $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
			$this->set_header($header, $value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    73
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    74
	 * @param string $header
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    75
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
	function get_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
		return isset($this->headers[$header])? $this->headers[$header] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    80
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    81
	 * @param Translation_Entry $entry
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    82
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
	function translate_entry(&$entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
		$key = $entry->key();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
		return isset($this->entries[$key])? $this->entries[$key] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    88
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    89
	 * @param string $singular
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    90
	 * @param string $context
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    91
	 * @return string
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    92
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
	function translate($singular, $context=null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
		$entry = new Translation_Entry(array('singular' => $singular, 'context' => $context));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
		$translated = $this->translate_entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
		return ($translated && !empty($translated->translations))? $translated->translations[0] : $singular;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
	}
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
	 * 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
   101
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
	 * Here, in the base Translations class, the common logic for English is implemented:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
	 * 	0 if there is one element, 1 otherwise
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
	 * 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
   106
	 * from their headers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
	 * @param integer $count number of items
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
	function select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
		return 1 == $count? 0 : 1;
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
	function get_plural_forms_count() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
		return 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   118
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   119
	 * @param string $singular
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   120
	 * @param string $plural
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   121
	 * @param int    $count
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   122
	 * @param string $context
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   123
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
	function translate_plural($singular, $plural, $count, $context = null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
		$entry = new Translation_Entry(array('singular' => $singular, 'plural' => $plural, 'context' => $context));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
		$translated = $this->translate_entry($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
		$index = $this->select_plural_form($count);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
		$total_plural_forms = $this->get_plural_forms_count();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
		if ($translated && 0 <= $index && $index < $total_plural_forms &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
				is_array($translated->translations) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
				isset($translated->translations[$index]))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
			return $translated->translations[$index];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
			return 1 == $count? $singular : $plural;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
	 * Merge $other in the current object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
	 * @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
   141
	 * @return void
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 merge_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
		foreach( $other->entries as $entry ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
			$this->entries[$entry->key()] = $entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
	function merge_originals_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
		foreach( $other->entries as $entry ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
			if ( !isset( $this->entries[$entry->key()] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
				$this->entries[$entry->key()] = $entry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
				$this->entries[$entry->key()]->merge_with($entry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
class Gettext_Translations extends Translations {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
	 * The gettext implementation of select_plural_form.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	 * 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
   164
	 * they can't share it effectively.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
	 *
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   166
	 * @param int $count
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
	function gettext_select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
		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
   170
			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
   171
			$this->_nplurals = $nplurals;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
			$this->_gettext_select_plural_form = $this->make_plural_form_function($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
		return call_user_func($this->_gettext_select_plural_form, $count);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   177
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   178
	 * @param string $header
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   179
	 * @return array
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   180
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
	function nplurals_and_expression_from_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
		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
   183
			$nplurals = (int)$matches[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
			$expression = trim($this->parenthesize_plural_exression($matches[2]));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
			return array($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
			return array(2, 'n != 1');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
	 * Makes a function, which will return the right translation index, according to the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
	 * plural forms header
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   194
	 * @param int    $nplurals
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   195
	 * @param string $expression
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
	function make_plural_form_function($nplurals, $expression) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
		$expression = str_replace('n', '$n', $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
		$func_body = "
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
			\$index = (int)($expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
			return (\$index < $nplurals)? \$index : $nplurals - 1;";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
		return create_function('$n', $func_body);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
	/**
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   206
	 * Adds parentheses to the inner parts of ternary operators in
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
	 * plural expressions, because PHP evaluates ternary oerators from left to right
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
	 * @param string $expression the expression without parentheses
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
	 * @return string the expression with parentheses added
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
	function parenthesize_plural_exression($expression) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
		$expression .= ';';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
		$res = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
		$depth = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
		for ($i = 0; $i < strlen($expression); ++$i) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
			$char = $expression[$i];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
			switch ($char) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
				case '?':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
					$res .= ' ? (';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
					$depth++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
				case ':':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
					$res .= ') : (';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
				case ';':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
					$res .= str_repeat(')', $depth) . ';';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
					$depth= 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
					break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
				default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
					$res .= $char;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
		return rtrim($res, ';');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   237
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   238
	 * @param string $translation
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   239
	 * @return array
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   240
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
	function make_headers($translation) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
		$headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
		// sometimes \ns are used instead of real new lines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
		$translation = str_replace('\n', "\n", $translation);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
		$lines = explode("\n", $translation);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
		foreach($lines as $line) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
			$parts = explode(':', $line, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
			if (!isset($parts[1])) continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
			$headers[trim($parts[0])] = trim($parts[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
		return $headers;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   254
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   255
	 * @param string $header
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   256
	 * @param string $value
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   257
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
	function set_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
		parent::set_header($header, $value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
		if ('Plural-Forms' == $header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
			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
   262
			$this->_nplurals = $nplurals;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
			$this->_gettext_select_plural_form = $this->make_plural_form_function($nplurals, $expression);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
if ( !class_exists( 'NOOP_Translations' ) ):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
 * Provides the same interface as Translations, but doesn't do anything
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
class NOOP_Translations {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
	var $entries = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
	var $headers = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
	function add_entry($entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
	function set_header($header, $value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
	function set_headers($headers) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
	function get_header($header) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
	function translate_entry(&$entry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   295
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   296
	 * @param string $singular
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   297
	 * @param string $context
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   298
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
	function translate($singular, $context=null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
		return $singular;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
	function select_plural_form($count) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
		return 1 == $count? 0 : 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
	function get_plural_forms_count() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
		return 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
5
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   311
	/**
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   312
	 * @param string $singular
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   313
	 * @param string $plural
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   314
	 * @param int    $count
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   315
	 * @param string $context
5e2f62d02dcd upgrade wordpress + plugins
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   316
	 */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
	function translate_plural($singular, $plural, $count, $context = null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
			return 1 == $count? $singular : $plural;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
	function merge_with(&$other) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
endif;