diff options
author | RedMatrix <info@friendica.com> | 2014-12-31 10:21:53 +1100 |
---|---|---|
committer | RedMatrix <info@friendica.com> | 2014-12-31 10:21:53 +1100 |
commit | 7b0b0dd76f97118e5cae64c2d444d9343da7074c (patch) | |
tree | 895de27ff85b372fd9bbb5f829942e329001a7ef /library/intl/src/Language/LanguageRepository.php | |
parent | 4a82967639e662821de177e3bd829b735b4eb24e (diff) | |
parent | b54bbf0fb8af72bd5273597f564f084aa1c1ac79 (diff) | |
download | volse-hubzilla-7b0b0dd76f97118e5cae64c2d444d9343da7074c.tar.gz volse-hubzilla-7b0b0dd76f97118e5cae64c2d444d9343da7074c.tar.bz2 volse-hubzilla-7b0b0dd76f97118e5cae64c2d444d9343da7074c.zip |
Merge pull request #794 from pafcu/lang
Language names via intl library.
Diffstat (limited to 'library/intl/src/Language/LanguageRepository.php')
-rw-r--r-- | library/intl/src/Language/LanguageRepository.php | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/library/intl/src/Language/LanguageRepository.php b/library/intl/src/Language/LanguageRepository.php new file mode 100644 index 000000000..50335cdc0 --- /dev/null +++ b/library/intl/src/Language/LanguageRepository.php @@ -0,0 +1,96 @@ +<?php + +namespace CommerceGuys\Intl\Language; + +use CommerceGuys\Intl\LocaleResolverTrait; +use CommerceGuys\Intl\Exception\UnknownLanguageException; + +/** + * Manages languages based on JSON definitions. + */ +class LanguageRepository implements LanguageRepositoryInterface +{ + use LocaleResolverTrait; + + /** + * Per-locale language definitions. + * + * @var array + */ + protected $definitions = array(); + + /** + * Creates a LanguageRepository instance. + * + * @param string $definitionPath The path to the currency definitions. + * Defaults to 'resources/language'. + */ + public function __construct($definitionPath = null) + { + $this->definitionPath = $definitionPath ? $definitionPath : __DIR__ . '/../../resources/language/'; + } + + /** + * {@inheritdoc} + */ + public function get($languageCode, $locale = null, $fallbackLocale = null) + { + $locale = $this->resolveLocale($locale, $fallbackLocale); + $definitions = $this->loadDefinitions($locale); + if (!isset($definitions[$languageCode])) { + throw new UnknownLanguageException($languageCode); + } + + return $this->createLanguageFromDefinition($definitions[$languageCode], $locale); + } + + /** + * {@inheritdoc} + */ + public function getAll($locale = null, $fallbackLocale = null) + { + $locale = $this->resolveLocale($locale, $fallbackLocale); + $definitions = $this->loadDefinitions($locale); + $languages = array(); + foreach ($definitions as $languageCode => $definition) { + $languages[$languageCode] = $this->createLanguageFromDefinition($definition, $locale); + } + + return $languages; + } + + /** + * Loads the language definitions for the provided locale. + * + * @param string $locale The desired locale. + * + * @return array + */ + protected function loadDefinitions($locale) + { + if (!isset($this->definitions[$locale])) { + $filename = $this->definitionPath . $locale . '.json'; + $this->definitions[$locale] = json_decode(file_get_contents($filename), true); + } + + return $this->definitions[$locale]; + } + + /** + * Creates a language object from the provided definition. + * + * @param array $definition The language definition. + * @param string $locale The locale of the language definition. + * + * @return Language + */ + protected function createLanguageFromDefinition(array $definition, $locale) + { + $language = new Language(); + $language->setLanguageCode($definition['code']); + $language->setName($definition['name']); + $language->setLocale($locale); + + return $language; + } +} |