216 lines
4.2 KiB
PHP
216 lines
4.2 KiB
PHP
<?php namespace Laravel;
|
|
|
|
class Lang_Factory {
|
|
|
|
/**
|
|
* The configuration manager instance.
|
|
*
|
|
* @var Config
|
|
*/
|
|
protected $config;
|
|
|
|
/**
|
|
* The paths containing the language files.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $paths;
|
|
|
|
/**
|
|
* Create a new language factory instance.
|
|
*
|
|
* Note: The entire configuration manager is used in case the default language
|
|
* is changed during the course of a request to the application.
|
|
*
|
|
* @param Config $config
|
|
* @param array $paths
|
|
* @return void
|
|
*/
|
|
public function __construct(Config $config, $paths)
|
|
{
|
|
$this->paths = $paths;
|
|
$this->config = $config;
|
|
}
|
|
|
|
/**
|
|
* Begin retrieving a language line.
|
|
*
|
|
* @param string $key
|
|
* @param array $replacements
|
|
* @return Lang
|
|
*/
|
|
public function line($key, $replacements = array())
|
|
{
|
|
return new Lang($key, $replacements, $this->config->get('application.language'), $this->paths);
|
|
}
|
|
|
|
}
|
|
|
|
class Lang {
|
|
|
|
/**
|
|
* All of the loaded language lines.
|
|
*
|
|
* The array is keyed by [$language.$file].
|
|
*
|
|
* @var array
|
|
*/
|
|
private static $lines = array();
|
|
|
|
/**
|
|
* The key of the language line being retrieved.
|
|
*
|
|
* @var string
|
|
*/
|
|
private $key;
|
|
|
|
/**
|
|
* The replacements that should be made on the language line.
|
|
*
|
|
* @var array
|
|
*/
|
|
private $replacements;
|
|
|
|
/**
|
|
* The default language being used by the application.
|
|
*
|
|
* @var string
|
|
*/
|
|
private $language;
|
|
|
|
/**
|
|
* The paths containing the language files.
|
|
*
|
|
* @var array
|
|
*/
|
|
private $paths;
|
|
|
|
/**
|
|
* Create a new Lang instance.
|
|
*
|
|
* @param string $key
|
|
* @param array $replacements
|
|
* @param string $language
|
|
* @param array $paths
|
|
* @return void
|
|
*/
|
|
public function __construct($key, $replacements, $language, $paths)
|
|
{
|
|
$this->key = $key;
|
|
$this->paths = $paths;
|
|
$this->language = $language;
|
|
$this->replacements = $replacements;
|
|
}
|
|
|
|
/**
|
|
* Create a new Lang instance.
|
|
*
|
|
* @param string $key
|
|
* @param array $replacements
|
|
* @return Lang
|
|
*/
|
|
public static function line($key, $replacements = array())
|
|
{
|
|
return IoC::container()->resolve('laravel.lang')->line($key, $replacements);
|
|
}
|
|
|
|
/**
|
|
* Get the language line.
|
|
*
|
|
* A default value may also be specified, which will be returned in the language line doesn't exist.
|
|
*
|
|
* @param string $language
|
|
* @return string
|
|
*/
|
|
public function get($default = null)
|
|
{
|
|
list($file, $line) = $this->parse($this->key);
|
|
|
|
if ( ! $this->load($file))
|
|
{
|
|
return ($default instanceof \Closure) ? call_user_func($default) : $default;
|
|
}
|
|
|
|
$line = Arr::get(static::$lines[$this->language.$file], $line, $default);
|
|
|
|
foreach ($this->replacements as $key => $value)
|
|
{
|
|
$line = str_replace(':'.$key, $value, $line);
|
|
}
|
|
|
|
return $line;
|
|
}
|
|
|
|
/**
|
|
* Parse a language key.
|
|
*
|
|
* Language keys follow a {file}.{key} convention. If a specific language key is not
|
|
* specified, an exception will be thrown. Setting entire language files at run-time
|
|
* is not currently supported.
|
|
*
|
|
* @param string $key
|
|
* @return array
|
|
*/
|
|
private function parse($key)
|
|
{
|
|
if (count($segments = explode('.', $key)) > 1)
|
|
{
|
|
return array($segments[0], implode('.', array_slice($segments, 1)));
|
|
}
|
|
|
|
throw new \Exception("Invalid language line [$key]. A specific line must be specified.");
|
|
}
|
|
|
|
/**
|
|
* Load a language file.
|
|
*
|
|
* If the language file has already been loaded, it will not be loaded again.
|
|
*
|
|
* @param string $file
|
|
* @return bool
|
|
*/
|
|
private function load($file)
|
|
{
|
|
if (isset(static::$lines[$this->language.$file])) return;
|
|
|
|
$language = array();
|
|
|
|
foreach ($this->paths as $directory)
|
|
{
|
|
if (file_exists($path = $directory.$this->language.'/'.$file.EXT))
|
|
{
|
|
$language = array_merge($language, require $path);
|
|
}
|
|
}
|
|
|
|
if (count($language) > 0)
|
|
{
|
|
static::$lines[$this->language.$file] = $language;
|
|
}
|
|
|
|
return isset(static::$lines[$this->language.$file]);
|
|
}
|
|
|
|
/**
|
|
* Set the language the line should be returned in.
|
|
*
|
|
* The language specified in this method should correspond to a language directory in your application.
|
|
*
|
|
* @param string $language
|
|
* @return Lang
|
|
*/
|
|
public function in($language)
|
|
{
|
|
$this->language = $language;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the string content of the language line.
|
|
*/
|
|
public function __toString()
|
|
{
|
|
return $this->get();
|
|
}
|
|
|
|
} |