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

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

WBOY
WBOYoriginal
2016-06-13 10:55:341128parcourir

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

 

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn