addNamespace($hash['ID'], $hash['DESCRIPTION']); $this->_findUnused($hash); return; } list($ns, $directive) = explode('.', $hash['ID'], 2); if (isset($hash['TYPE'], $hash['DEFAULT'], $hash['DESCRIPTION'])) { $type = $hash['TYPE']; $raw_default = $hash['DEFAULT']; $default = eval("return $raw_default;"); $description = $hash['DESCRIPTION']; $schema->add($ns, $directive, $default, $type, $description); } if (isset($hash['ALLOWED'])) { $raw_allowed = $hash['ALLOWED']; $allowed = eval("return array($raw_allowed);"); $schema->addAllowedValues($ns, $directive, $allowed); } // This must be after ALLOWED if (isset($hash['VALUE-ALIASES'])) { $raw_value_aliases = $hash['VALUE-ALIASES']; $value_aliases = eval("return array($raw_value_aliases);"); $schema->addValueAliases($ns, $directive, $value_aliases); } if (isset($hash['ALIASES'])) { $raw_aliases = $hash['ALIASES']; $aliases = preg_split('/\s*,\s*/', $raw_aliases); foreach ($aliases as $alias) { list($alias_ns, $alias_directive) = explode('.', $alias, 2); $schema->addAlias($alias_ns, $alias_directive, $ns, $directive); } } $this->_findUnused($hash); } /** * Triggers errors for any unused keys passed in the hash; such keys * may indicate typos, missing values, etc. * @param $hash Instance of ConfigSchema_StringHash to check. */ protected function _findUnused($hash) { $accessed = $hash->getAccessed(); foreach ($hash as $k => $v) { if (!isset($accessed[$k])) { trigger_error("String hash key '$k' not used by adapter", E_USER_NOTICE); } } } }