diff options
Diffstat (limited to 'phpBB/includes/session.php')
| -rw-r--r-- | phpBB/includes/session.php | 52 | 
1 files changed, 35 insertions, 17 deletions
| diff --git a/phpBB/includes/session.php b/phpBB/includes/session.php index 4fac6ddd68..dc3fd7e142 100644 --- a/phpBB/includes/session.php +++ b/phpBB/includes/session.php @@ -1371,7 +1371,7 @@ class user extends session  	var $timezone;  	var $dst; -	var $lang_name; +	var $lang_name = false;  	var $lang_id = false;  	var $lang_path;  	var $img_lang; @@ -1382,6 +1382,30 @@ class user extends session  	var $keyvalues = array();  	/** +	* Constructor to set the lang path +	*/ +	public function __construct() +	{ +		$this->lang_path = PHPBB_ROOT_PATH . 'language/'; +	} + +	/** +	* Function to set custom language path (able to use directory outside of phpBB) +	* +	* @param string $lang_path New language path used. +	* @access public +	*/ +	function set_custom_lang_path($lang_path) +	{ +		$this->lang_path = $lang_path; + +		if (substr($this->lang_path, -1) != '/') +		{ +			$this->lang_path .= '/'; +		} +	} + +	/**  	* Setup basic user-specific items (style, language, ...)  	*/  	function setup($lang_set = false, $style = false) @@ -1390,9 +1414,7 @@ class user extends session  		if ($this->data['user_id'] != ANONYMOUS)  		{ -			$this->lang_name = (file_exists(PHPBB_ROOT_PATH . 'language/' . $this->data['user_lang'] . '/common.' . PHP_EXT)) ? $this->data['user_lang'] : basename($config['default_lang']); -			$this->lang_path = PHPBB_ROOT_PATH . 'language/' . $this->lang_name . '/'; - +			$this->lang_name = (file_exists($this->lang_path . $this->data['user_lang'] . "/common." . PHP_EXT)) ? $this->data['user_lang'] : basename($config['default_lang']);  			$this->date_format = $this->data['user_dateformat'];  			$this->timezone = $this->data['user_timezone'] * 3600;  			$this->dst = $this->data['user_dst'] * 3600; @@ -1400,7 +1422,6 @@ class user extends session  		else  		{  			$this->lang_name = basename($config['default_lang']); -			$this->lang_path = PHPBB_ROOT_PATH . 'language/' . $this->lang_name . '/';  			$this->date_format = $config['default_dateformat'];  			$this->timezone = $config['board_timezone'] * 3600;  			$this->dst = $config['board_dst'] * 3600; @@ -1420,10 +1441,9 @@ class user extends session  					$accept_lang = substr($accept_lang, 0, 2) . '_' . strtoupper(substr($accept_lang, 3, 2));  					$accept_lang = basename($accept_lang); -					if (file_exists(PHPBB_ROOT_PATH . 'language/' . $accept_lang . "/common." . PHP_EXT)) +					if (file_exists($this->lang_path . $accept_lang . "/common." . PHP_EXT))  					{  						$this->lang_name = $config['default_lang'] = $accept_lang; -						$this->lang_path = PHPBB_ROOT_PATH . 'language/' . $accept_lang . '/';  						break;  					}  					else @@ -1432,10 +1452,9 @@ class user extends session  						$accept_lang = substr($accept_lang, 0, 2);  						$accept_lang = basename($accept_lang); -						if (file_exists(PHPBB_ROOT_PATH . 'language/' . $accept_lang . "/common." . PHP_EXT)) +						if (file_exists($this->lang_path . $accept_lang . "/common." . PHP_EXT))  						{  							$this->lang_name = $config['default_lang'] = $accept_lang; -							$this->lang_path = PHPBB_ROOT_PATH . 'language/' . $accept_lang . '/';  							break;  						}  					} @@ -1447,9 +1466,9 @@ class user extends session  		// We include common language file here to not load it every time a custom language file is included  		$lang = &$this->lang; -		if ((@include $this->lang_path . 'common.' . PHP_EXT) === false) +		if ((@include $this->lang_path . $this->lang_name . "/common." . PHP_EXT) === false)  		{ -			die('Language file ' . $this->lang_name . '/common.' . PHP_EXT . " couldn't be opened."); +			die('Language file ' . $this->lang_path . $this->lang_name . "/common." . PHP_EXT . " couldn't be opened.");  		}  		$this->add_lang($lang_set); @@ -1813,12 +1832,11 @@ class user extends session  	*/  	function set_lang(&$lang, &$help, $lang_file, $use_db = false, $use_help = false)  	{ -		// Make sure the language path is set (if the user setup did not happen it is not set) -		if (!$this->lang_path) +		// Make sure the language name is set (if the user setup did not happen it is not set) +		if (!$this->lang_name)  		{  			global $config; - -			$this->lang_path = PHPBB_ROOT_PATH . 'language/' . basename($config['default_lang']) . '/'; +			$this->lang_name = basename($config['default_lang']);  		}  		// $lang == $this->lang @@ -1828,11 +1846,11 @@ class user extends session  		{  			if ($use_help && strpos($lang_file, '/') !== false)  			{ -				$language_filename = $this->lang_path . substr($lang_file, 0, stripos($lang_file, '/') + 1) . 'help_' . substr($lang_file, stripos($lang_file, '/') + 1) . '.' . PHP_EXT; +				$language_filename = $this->lang_path . $this->lang_name . '/' . substr($lang_file, 0, stripos($lang_file, '/') + 1) . 'help_' . substr($lang_file, stripos($lang_file, '/') + 1) . '.' . PHP_EXT;  			}  			else  			{ -				$language_filename = $this->lang_path . (($use_help) ? 'help_' : '') . $lang_file . '.' . PHP_EXT; +				$language_filename = $this->lang_path . $this->lang_name . '/' . (($use_help) ? 'help_' : '') . $lang_file . '.' . PHP_EXT;  			}  			if ((@include $language_filename) === false) | 
