You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							85 lines
						
					
					
						
							2.3 KiB
						
					
					
				
			
		
		
	
	
							85 lines
						
					
					
						
							2.3 KiB
						
					
					
				| <?php | |
| /** | |
|  * @link http://www.yiiframework.com/ | |
|  * @copyright Copyright (c) 2008 Yii Software LLC | |
|  * @license http://www.yiiframework.com/license/ | |
|  */ | |
|  | |
| namespace yii\i18n; | |
|  | |
| use Yii; | |
|  | |
| /** | |
|  * GettextMessageSource represents a message source that is based on GNU Gettext. | |
|  * | |
|  * Each GettextMessageSource instance represents the message tranlations | |
|  * for a single domain. And each message category represents a message context | |
|  * in Gettext. Translated messages are stored as either a MO or PO file, | |
|  * depending on the [[useMoFile]] property value. | |
|  * | |
|  * All translations are saved under the [[basePath]] directory. | |
|  * | |
|  * Translations in one language are kept as MO or PO files under an individual | |
|  * subdirectory whose name is the language ID. The file name is specified via | |
|  * [[catalog]] property, which defaults to 'messages'. | |
|  * | |
|  * @author Qiang Xue <qiang.xue@gmail.com> | |
|  * @since 2.0 | |
|  */ | |
| class GettextMessageSource extends MessageSource | |
| { | |
| 	const MO_FILE_EXT = '.mo'; | |
| 	const PO_FILE_EXT = '.po'; | |
|  | |
| 	/** | |
| 	 * @var string | |
| 	 */ | |
| 	public $basePath = '@app/messages'; | |
| 	/** | |
| 	 * @var string | |
| 	 */ | |
| 	public $catalog = 'messages'; | |
| 	/** | |
| 	 * @var boolean | |
| 	 */ | |
| 	public $useMoFile = true; | |
| 	/** | |
| 	 * @var boolean | |
| 	 */ | |
| 	public $useBigEndian = false; | |
|  | |
| 	/** | |
| 	 * Loads the message translation for the specified language and category. | |
| 	 * Child classes should override this method to return the message translations of | |
| 	 * the specified language and category. | |
| 	 * @param string $category the message category | |
| 	 * @param string $language the target language | |
| 	 * @return array the loaded messages. The keys are original messages, and the values | |
| 	 * are translated messages. | |
| 	 */ | |
| 	protected function loadMessages($category, $language) | |
| 	{ | |
| 		$messageFile = Yii::getAlias($this->basePath) . '/' . $language . '/' . $this->catalog; | |
| 		if ($this->useMoFile) { | |
| 			$messageFile .= static::MO_FILE_EXT; | |
| 		} else { | |
| 			$messageFile .= static::PO_FILE_EXT; | |
| 		} | |
|  | |
| 		if (is_file($messageFile)) { | |
| 			if ($this->useMoFile) { | |
| 				$gettextFile = new GettextMoFile(['useBigEndian' => $this->useBigEndian]); | |
| 			} else { | |
| 				$gettextFile = new GettextPoFile(); | |
| 			} | |
| 			$messages = $gettextFile->load($messageFile, $category); | |
| 			if (!is_array($messages)) { | |
| 				$messages = []; | |
| 			} | |
| 			return $messages; | |
| 		} else { | |
| 			Yii::error("The message file for category '$category' does not exist: $messageFile", __METHOD__); | |
| 			return []; | |
| 		} | |
| 	} | |
| }
 | |
| 
 |