Home >php教程 >php手册 >CI框架源码阅读---------Lang.php

CI框架源码阅读---------Lang.php

WBOY
WBOYOriginal
2016-06-13 10:55:341129browse

[php]  

/** 

 * 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 */  

 

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn