<?php if ( ! defined("BASEPATH")) exit("No direct script access allowed");
/**
* CodeIgniter
*
* An open source application development framework for PHP 5.1.6 or newer
*
* @package CodeIgniter
* @author ExpressionEngine Dev Team
* @copyright Copyright (c) 2008 - 2011, EllisLab, Inc.
* @license http://codeigniter.com/user_guide/license.html
* @link http://codeigniter.com
* @since Version 1.0
* @filesource
*/
// ------------------------------------------------------------------------
/**
* Language Class
* 官方使用手册:http://codeigniter.org.cn/user_guide/libraries/language.html
* @package CodeIgniter
* @subpackage Libraries
* @category Language
* @author ExpressionEngine Dev Team
* @link http://codeigniter.com/user_guide/libraries/language.html
*/
class CI_Lang {
/**
* List of translations
* 语言包列表
* @var array
*/
var $language = array();
/**
* List of loaded language files
* 已经被加载的语言包列表
* @var array
*/
var $is_loaded = array();
/**
* Constructor
*
* @access public
*/
function __construct()
{
log_message("debug", "Language Class Initialized");
}
// --------------------------------------------------------------------
/**
* Load a language file
* 加载语言包
* @access public
* @param mixed the name of the language file to be loaded. Can be an array
* 要被加载的语言文件。
* @param string the language (english, etc.) 要使用的语言
* @param bool return loaded array of translations 直接返回语言包数组
* 不加入到$this->is_loaded和$this->language中去
* @param bool add suffix to $langfile 文件是否添加后缀
* @param string alternative path to look for language file 语言包文件的自定义路径
* @return mixed
*/
function load($langfile = "", $idiom = "", $return = FALSE, $add_suffix = TRUE, $alt_path = "")
{
// langfile 文件的.php 后缀去掉
$langfile = str_replace(".php", "", $langfile);
// 判断需不需要添加后缀如果需要
// 将_lang. 去掉并再langfile后面添加_lang
if ($add_suffix == TRUE)
{
$langfile = str_replace("_lang.", "", $langfile)."_lang";
}
// 为langfile添加.php后缀
$langfile .= ".php";
// 判断当前文件是否被加载过
if (in_array($langfile, $this->is_loaded, TRUE))
{
return;
}
// 获取配置文件的数据
$config =& get_config();
// 如果要使用的语言为空
// 那么 我们将从$config中获取
if ($idiom == "")
{
$deft_lang = ( ! isset($config["language"])) ? "english" : $config["language"];
$idiom = ($deft_lang == "") ? "english" : $deft_lang;
}
// Determine where the language file is and load it
// 在自定义路径下寻找语言包并加载
if ($alt_path != "" && file_exists($alt_path."language/".$idiom."/".$langfile))
{
include($alt_path."language/".$idiom."/".$langfile);
}
else
{
// 如果自定义路径下没找到调用get_instance()->load->get_package_paths(TRUE)
// 在包路径下寻找
// get_package_paths这个函数在loader.php中
$found = FALSE;
foreach (get_instance()->load->get_package_paths(TRUE) as $package_path)
{
if (file_exists($package_path."language/".$idiom."/".$langfile))
{
include($package_path."language/".$idiom."/".$langfile);
$found = TRUE;
break;
}
}
// 如果还没找到就只能报错了
//
if ($found !== TRUE)
{
show_error("Unable to load the requested language file: language/".$idiom."/".$langfile);
}
}
if ( ! isset($lang))
{
log_message("error", "Language file contains no data: language/".$idiom."/".$langfile);
return;
}
if ($return == TRUE)
{
return $lang;
}
$this->is_loaded[] = $langfile;
$this->language = array_merge($this->language, $lang);
unset($lang);
log_message("debug", "Language file loaded: language/".$idiom."/".$langfile);
return TRUE;
}
// --------------------------------------------------------------------
/**
* Fetch a single line of text from the language array
* 获取一行文本
* @access public
* @param string $line the language line
* @return string
*/
function line($line = "")
{
/*
* $this->language 的样子
* $lang["error_email_missing"] = "You must submit an email address";
* $lang["error_url_missing"] = "You must submit a URL";
* $lang["error_username_missing"] = "You must submit a username";
*/
$value = ($line == "" OR ! isset($this->language[$line])) ? FALSE : $this->language[$line];
// Because killer robots like unicorns!
if ($value === FALSE)
{
log_message("error", "Could not find the language line "".$line.""");
}
return $value;
}
}
// END Language Class
/* End of file Lang.php */
/* Location: ./system/core/Lang.php */