Source for file Decorator.php
Documentation is available at Decorator.php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
* Contains the Translation2_Decorator base class
* LICENSE: Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. 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.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR "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 FREEBSD PROJECT 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.
* @category Internationalization
* @author Lorenzo Alberton <l.alberton@quipo.it>
* @copyright 2004-2005 Lorenzo Alberton
* @license http://www.debian.org/misc/bsd.license BSD License (3 Clause)
* @version CVS: $Id: Decorator.php,v 1.22 2007/10/28 23:14:49 quipo Exp $
* @link http://pear.php.net/package/Translation2
* Translation2_Decorator. Base Decorator class for Translation2
* Extend this class to provide custom decorators.
* Some decorators are already bundled with the package.
* @category Internationalization
* @author Lorenzo Alberton <l.alberton@quipo.it>
* @copyright 2004-2005 Lorenzo Alberton
* @license http://www.debian.org/misc/bsd.license BSD License (3 Clause)
* @link http://pear.php.net/package/Translation2
* Translation2 object being decorated
* Constructs the Translation2_Decorator
* @param object &$translation2 Translation2 object to decorate
$this->storage = & $translation2->storage;
$this->lang = & $translation2->lang;
* @param array $options decorator options
foreach ($options as $option => $value) {
* @param string $option option name
* @param mixed $value option value
if (isset ($this->$option)) {
// {{{ setContainerOptions()
* Set some storage driver options
* @param array $options storage driver options
$this->storage->_parseOptions ($options);
* Return an instance of a decorator
* @param string $decorator Name of the decorator
* @param object $object instance [optional]
* @return object Decorator object reference
$new_decorator = & $this->translation2->getDecorator ($decorator, $obj);
$new_decorator = & $this->translation2->getDecorator ($decorator, $this);
* Set charset used to read/store the translations
* @param string $charset character set (encoding)
* @return PEAR_Error on failure
* @param string $langID language ID
// {{{ setPageID($pageID)
* @param string $pageID page/group ID
* @param string $langID language ID
* @param string $format ['name', 'meta', 'error_text', 'array']
* @return mixed [string | array], depending on $format
function getLang($langID=null , $format= 'name')
* @param string $format ['ids', 'names', 'array']
* Set parameters for next string
* @param array $params array of replacement parameters
* @param string $stringID string ID
* @param string $pageID page/group ID
* @param string $langID language ID
* @param string $defaultText Text to display when the strings in both
* the default and the fallback lang are empty
function getRaw($stringID, $pageID = TRANSLATION2_DEFAULT_PAGEID , $langID = null , $defaultText = '')
return $this->translation2->getRaw ($stringID, $pageID, $langID, $defaultText);
* All the filters are applied.
* @param string $stringID string ID
* @param string $pageID page/group ID
* @param string $langID language ID
* @param string $defaultText Text to display when the string is empty
* NB: This parameter is only used in the DefaultText decorator
function get($stringID, $pageID = TRANSLATION2_DEFAULT_PAGEID , $langID = null , $defaultText = '')
return $this->translation2->get ($stringID, $pageID, $langID, $defaultText);
* Get the array of strings in a page
* Fetch the strings from the container, without any replacing
* @param string $pageID page/group ID
* @param string $langID language ID
function getRawPage($pageID = TRANSLATION2_DEFAULT_PAGEID , $langID = null )
* Same as getRawPage, but resort to fallback language and
* replace parameters when needed
* @param string $pageID page/group ID
* @param string $langID language ID
function getPage($pageID = TRANSLATION2_DEFAULT_PAGEID , $langID = null )
* Replace parameters in strings
* @param mixed $strings strings where the replacements must occur
// {{{ replaceEmptyStringsWithKeys()
* Replace empty strings with their stringID
* @param array $strings array of strings to be replaced if empty
return $this->translation2->replaceEmptyStringsWithKeys ($strings);
* Get the stringID for the given string. This method is the reverse of get().
* @param string $string This is NOT the stringID, this is a real string.
* The method will search for its matching stringID, and then
* it will return the associate string in the selected language.
* @param string $pageID page/group ID
function getStringID($string, $pageID = TRANSLATION2_DEFAULT_PAGEID )
* Clone internal object references
* This method is called automatically by PHP5
Documentation generated on Tue, 06 May 2008 06:00:23 -0400 by phpDocumentor 1.4.0. PEAR Logo Copyright © PHP Group 2004.
|