system system.base system.caching system.caching.dependencies system.collections system.console system.db system.db.ar system.db.schema system.db.schema.cubrid system.db.schema.mssql system.db.schema.mysql system.db.schema.oci system.db.schema.pgsql system.db.schema.sqlite system.gii system.i18n system.i18n.gettext system.logging system.test system.utils system.validators system.web system.web.actions system.web.auth system.web.filters system.web.form system.web.helpers system.web.renderers system.web.services system.web.widgets system.web.widgets.captcha system.web.widgets.pagers zii.behaviors zii.widgets zii.widgets.grid zii.widgets.jui

CGettextMoFile

system.i18n.gettext
继承 class CGettextMoFile » CGettextFile » CComponent
可用自 1.0
源码 framework/i18n/gettext/CGettextMoFile.php
CGettextMoFile represents an MO Gettext message file.

This class is written by adapting Michael's Gettext_MO class in PEAR. Please refer to the following license terms.

Copyright (c) 2004-2005, Michael Wallner . All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

公共属性

隐藏继承的属性

属性类型描述被定义在
useBigEndian boolean whether to use Big Endian when reading and writing an integer. CGettextMoFile

公共方法

隐藏继承的方法

方法描述被定义在
__call() Calls the named method which is not a class method. CComponent
__construct() Constructor. CGettextMoFile
__get() Returns a property value, an event handler list or a behavior based on its name. CComponent
__isset() Checks if a property value is null. CComponent
__set() Sets value of a component property. CComponent
__unset() Sets a component property to be null. CComponent
asa() Returns the named behavior object. CComponent
attachBehavior() Attaches a behavior to this component. CComponent
attachBehaviors() Attaches a list of behaviors to the component. CComponent
attachEventHandler() Attaches an event handler to an event. CComponent
canGetProperty() Determines whether a property can be read. CComponent
canSetProperty() Determines whether a property can be set. CComponent
detachBehavior() Detaches a behavior from the component. CComponent
detachBehaviors() Detaches all behaviors from the component. CComponent
detachEventHandler() Detaches an existing event handler. CComponent
disableBehavior() Disables an attached behavior. CComponent
disableBehaviors() Disables all behaviors attached to this component. CComponent
enableBehavior() Enables an attached behavior. CComponent
enableBehaviors() Enables all behaviors attached to this component. CComponent
evaluateExpression() Evaluates a PHP expression or callback under the context of this component. CComponent
getEventHandlers() Returns the list of attached event handlers for an event. CComponent
hasEvent() Determines whether an event is defined. CComponent
hasEventHandler() Checks whether the named event has attached handlers. CComponent
hasProperty() Determines whether a property is defined. CComponent
load() Loads messages from an MO file. CGettextMoFile
raiseEvent() Raises an event. CComponent
save() Saves messages to an MO file. CGettextMoFile

受保护的方法

隐藏继承的方法

方法描述被定义在
readByte() Reads one or several bytes. CGettextMoFile
readInteger() Reads a 4-byte integer. CGettextMoFile
readString() Reads a string. CGettextMoFile
writeByte() Writes bytes. CGettextMoFile
writeInteger() Writes a 4-byte integer. CGettextMoFile
writeString() Writes a string. CGettextMoFile

属性详情

useBigEndian 属性
public boolean $useBigEndian;

whether to use Big Endian when reading and writing an integer.

方法详情

__construct() 方法
public void __construct(boolean $useBigEndian=false)
$useBigEndian boolean whether to use Big Endian when reading and writing an integer.
源码: framework/i18n/gettext/CGettextMoFile.php#55 (显示)
public function __construct($useBigEndian=false)
{
    
$this->useBigEndian=$useBigEndian;
}

Constructor.

load() 方法
public array load(string $file, string $context)
$file string file path
$context string message context
{return} array message translations (source message => translated message)
源码: framework/i18n/gettext/CGettextMoFile.php#67 (显示)
public function load($file,$context)
{
    if(!(
$fr=@fopen($file,'rb')))
        throw new 
CException(Yii::t('yii','Unable to read file "{file}".',
            array(
'{file}'=>$file)));

    if(!@
flock($fr,LOCK_SH))
        throw new 
CException(Yii::t('yii','Unable to lock file "{file}" for reading.',
            array(
'{file}'=>$file)));

    
$array=unpack('c',$this->readByte($fr,4));
    
$magic=current($array);
    if(
$magic==-34)
        
$this->useBigEndian=false;
    elseif(
$magic==-107)
        
$this->useBigEndian=true;
    else
        throw new 
CException(Yii::t('yii','Invalid MO file: {file} (magic: {magic}).',
            array(
'{file}'=>$file,'{magic}'=>$magic)));

    if((
$revision=$this->readInteger($fr))!=0)
        throw new 
CException(Yii::t('yii','Invalid MO file revision: {revision}.',
            array(
'{revision}'=>$revision)));

    
$count=$this->readInteger($fr);
    
$sourceOffset=$this->readInteger($fr);
    
$targetOffset=$this->readInteger($fr);

    
$sourceLengths=array();
    
$sourceOffsets=array();
    
fseek($fr,$sourceOffset);
    for(
$i=0;$i<$count;++$i)
    {
        
$sourceLengths[]=$this->readInteger($fr);
        
$sourceOffsets[]=$this->readInteger($fr);
    }

    
$targetLengths=array();
    
$targetOffsets=array();
    
fseek($fr,$targetOffset);
    for(
$i=0;$i<$count;++$i)
    {
        
$targetLengths[]=$this->readInteger($fr);
        
$targetOffsets[]=$this->readInteger($fr);
    }

    
$messages=array();
    for(
$i=0;$i<$count;++$i)
    {
        
$id=$this->readString($fr,$sourceLengths[$i],$sourceOffsets[$i]);
        
$pos strpos($id,chr(4));

        if((
$context && $pos!==false && substr($id,0,$pos)===$context) || (!$context && $pos===false))
        {
            if(
$pos !== false)
                
$id=substr($id,$pos+1);

            
$message=$this->readString($fr,$targetLengths[$i],$targetOffsets[$i]);
            
$messages[$id]=$message;
        }
    }

    @
flock($fr,LOCK_UN);
    @
fclose($fr);

    return 
$messages;
}

Loads messages from an MO file.

readByte() 方法
protected string readByte(resource $fr, integer $n=1)
$fr resource file handle
$n integer number of bytes to read
{return} string bytes
源码: framework/i18n/gettext/CGettextMoFile.php#212 (显示)
protected function readByte($fr,$n=1)
{
    if(
$n>0)
        return 
fread($fr,$n);
}

Reads one or several bytes.

readInteger() 方法
protected integer readInteger(resource $fr)
$fr resource file handle
{return} integer the result
源码: framework/i18n/gettext/CGettextMoFile.php#235 (显示)
protected function readInteger($fr)
{
    
$array=unpack($this->useBigEndian 'N' 'V'$this->readByte($fr,4));
    return 
current($array);
}

Reads a 4-byte integer.

参见

readString() 方法
protected string readString(resource $fr, integer $length, integer $offset=NULL)
$fr resource file handle
$length integer string length
$offset integer offset of the string in the file. If null, it reads from the current position.
{return} string the result
源码: framework/i18n/gettext/CGettextMoFile.php#259 (显示)
protected function readString($fr,$length,$offset=null)
{
    if(
$offset!==null)
        
fseek($fr,$offset);
    return 
$this->readByte($fr,$length);
}

Reads a string.

save() 方法
public void save(string $file, array $messages)
$file string file path
$messages array message translations (message id => translated message). Note if the message has a context, the message id must be prefixed with the context with chr(4) as the separator.
源码: framework/i18n/gettext/CGettextMoFile.php#143 (显示)
public function save($file,$messages)
{
    if(!(
$fw=@fopen($file,'wb')))
        throw new 
CException(Yii::t('yii','Unable to write file "{file}".',
            array(
'{file}'=>$file)));

    if(!@
flock($fw,LOCK_EX))
        throw new 
CException(Yii::t('yii','Unable to lock file "{file}" for writing.',
            array(
'{file}'=>$file)));

    
// magic
    
if($this->useBigEndian)
        
$this->writeByte($fw,pack('c*'0x950x040x120xde));
    else
        
$this->writeByte($fw,pack('c*'0xde0x120x040x95));

    
// revision
    
$this->writeInteger($fw,0);

    
// message count
    
$n=count($messages);
    
$this->writeInteger($fw,$n);

    
// offset of source message table
    
$offset=28;
    
$this->writeInteger($fw,$offset);
    
$offset+=($n*8);
    
$this->writeInteger($fw,$offset);
    
// hashtable size, omitted
    
$this->writeInteger($fw,0);
    
$offset+=($n*8);
    
$this->writeInteger($fw,$offset);

    
// length and offsets for source messagess
    
foreach(array_keys($messages) as $id)
    {
        
$len=strlen($id);
        
$this->writeInteger($fw,$len);
        
$this->writeInteger($fw,$offset);
        
$offset+=$len+1;
    }

    
// length and offsets for target messagess
    
foreach($messages as $message)
    {
        
$len=strlen($message);
        
$this->writeInteger($fw,$len);
        
$this->writeInteger($fw,$offset);
        
$offset+=$len+1;
    }

    
// source messages
    
foreach(array_keys($messages) as $id)
        
$this->writeString($fw,$id);

    
// target messages
    
foreach($messages as $message)
        
$this->writeString($fw,$message);

    @
flock($fw,LOCK_UN);
    @
fclose($fw);
}

Saves messages to an MO file.

writeByte() 方法
protected integer writeByte(resource $fw, string $data)
$fw resource file handle
$data string the data
{return} integer how many bytes are written
源码: framework/i18n/gettext/CGettextMoFile.php#224 (显示)
protected function writeByte($fw,$data)
{
    return 
fwrite($fw,$data);
}

Writes bytes.

writeInteger() 方法
protected integer writeInteger(resource $fw, integer $data)
$fw resource file handle
$data integer the data
{return} integer how many bytes are written
源码: framework/i18n/gettext/CGettextMoFile.php#247 (显示)
protected function writeInteger($fw,$data)
{
    return 
$this->writeByte($fw,pack($this->useBigEndian 'N' 'V', (int)$data));
}

Writes a 4-byte integer.

writeString() 方法
protected integer writeString(resource $fw, string $data)
$fw resource file handle
$data string the string
{return} integer how many bytes are written
源码: framework/i18n/gettext/CGettextMoFile.php#272 (显示)
protected function writeString($fw,$data)
{
    return 
$this->writeByte($fw,$data."\0");
}

Writes a string.