本文整理匯總了PHP中Zend_Config::setReadOnly方法的典型用法代碼示例。如果您正苦於以下問題:PHP Zend_Config::setReadOnly方法的具體用法?PHP Zend_Config::setReadOnly怎麽用?PHP Zend_Config::setReadOnly使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Zend_Config
的用法示例。
在下文中一共展示了Zend_Config::setReadOnly方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: _initConfig
/**
* Combine the static info found in application.ini with the
* dynamic info found in the Info table.
*
* @return void
*/
protected function _initConfig()
{
$this->bootstrap('db');
$this->bootstrap('locale');
if (!class_exists('Model_Info')) {
return;
}
try {
$staticConfig = Zend_Registry::get('config');
$infoModel = $this->_getInfoModel();
$dynamicConfig = $infoModel->fetchAsConfig(null, APPLICATION_ENV);
// Very sneakily bypass 'readOnly'
if ($staticConfig->readOnly()) {
$staticConfig = new Zend_Config($staticConfig->toArray(), APPLICATION_ENV, true);
}
$staticConfig->merge($dynamicConfig);
$staticConfig->setReadOnly();
Zend_Registry::set('config', $staticConfig);
} catch (Exception $e) {
$msg = $e->getMessage();
if (strpos($msg, 'Unknown database') === false && strpos($msg, "doesn't exist") === false) {
throw $e;
}
}
}
示例2: setQuotaModuleEnableDev
/**
* @param boolean $enableDev
*/
protected function setQuotaModuleEnableDev($enableDev)
{
$config = Registry::getConfig();
$newConfig = new \Zend_Config($config->toArray(), true);
$newConfig->quota->module->enableDev = $enableDev;
$newConfig->setReadOnly();
Registry::setConfig($newConfig);
}
示例3: _initConfig
public function _initConfig()
{
$config = new Zend_Config($this->getOptions(), true);
$inifiles = array('app', 'cache', 'private');
//TODO: only load cache.ini for models
foreach ($inifiles as $file) {
$inifile = APPLICATION_PATH . "/configs/{$file}.ini";
if (is_readable($inifile)) {
$config->merge(new Zend_Config_Ini($inifile));
}
}
$config->setReadOnly();
$this->setOptions($config->toArray());
Zend_Registry::set('config', $config);
define('DATE_DB', 'Y-m-d H:i:s');
}
示例4: init
/**
* Load both config files.
*
* @return Zend_Config
*/
public function init()
{
$mainConfig = $this->_coreResource->init();
$testConfigPath = APP_DIR . '/tests/config.ini';
$config = new Zend_Config_Ini($testConfigPath);
if (!Zend_Registry::isRegistered('test_config')) {
Zend_Registry::set('test_config', $config->testing);
}
// Merging the configs allows us to override settings only for tests.
if ($config->site instanceof Zend_Config) {
$mainCopy = new Zend_Config($mainConfig->toArray(), true);
$mainCopy->merge($config->site);
$mainCopy->setReadOnly(true);
$mainConfig = $mainCopy;
}
return $mainConfig;
}
示例5: testSetReadOnly
/**
* ensure that modification is not allowed after calling setReadOnly()
*
*/
public function testSetReadOnly()
{
$configData = array('a' => 'a');
$config = new Zend_Config($configData, true);
$config->b = 'b';
$config->setReadOnly();
try {
$config->c = 'c';
} catch (Zend_Config_Exception $expected) {
$this->assertContains('is read only', $expected->getMessage());
return;
}
$this->fail('Expected read only exception has not been raised.');
}
示例6: testSetReadOnlyAppliesToChildren
/**
* @group ZF-4728
*
*/
public function testSetReadOnlyAppliesToChildren()
{
$config = new Zend_Config($this->_all, true);
$config->setReadOnly();
$this->assertTrue($config->readOnly());
$this->assertTrue($config->one->readOnly(), 'First level children are writable');
$this->assertTrue($config->one->two->readOnly(), 'Second level children are writable');
}
示例7: foreach
if (isset($arr['zend']['zend_path'])) {
$zenddir = $arr['zend']['zend_path'];
}
}
// Setup include path
//add zend directory to include path
set_include_path(get_include_path() . PATH_SEPARATOR . $zenddir);
// Initialize Zend Framework loader
require_once 'Zend/Loader/Autoloader.php';
// require_once 'services/Pdoconfig.php';
// require_once 'services/UserModel.php';
Zend_Loader_Autoloader::getInstance();
// Load configuration
$default_config = new Zend_Config(array("production" => false), true);
$default_config->merge(new Zend_Config_Ini($configfile, 'zendamf'));
$default_config->setReadOnly();
$amf = $default_config->amf;
// Store configuration in the registry
Zend_Registry::set("amf-config", $amf);
// Initialize AMF Server
$server = new Zend_Amf_Server();
$server->setProduction($amf->production);
if (isset($amf->directories)) {
$dirs = $amf->directories->toArray();
foreach ($dirs as $dir) {
// get the first character of the path.
// If it does not start with slash then it implies that the path is relative to webroot. Else it will be treated as absolute path
$length = strlen($dir);
$firstChar = $dir;
if ($length >= 1) {
$firstChar = $dir[0];
示例8: removeValue
/**
* @param array $pathToValue
*/
public static function removeValue(array $pathToValue)
{
$config = Registry::getConfig()->toArray();
if (count($pathToValue) <= 0) {
$config = array();
} else {
$configPart =& $config;
foreach (array_slice($pathToValue, 0, -1) as $key) {
if (!array_key_exists($key, $configPart)) {
return;
}
$configPart =& $configPart[$key];
}
unset($configPart[end($pathToValue)]);
}
$newConfig = new \Zend_Config($config, true);
$newConfig->setReadOnly();
Registry::setConfig($newConfig);
}