"allow mixed installations of trunk and 1.4 apps, by reading both langfiles"

This commit is contained in:
Ralf Becker 2007-10-19 13:02:55 +00:00
parent e1dec0fc76
commit 761cb8c9a0

View File

@ -42,6 +42,7 @@
// Define prefix for langfiles (historically 'phpgw_') // Define prefix for langfiles (historically 'phpgw_')
define('EGW_LANGFILE_PREFIX', 'egw_'); define('EGW_LANGFILE_PREFIX', 'egw_');
define('PHPGW_LANGFILE_PREFIX', 'phpgw_');
class translation class translation
{ {
@ -241,26 +242,30 @@
*/ */
function add_setup($lang) function add_setup($lang)
{ {
$fn = EGW_SERVER_ROOT.'/setup/lang/' . EGW_LANGFILE_PREFIX . $lang . '.lang'; foreach(array(
if (!file_exists($fn)) EGW_SERVER_ROOT.'/setup/lang/' . EGW_LANGFILE_PREFIX . $lang . '.lang',
EGW_SERVER_ROOT.'/setup/lang/' . PHPGW_LANGFILE_PREFIX . $lang . '.lang',
EGW_SERVER_ROOT.'/setup/lang/' . EGW_LANGFILE_PREFIX . 'en.lang',
EGW_SERVER_ROOT.'/setup/lang/' . PHPGW_LANGFILE_PREFIX . 'en.lang',
) as $fn)
{ {
$fn = EGW_SERVER_ROOT.'/setup/lang/' . EGW_LANGFILE_PREFIX . 'en.lang'; if (file_exists($fn))
}
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 $fp = fopen($fn,'r');
list($message_id,,,$content) = explode("\t",$data); while ($data = fgets($fp,8000))
$phrases[strtolower(trim($message_id))] = str_replace("\n",'',$content); {
} // explode with "\t" and removing "\n" with str_replace, needed to work with mbstring.overload=7
fclose($fp); list($message_id,,,$content) = explode("\t",$data);
$phrases[strtolower(trim($message_id))] = str_replace("\n",'',$content);
}
fclose($fp);
foreach($phrases as $message_id => $content) foreach($phrases as $message_id => $content)
{ {
$this->lang_arr[$message_id] = $this->convert($content,$phrases['charset']); $this->lang_arr[$message_id] = $this->convert($content,$phrases['charset']);
}
} }
break;
} }
$this->loaded_apps['setup'] = $lang; $this->loaded_apps['setup'] = $lang;
} }
@ -556,8 +561,9 @@
foreach($apps as $app) foreach($apps as $app)
{ {
$appfile = EGW_SERVER_ROOT . SEP . $app . SEP . 'setup' . SEP . EGW_LANGFILE_PREFIX . strtolower($lang) . '.lang'; $appfile = EGW_SERVER_ROOT . SEP . $app . SEP . 'setup' . SEP . EGW_LANGFILE_PREFIX . strtolower($lang) . '.lang';
$old_appfile = EGW_SERVER_ROOT . SEP . $app . SEP . 'setup' . SEP . PHPGW_LANGFILE_PREFIX . strtolower($lang) . '.lang';
//echo '<br>Checking in: ' . $app; //echo '<br>Checking in: ' . $app;
if($GLOBALS['egw_setup']->app_registered($app) && file_exists($appfile)) if($GLOBALS['egw_setup']->app_registered($app) && (file_exists($appfile) || file_exists($appfile=$old_appfile)))
{ {
//echo '<br>Including: ' . $appfile; //echo '<br>Including: ' . $appfile;
$lines = file($appfile); $lines = file($appfile);
@ -683,8 +689,9 @@
foreach($apps as $app => $data) foreach($apps as $app => $data)
{ {
$fname = EGW_SERVER_ROOT . "/$app/setup/" . EGW_LANGFILE_PREFIX . "$lang.lang"; $fname = EGW_SERVER_ROOT . "/$app/setup/" . EGW_LANGFILE_PREFIX . "$lang.lang";
$old_fname = EGW_SERVER_ROOT . "/$app/setup/" . PHPGW_LANGFILE_PREFIX . "$lang.lang";
if (file_exists($fname)) if (file_exists($fname) || file_exists($fname = $old_fname))
{ {
$ctime = filectime($fname); $ctime = filectime($fname);
/* This is done to avoid string offset error at least in php5 */ /* This is done to avoid string offset error at least in php5 */