Конфигурация реестра - как реализовать - PullRequest
1 голос
/ 06 февраля 2012

Я после некоторого ввода / руководства .. У меня есть приложение, которое использует реестр центральной конфигурации, как показано ниже ..

Приложение анализирует каталог конфигурации для файлов ini и устанавливает массивы в класс, используя имя файла в качестве индекса, а также отдельные переменные конфигурации при необходимости.

Я вижу несколько проблем, в том числе:

  1. Конфликты имен между файлами и переменными, установленными в скрипте
  2. Невозможность извлечь переменные вложенного массива, что приводит к следующему коду:

    $ database = config :: get ('database'); $ actual_record = $ database ['default'];

Я испытал желание добавить второй параметр get для вложенного значения, однако, что произойдет в будущем, если мне понадобится получить значение третьего или четвертого уровня.

class config
{
   private static $registry;

   /**
   *
   */
   private function __construct() {}

   /**
   *
   */
   public static function get($key)
   {
      if (isset(self::$registry[$key])) return self::$registry[$key];
      else return FALSE;
   }

   /**
   *
   */
   public static function set($key, $value, $overwrite = FALSE)
   {
      // Does the variable already exist?
      if (isset(self::$registry[$key]) && $overwrite === FALSE) 
         throw new Exception();

      self::$registry[$key] = $value;
   }
}

Заранее спасибо за помощь ..

Ответы [ 2 ]

2 голосов
/ 06 февраля 2012

Если я вас правильно понимаю, вы можете добавить новый экземпляр config снова, если на следующем уровне есть несколько значений.

Конфигурация, подобная этой

value.second = a
value.third = b
other.value.my = a
other.value.foo = b

Будет тогдарезультат в дереве классов, как это (config всегда является экземпляром класса, а намерение означает, что что-то находится в массиве атрибутов экземпляра config выше; тексты до => являются индексными именами, с которыми вы будетедоступ к ним).

config
    value => config
        second => a
        third => b
    other => config
        value => config
            my => a
            foo => b

Надеюсь, вы немного поймете, что я имею в виду.

Тогда вы сможете реализовать либо ArrayAccess , либо магические методы __get и __set для одного из следующих способов доступа к вашим значениям:

config->value->second
config->other->value->my

или

config['value']['second']
config['other']['value']['my']
1 голос
/ 06 февраля 2012

Как предлагается в комментариях, здесь приведен код для работы имен, разделенных точками. Там может быть более эффективное решение, я просто бросил это для вас.

class Config
{
    private
        $registry
    ;

    public function __construct($registry)
    {
        $this->registry = $registry;
    }

   public function get($identifier)
   {
        return $this->resolve(explode('.', $identifier), $this->registry);
    }

    private function resolve($entries, $in)
    {
        if(key_exists($entries[0], $in) && count($entries) > 1)
        {
            // We have more than one level to resolve
            $newIn = $in[$entries[0]];
            unset($entries[0]);
            return $this->resolve(array_values($entries), $newIn);
        }
        elseif(key_exists($entries[0], $in) && count($entries) == 1)
        {
            // We are at the bottom, let's return.
            return $in[$entries[0]];
        }
        // If we get here something went wrong.
        throw new Exception('Entry could not be resolved.');
    }
}

$cfg = new Config(
    array(
        'plain' => 'plain entry',
        'nested'    =>  array(
            'first' =>  'nested, first entry',
            'second'    =>  array(
                'third' =>  'deeper nested entry'
            )
        )
    )
);

print_r($cfg->get('plain'))."\n";
print_r($cfg->get('nested.first'))."\n";
print_r($cfg->get('nested.second.third'))."\n";
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...