2012-04-17 16:52:01 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scope guard to hold a temporary environment. See @{class:PhabricatorEnv} for
|
|
|
|
* instructions on use.
|
|
|
|
*
|
|
|
|
* @task internal Internals
|
|
|
|
* @task override Overriding Environment Configuration
|
|
|
|
*/
|
|
|
|
final class PhabricatorScopedEnv {
|
|
|
|
|
|
|
|
private $key;
|
2012-05-01 22:11:45 +02:00
|
|
|
private $isPopped = false;
|
2012-04-17 16:52:01 +02:00
|
|
|
|
|
|
|
/* -( Overriding Environment Configuration )------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Override a configuration key in this scope, setting it to a new value.
|
|
|
|
*
|
|
|
|
* @param string Key to override.
|
|
|
|
* @param wild New value.
|
|
|
|
* @return this
|
|
|
|
*
|
|
|
|
* @task override
|
|
|
|
*/
|
|
|
|
public function overrideEnvConfig($key, $value) {
|
|
|
|
PhabricatorEnv::overrideEnvConfig(
|
|
|
|
$this->key,
|
|
|
|
$key,
|
|
|
|
$value);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* -( Internals )---------------------------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @task internal
|
|
|
|
*/
|
|
|
|
public function __construct($stack_key) {
|
|
|
|
$this->key = $stack_key;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Release the scoped environment.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @task internal
|
|
|
|
*/
|
|
|
|
public function __destruct() {
|
2012-05-01 22:11:45 +02:00
|
|
|
if (!$this->isPopped) {
|
|
|
|
PhabricatorEnv::popEnvironment($this->key);
|
|
|
|
$this->isPopped = true;
|
|
|
|
}
|
2012-04-17 16:52:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|