aboutsummaryrefslogtreecommitdiffstats
path: root/library/intl/src/Language/LanguageRepository.php
diff options
context:
space:
mode:
authorzotlabs <mike@macgirvin.com>2017-11-04 18:18:10 -0700
committerzotlabs <mike@macgirvin.com>2017-11-04 18:18:10 -0700
commit7ef641e256aba64978ea9a41a31b78e4af5c68b0 (patch)
treeac7e80030e53bc0c91fb6a3757e04e4e65fb1b3b /library/intl/src/Language/LanguageRepository.php
parent1d903655afdd8e49942c6d6c9ca1a7feadeaaa82 (diff)
parent6995d54a3cc162d87f881f6e206fa356230fd9e8 (diff)
downloadvolse-hubzilla-7ef641e256aba64978ea9a41a31b78e4af5c68b0.tar.gz
volse-hubzilla-7ef641e256aba64978ea9a41a31b78e4af5c68b0.tar.bz2
volse-hubzilla-7ef641e256aba64978ea9a41a31b78e4af5c68b0.zip
Merge branch 'dev' of https://github.com/redmatrix/hubzilla into dev_merge
Diffstat (limited to 'library/intl/src/Language/LanguageRepository.php')
-rw-r--r--library/intl/src/Language/LanguageRepository.php96
1 files changed, 0 insertions, 96 deletions
diff --git a/library/intl/src/Language/LanguageRepository.php b/library/intl/src/Language/LanguageRepository.php
deleted file mode 100644
index 50335cdc0..000000000
--- a/library/intl/src/Language/LanguageRepository.php
+++ /dev/null
@@ -1,96 +0,0 @@
-<?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;
- }
-}