mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-12-22 06:30:59 +01:00
- making all methods of translation class static
- caching the phrases in new egw_cache on Tree level --> a good speed improvment on my devel system - also added a global function check_load_extension($extension,$throw=false)
This commit is contained in:
parent
fd9856ebf5
commit
bf036043b2
@ -128,6 +128,7 @@ class egw extends egw_minimal
|
||||
//$GLOBALS['egw_info']['server'] = config::read('phpgwapi'); would unserialize arrays
|
||||
|
||||
// setup the other subclasses
|
||||
// translation class is here only for backward compatibility, as all it's methods can be called static now
|
||||
$this->translation = new translation();
|
||||
$this->common = new common();
|
||||
$this->accounts = accounts::getInstance();
|
||||
@ -200,7 +201,8 @@ class egw extends egw_minimal
|
||||
{
|
||||
$this->template->set_root(EGW_APP_TPL);
|
||||
}
|
||||
$this->translation->add_app($GLOBALS['egw_info']['flags']['currentapp']);
|
||||
// init the translation class, necessary as own wakeup would run before our's
|
||||
translation::init();
|
||||
|
||||
// verify the session
|
||||
$GLOBALS['egw']->verify_session();
|
||||
@ -439,20 +441,20 @@ class egw extends egw_minimal
|
||||
/**
|
||||
* Shortcut to translation class
|
||||
*
|
||||
* This function is a basic wrapper to translation->translate()
|
||||
* This function is a basic wrapper to translation::translate()
|
||||
*
|
||||
* @deprecated only used in the old timetracker
|
||||
* @param string The key for the phrase
|
||||
* @see translation->translate()
|
||||
* @see translation::translate()
|
||||
*/
|
||||
function lang($key,$args=null)
|
||||
static function lang($key,$args=null)
|
||||
{
|
||||
if (!is_array($args))
|
||||
{
|
||||
$args = func_get_args();
|
||||
array_shift($args);
|
||||
}
|
||||
return $this->translation->translate($key,$args);
|
||||
return translation::translate($key,$args);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -38,7 +38,7 @@
|
||||
* The $app parameter should be either the app or the class name, which both are unique.
|
||||
*
|
||||
* The tree and instance wide cache uses a certain provider class, to store the data
|
||||
* eg. in memcached or if there's nothing else configured in the session.
|
||||
* eg. in memcached or if there's nothing else configured in the filesystem (eGW's temp_dir).
|
||||
*/
|
||||
class egw_cache
|
||||
{
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -59,6 +59,28 @@ function array2string($var)
|
||||
return 'UNKNOWN TYPE!';
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if a given extension is loaded or load it if possible (requires sometimes disabled dl function)
|
||||
*
|
||||
* @param string $extension
|
||||
* @param boolean $throw=false should we throw an exception, if $extension could not be loaded, default false = no
|
||||
* @return boolean true if loaded now, false otherwise
|
||||
*/
|
||||
function check_load_extension($extension,$throw=false)
|
||||
{
|
||||
if (!defined('PHP_SHLIB_PREFIX'))
|
||||
{
|
||||
define('PHP_SHLIB_PREFIX',PHP_SHLIB_SUFFIX == 'dll' ? 'php_' : '');
|
||||
}
|
||||
$loaded = extension_loaded($extension) || function_exists('dl') && @dl(PHP_SHLIB_PREFIX.$extension.'.'.PHP_SHLIB_SUFFIX);
|
||||
|
||||
if (!($loaded))
|
||||
{
|
||||
throw new Exception ("PHP extension '$ext' not loaded AND can NOT be loaded via dl('$dl')!");
|
||||
}
|
||||
return $loaded;
|
||||
}
|
||||
|
||||
/**
|
||||
* @internal Not to be used directly. Should only be used by print_debug()
|
||||
*/
|
||||
@ -1325,7 +1347,7 @@ if (!function_exists('lang')) // setup declares an own version
|
||||
$vars = func_get_args();
|
||||
array_shift($vars); // remove $key
|
||||
}
|
||||
return $GLOBALS['egw']->translation->translate($key,$vars);
|
||||
return translation::translate($key,$vars);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1348,9 +1370,7 @@ function try_lang($key,$vars=null)
|
||||
$vars = func_get_args();
|
||||
array_shift($vars); // remove $key
|
||||
}
|
||||
return is_object($GLOBALS['egw']) && isset($GLOBALS['egw']->translations) ?
|
||||
$GLOBALS['egw']->translation->translate($key,$vars) :
|
||||
str_replace($varnames,$vars,$key);
|
||||
return class_exists(translations,false) ? translation::translate($key,$vars) : str_replace($varnames,$vars,$key);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -11,177 +11,152 @@
|
||||
* @version $Id$
|
||||
*/
|
||||
|
||||
if (!defined('MAX_MESSAGE_ID_LENGTH'))
|
||||
if (!defined('MAX_MESSAGE_ID_LENGTH'))
|
||||
{
|
||||
define('MAX_MESSAGE_ID_LENGTH',128);
|
||||
}
|
||||
|
||||
// Define prefix for langfiles (historically 'phpgw_')
|
||||
define('EGW_LANGFILE_PREFIX', 'egw_');
|
||||
|
||||
class setup_translation
|
||||
{
|
||||
var $langarray = array();
|
||||
|
||||
var $no_translation_marker = '*';
|
||||
|
||||
/**
|
||||
* constructor for the class, loads all phrases into langarray
|
||||
*
|
||||
* @param $lang user lang variable (defaults to en)
|
||||
*/
|
||||
function __construct()
|
||||
{
|
||||
define('MAX_MESSAGE_ID_LENGTH',128);
|
||||
$ConfigLang = get_var('ConfigLang',Array('POST','COOKIE'));
|
||||
|
||||
if(!$ConfigLang)
|
||||
{
|
||||
$lang = 'en';
|
||||
}
|
||||
else
|
||||
{
|
||||
$lang = $ConfigLang;
|
||||
}
|
||||
|
||||
$fn = '.' . SEP . 'lang' . SEP . EGW_LANGFILE_PREFIX . $lang . '.lang';
|
||||
if (!file_exists($fn))
|
||||
{
|
||||
$fn = '.' . SEP . 'lang' . SEP . EGW_LANGFILE_PREFIX .'en.lang';
|
||||
}
|
||||
if (file_exists($fn) && ($fp = fopen($fn,'r')))
|
||||
{
|
||||
while (($data = fgets($fp,8000)))
|
||||
{
|
||||
// explode with "\t" and removing "\n" with str_replace, needed to work with mbstring.overload=7
|
||||
list($message_id,,,$content) = explode("\t",$data);
|
||||
$this->langarray[strtolower(trim($message_id))] = str_replace("\n",'',$content);
|
||||
}
|
||||
fclose($fp);
|
||||
|
||||
if (!$GLOBALS['egw_setup']->system_charset)
|
||||
{
|
||||
$GLOBALS['egw_setup']->system_charset = $this->langarray['charset'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Define prefix for langfiles (historically 'phpgw_')
|
||||
define('EGW_LANGFILE_PREFIX', 'egw_');
|
||||
|
||||
class setup_translation
|
||||
/**
|
||||
* Translate phrase to user selected lang
|
||||
*
|
||||
* @param $key phrase to translate
|
||||
* @param $vars vars sent to lang function, passed to us
|
||||
*/
|
||||
function translate($key, $vars=False)
|
||||
{
|
||||
var $langarray = array();
|
||||
static $placeholders = array('%1','%2','%3','%4','%5','%6','%7','%8','%9','%10');
|
||||
|
||||
var $no_translation_marker = '*';
|
||||
|
||||
/**
|
||||
* constructor for the class, loads all phrases into langarray
|
||||
*
|
||||
* @param $lang user lang variable (defaults to en)
|
||||
*/
|
||||
function setup_translation()
|
||||
$ret = $key . $this->no_translation_marker;
|
||||
$key = strtolower(trim($key));
|
||||
if (isset($this->langarray[$key]))
|
||||
{
|
||||
$ConfigLang = get_var('ConfigLang',Array('POST','COOKIE'));
|
||||
$ret = $this->langarray[$key];
|
||||
}
|
||||
if ($GLOBALS['egw_setup']->system_charset != $this->langarray['charset'])
|
||||
{
|
||||
$ret = translation::convert($ret,$this->langarray['charset']);
|
||||
}
|
||||
if (is_array($vars))
|
||||
{
|
||||
$ret = str_replace($placeholders, $vars, $ret);
|
||||
}
|
||||
return $ret;
|
||||
}
|
||||
|
||||
if(!$ConfigLang)
|
||||
{
|
||||
$lang = 'en';
|
||||
}
|
||||
else
|
||||
{
|
||||
$lang = $ConfigLang;
|
||||
}
|
||||
function get_langs($DEBUG=False)
|
||||
{
|
||||
return translaton::get_langs($DEBUG);
|
||||
}
|
||||
|
||||
$fn = '.' . SEP . 'lang' . SEP . EGW_LANGFILE_PREFIX . $lang . '.lang';
|
||||
if (!file_exists($fn))
|
||||
function drop_langs($appname,$DEBUG=False)
|
||||
{
|
||||
return translaton::drop_langs($appname,$DEBUG);
|
||||
}
|
||||
|
||||
function add_langs($appname,$DEBUG=False,$force_langs=False)
|
||||
{
|
||||
return translaton::add_langs($appname,$DEBUG,$force_langs);
|
||||
}
|
||||
|
||||
function drop_add_all_langs($langs=False)
|
||||
{
|
||||
if (!$langs && !count($langs = translation::get_langs()))
|
||||
{
|
||||
$langs[] = 'en';
|
||||
}
|
||||
return translation::install_langs($langs,'dumpold');
|
||||
}
|
||||
|
||||
/**
|
||||
* List availible charsets and it's supported languages
|
||||
* @param boolean/string $name=false name for selectbox or false to return an array
|
||||
* @param string $selected selected charset
|
||||
* @return string/array html for a selectbox or array with charset / languages pairs
|
||||
*/
|
||||
function get_charsets($name=false,$selected='')
|
||||
{
|
||||
$charsets = array(
|
||||
'utf-8' => 'utf-8: '.lang('all languages (incl. not listed ones)'),
|
||||
);
|
||||
if (($f = fopen('lang/languages','r')))
|
||||
{
|
||||
while(($line = fgets($f)) !== false)
|
||||
{
|
||||
$fn = '.' . SEP . 'lang' . SEP . EGW_LANGFILE_PREFIX .'en.lang';
|
||||
}
|
||||
if (file_exists($fn))
|
||||
{
|
||||
$fp = fopen($fn,'r');
|
||||
while ($data = fgets($fp,8000))
|
||||
list($lang,$language) = explode("\t",trim($line));
|
||||
if ($lang && ($lf = @fopen("../phpgwapi/setup/" . EGW_LANGFILE_PREFIX . "$lang.lang",'r')))
|
||||
{
|
||||
// explode with "\t" and removing "\n" with str_replace, needed to work with mbstring.overload=7
|
||||
list($message_id,,,$content) = explode("\t",$data);
|
||||
$this->langarray[strtolower(trim($message_id))] = str_replace("\n",'',$content);
|
||||
}
|
||||
fclose($fp);
|
||||
|
||||
if (!$GLOBALS['egw_setup']->system_charset)
|
||||
{
|
||||
$GLOBALS['egw_setup']->system_charset = $this->langarray['charset'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Translate phrase to user selected lang
|
||||
*
|
||||
* @param $key phrase to translate
|
||||
* @param $vars vars sent to lang function, passed to us
|
||||
*/
|
||||
function translate($key, $vars=False)
|
||||
{
|
||||
$ret = $key . $this->no_translation_marker;
|
||||
$key = strtolower(trim($key));
|
||||
if (isset($this->langarray[$key]))
|
||||
{
|
||||
$ret = $this->langarray[$key];
|
||||
}
|
||||
if ($GLOBALS['egw_setup']->system_charset != $this->langarray['charset'])
|
||||
{
|
||||
if (!is_object($this->sql))
|
||||
{
|
||||
$this->setup_translation_sql();
|
||||
}
|
||||
$ret = $this->sql->convert($ret,$this->langarray['charset']);
|
||||
}
|
||||
if (is_array($vars))
|
||||
{
|
||||
foreach($vars as $n => $var)
|
||||
{
|
||||
$ret = str_replace( '%'.($n+1), $var, $ret );
|
||||
}
|
||||
}
|
||||
return $ret;
|
||||
}
|
||||
|
||||
// the following functions have been moved to phpgwapi/tanslation_sql
|
||||
|
||||
function setup_translation_sql()
|
||||
{
|
||||
if (!is_object($this->sql) || is_object($GLOBALS['egw_setup']->db) && !is_object($this->sql->db))
|
||||
{
|
||||
include_once(EGW_API_INC.'/class.translation.inc.php');
|
||||
$this->sql =& new translation;
|
||||
}
|
||||
}
|
||||
|
||||
function get_langs($DEBUG=False)
|
||||
{
|
||||
$this->setup_translation_sql();
|
||||
return $this->sql->get_langs($DEBUG);
|
||||
}
|
||||
|
||||
function drop_langs($appname,$DEBUG=False)
|
||||
{
|
||||
$this->setup_translation_sql();
|
||||
return $this->sql->drop_langs($appname,$DEBUG);
|
||||
}
|
||||
|
||||
function add_langs($appname,$DEBUG=False,$force_langs=False)
|
||||
{
|
||||
$this->setup_translation_sql();
|
||||
return $this->sql->add_langs($appname,$DEBUG,$force_langs);
|
||||
}
|
||||
|
||||
function drop_add_all_langs($langs=False)
|
||||
{
|
||||
$this->setup_translation_sql();
|
||||
|
||||
if (!$langs && !count($langs = $this->sql->get_langs()))
|
||||
{
|
||||
$langs[] = 'en';
|
||||
}
|
||||
return $this->sql->install_langs($langs,'dumpold');
|
||||
}
|
||||
|
||||
/**
|
||||
* List availible charsets and it's supported languages
|
||||
* @param boolean/string $name=false name for selectbox or false to return an array
|
||||
* @param string $selected selected charset
|
||||
* @return string/array html for a selectbox or array with charset / languages pairs
|
||||
*/
|
||||
function get_charsets($name=false,$selected='')
|
||||
{
|
||||
$charsets = array(
|
||||
'utf-8' => 'utf-8: '.lang('all languages (incl. not listed ones)'),
|
||||
);
|
||||
if (($f = fopen('lang/languages','r')))
|
||||
{
|
||||
while(($line = fgets($f)) !== false)
|
||||
{
|
||||
list($lang,$language) = explode("\t",trim($line));
|
||||
if ($lang && ($lf = @fopen("../phpgwapi/setup/" . EGW_LANGFILE_PREFIX . "$lang.lang",'r')))
|
||||
while(($line = fgets($lf)) !== false)
|
||||
{
|
||||
while(($line = fgets($lf)) !== false)
|
||||
list($phrase,,,$charset) = explode("\t",$line);
|
||||
if ($phrase == 'charset')
|
||||
{
|
||||
list($phrase,,,$charset) = explode("\t",$line);
|
||||
if ($phrase == 'charset')
|
||||
$charset = trim(strtolower($charset));
|
||||
|
||||
if ($charset != 'utf-8')
|
||||
{
|
||||
$charset = trim(strtolower($charset));
|
||||
|
||||
if ($charset != 'utf-8')
|
||||
{
|
||||
$charsets[$charset] .= (isset($charsets[$charset]) ? ', ' : $charset.': ') . $language;
|
||||
}
|
||||
break;
|
||||
$charsets[$charset] .= (isset($charsets[$charset]) ? ', ' : $charset.': ') . $language;
|
||||
}
|
||||
break;
|
||||
}
|
||||
fclose($lf);
|
||||
}
|
||||
fclose($lf);
|
||||
}
|
||||
fclose($f);
|
||||
}
|
||||
if (!$name)
|
||||
{
|
||||
return $charsets;
|
||||
}
|
||||
$html =& CreateObject('phpgwapi.html');
|
||||
|
||||
return $html->select($name,trim(strtolower($selected)),$charsets,true);
|
||||
fclose($f);
|
||||
}
|
||||
if (!$name)
|
||||
{
|
||||
return $charsets;
|
||||
}
|
||||
return html::select($name,trim(strtolower($selected)),$charsets,true);
|
||||
}
|
||||
?>
|
||||
}
|
||||
|
@ -22,11 +22,9 @@ $GLOBALS['egw_setup']->loaddb();
|
||||
|
||||
if (@$_POST['submit'])
|
||||
{
|
||||
$GLOBALS['egw_setup']->translation->setup_translation_sql();
|
||||
$GLOBALS['egw_setup']->translation->sql->install_langs(@$_POST['lang_selected'],@$_POST['upgrademethod']);
|
||||
translation::install_langs(@$_POST['lang_selected'],@$_POST['upgrademethod']);
|
||||
|
||||
|
||||
if( !$GLOBALS['egw_setup']->translation->sql->line_rejected )
|
||||
if(!translation::$line_rejected )
|
||||
{
|
||||
Header('Location: index.php');
|
||||
exit;
|
||||
@ -89,10 +87,10 @@ else
|
||||
}
|
||||
|
||||
// Rejected Lines
|
||||
if($_POST['debug'] && count($GLOBALS['egw_setup']->translation->sql->line_rejected))
|
||||
if($_POST['debug'] && count(translation::$line_rejected))
|
||||
{
|
||||
$str = '';
|
||||
foreach($GLOBALS['egw_setup']->translation->sql->line_rejected as $badline)
|
||||
foreach(translation::$line_rejected as $badline)
|
||||
{
|
||||
$_f_buffer = split("[/\\]", $badline['appfile']);
|
||||
$str .= lang('Application: %1, File: %2, Line: "%3"','<b>'.$_f_buffer[count($_f_buffer)-3].'</b>',
|
||||
|
Loading…
Reference in New Issue
Block a user