mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-04 20:01:00 +01:00
Provide a local cache for PhabricatorEnv
Summary: We hit some env config fairly often (~200 calls on the home page) and it's not especially cheap right now. This saves about 10ms on home, which is ~8% of the page weight on my machine. Test Plan: Clicked around, everything seemed fine. Unit tests. Reviewers: btrahan Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D5512
This commit is contained in:
parent
80e9fb72bb
commit
cd07182e9c
2 changed files with 60 additions and 40 deletions
|
@ -794,7 +794,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'aphront-panel-view-css' =>
|
'aphront-panel-view-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/5600525c/rsrc/css/aphront/panel-view.css',
|
'uri' => '/res/3d1420b3/rsrc/css/aphront/panel-view.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -2975,7 +2975,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'phabricator-jump-nav' =>
|
'phabricator-jump-nav' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/b33dd475/rsrc/css/application/directory/phabricator-jump-nav.css',
|
'uri' => '/res/2e0e2211/rsrc/css/application/directory/phabricator-jump-nav.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -3805,7 +3805,7 @@ celerity_register_resource_map(array(
|
||||||
), array(
|
), array(
|
||||||
'packages' =>
|
'packages' =>
|
||||||
array(
|
array(
|
||||||
'1f04085c' =>
|
'4fc2a8f9' =>
|
||||||
array(
|
array(
|
||||||
'name' => 'core.pkg.css',
|
'name' => 'core.pkg.css',
|
||||||
'symbols' =>
|
'symbols' =>
|
||||||
|
@ -3847,7 +3847,7 @@ celerity_register_resource_map(array(
|
||||||
34 => 'phabricator-object-item-list-view-css',
|
34 => 'phabricator-object-item-list-view-css',
|
||||||
35 => 'global-drag-and-drop-css',
|
35 => 'global-drag-and-drop-css',
|
||||||
),
|
),
|
||||||
'uri' => '/res/pkg/1f04085c/core.pkg.css',
|
'uri' => '/res/pkg/4fc2a8f9/core.pkg.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
),
|
),
|
||||||
'def4c982' =>
|
'def4c982' =>
|
||||||
|
@ -4038,16 +4038,16 @@ celerity_register_resource_map(array(
|
||||||
'reverse' =>
|
'reverse' =>
|
||||||
array(
|
array(
|
||||||
'aphront-attached-file-view-css' => '6b1fccc6',
|
'aphront-attached-file-view-css' => '6b1fccc6',
|
||||||
'aphront-dialog-view-css' => '1f04085c',
|
'aphront-dialog-view-css' => '4fc2a8f9',
|
||||||
'aphront-error-view-css' => '1f04085c',
|
'aphront-error-view-css' => '4fc2a8f9',
|
||||||
'aphront-form-view-css' => '1f04085c',
|
'aphront-form-view-css' => '4fc2a8f9',
|
||||||
'aphront-list-filter-view-css' => '1f04085c',
|
'aphront-list-filter-view-css' => '4fc2a8f9',
|
||||||
'aphront-pager-view-css' => '1f04085c',
|
'aphront-pager-view-css' => '4fc2a8f9',
|
||||||
'aphront-panel-view-css' => '1f04085c',
|
'aphront-panel-view-css' => '4fc2a8f9',
|
||||||
'aphront-table-view-css' => '1f04085c',
|
'aphront-table-view-css' => '4fc2a8f9',
|
||||||
'aphront-tokenizer-control-css' => '1f04085c',
|
'aphront-tokenizer-control-css' => '4fc2a8f9',
|
||||||
'aphront-tooltip-css' => '1f04085c',
|
'aphront-tooltip-css' => '4fc2a8f9',
|
||||||
'aphront-typeahead-control-css' => '1f04085c',
|
'aphront-typeahead-control-css' => '4fc2a8f9',
|
||||||
'differential-changeset-view-css' => '8aaacd1b',
|
'differential-changeset-view-css' => '8aaacd1b',
|
||||||
'differential-core-view-css' => '8aaacd1b',
|
'differential-core-view-css' => '8aaacd1b',
|
||||||
'differential-inline-comment-editor' => '67ea27d0',
|
'differential-inline-comment-editor' => '67ea27d0',
|
||||||
|
@ -4061,7 +4061,7 @@ celerity_register_resource_map(array(
|
||||||
'differential-table-of-contents-css' => '8aaacd1b',
|
'differential-table-of-contents-css' => '8aaacd1b',
|
||||||
'diffusion-commit-view-css' => 'c8ce2d88',
|
'diffusion-commit-view-css' => 'c8ce2d88',
|
||||||
'diffusion-icons-css' => 'c8ce2d88',
|
'diffusion-icons-css' => 'c8ce2d88',
|
||||||
'global-drag-and-drop-css' => '1f04085c',
|
'global-drag-and-drop-css' => '4fc2a8f9',
|
||||||
'inline-comment-summary-css' => '8aaacd1b',
|
'inline-comment-summary-css' => '8aaacd1b',
|
||||||
'javelin-aphlict' => 'def4c982',
|
'javelin-aphlict' => 'def4c982',
|
||||||
'javelin-behavior' => 'fe22443b',
|
'javelin-behavior' => 'fe22443b',
|
||||||
|
@ -4133,48 +4133,48 @@ celerity_register_resource_map(array(
|
||||||
'javelin-util' => 'fe22443b',
|
'javelin-util' => 'fe22443b',
|
||||||
'javelin-vector' => 'fe22443b',
|
'javelin-vector' => 'fe22443b',
|
||||||
'javelin-workflow' => 'fe22443b',
|
'javelin-workflow' => 'fe22443b',
|
||||||
'lightbox-attachment-css' => '1f04085c',
|
'lightbox-attachment-css' => '4fc2a8f9',
|
||||||
'maniphest-task-summary-css' => '6b1fccc6',
|
'maniphest-task-summary-css' => '6b1fccc6',
|
||||||
'maniphest-transaction-detail-css' => '6b1fccc6',
|
'maniphest-transaction-detail-css' => '6b1fccc6',
|
||||||
'phabricator-busy' => 'def4c982',
|
'phabricator-busy' => 'def4c982',
|
||||||
'phabricator-content-source-view-css' => '8aaacd1b',
|
'phabricator-content-source-view-css' => '8aaacd1b',
|
||||||
'phabricator-core-buttons-css' => '1f04085c',
|
'phabricator-core-buttons-css' => '4fc2a8f9',
|
||||||
'phabricator-core-css' => '1f04085c',
|
'phabricator-core-css' => '4fc2a8f9',
|
||||||
'phabricator-crumbs-view-css' => '1f04085c',
|
'phabricator-crumbs-view-css' => '4fc2a8f9',
|
||||||
'phabricator-directory-css' => '1f04085c',
|
'phabricator-directory-css' => '4fc2a8f9',
|
||||||
'phabricator-drag-and-drop-file-upload' => '67ea27d0',
|
'phabricator-drag-and-drop-file-upload' => '67ea27d0',
|
||||||
'phabricator-dropdown-menu' => 'def4c982',
|
'phabricator-dropdown-menu' => 'def4c982',
|
||||||
'phabricator-file-upload' => 'def4c982',
|
'phabricator-file-upload' => 'def4c982',
|
||||||
'phabricator-filetree-view-css' => '1f04085c',
|
'phabricator-filetree-view-css' => '4fc2a8f9',
|
||||||
'phabricator-flag-css' => '1f04085c',
|
'phabricator-flag-css' => '4fc2a8f9',
|
||||||
'phabricator-form-view-css' => '1f04085c',
|
'phabricator-form-view-css' => '4fc2a8f9',
|
||||||
'phabricator-header-view-css' => '1f04085c',
|
'phabricator-header-view-css' => '4fc2a8f9',
|
||||||
'phabricator-jump-nav' => '1f04085c',
|
'phabricator-jump-nav' => '4fc2a8f9',
|
||||||
'phabricator-keyboard-shortcut' => 'def4c982',
|
'phabricator-keyboard-shortcut' => 'def4c982',
|
||||||
'phabricator-keyboard-shortcut-manager' => 'def4c982',
|
'phabricator-keyboard-shortcut-manager' => 'def4c982',
|
||||||
'phabricator-main-menu-view' => '1f04085c',
|
'phabricator-main-menu-view' => '4fc2a8f9',
|
||||||
'phabricator-menu-item' => 'def4c982',
|
'phabricator-menu-item' => 'def4c982',
|
||||||
'phabricator-nav-view-css' => '1f04085c',
|
'phabricator-nav-view-css' => '4fc2a8f9',
|
||||||
'phabricator-notification' => 'def4c982',
|
'phabricator-notification' => 'def4c982',
|
||||||
'phabricator-notification-css' => '1f04085c',
|
'phabricator-notification-css' => '4fc2a8f9',
|
||||||
'phabricator-notification-menu-css' => '1f04085c',
|
'phabricator-notification-menu-css' => '4fc2a8f9',
|
||||||
'phabricator-object-item-list-view-css' => '1f04085c',
|
'phabricator-object-item-list-view-css' => '4fc2a8f9',
|
||||||
'phabricator-object-selector-css' => '8aaacd1b',
|
'phabricator-object-selector-css' => '8aaacd1b',
|
||||||
'phabricator-paste-file-upload' => 'def4c982',
|
'phabricator-paste-file-upload' => 'def4c982',
|
||||||
'phabricator-prefab' => 'def4c982',
|
'phabricator-prefab' => 'def4c982',
|
||||||
'phabricator-project-tag-css' => '6b1fccc6',
|
'phabricator-project-tag-css' => '6b1fccc6',
|
||||||
'phabricator-remarkup-css' => '1f04085c',
|
'phabricator-remarkup-css' => '4fc2a8f9',
|
||||||
'phabricator-shaped-request' => '67ea27d0',
|
'phabricator-shaped-request' => '67ea27d0',
|
||||||
'phabricator-side-menu-view-css' => '1f04085c',
|
'phabricator-side-menu-view-css' => '4fc2a8f9',
|
||||||
'phabricator-standard-page-view' => '1f04085c',
|
'phabricator-standard-page-view' => '4fc2a8f9',
|
||||||
'phabricator-textareautils' => 'def4c982',
|
'phabricator-textareautils' => 'def4c982',
|
||||||
'phabricator-tooltip' => 'def4c982',
|
'phabricator-tooltip' => 'def4c982',
|
||||||
'phabricator-transaction-view-css' => '1f04085c',
|
'phabricator-transaction-view-css' => '4fc2a8f9',
|
||||||
'phabricator-zindex-css' => '1f04085c',
|
'phabricator-zindex-css' => '4fc2a8f9',
|
||||||
'sprite-apps-large-css' => '1f04085c',
|
'sprite-apps-large-css' => '4fc2a8f9',
|
||||||
'sprite-gradient-css' => '1f04085c',
|
'sprite-gradient-css' => '4fc2a8f9',
|
||||||
'sprite-icon-css' => '1f04085c',
|
'sprite-icon-css' => '4fc2a8f9',
|
||||||
'sprite-menu-css' => '1f04085c',
|
'sprite-menu-css' => '4fc2a8f9',
|
||||||
'syntax-highlighting-css' => '1f04085c',
|
'syntax-highlighting-css' => '4fc2a8f9',
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
20
src/infrastructure/env/PhabricatorEnv.php
vendored
20
src/infrastructure/env/PhabricatorEnv.php
vendored
|
@ -54,6 +54,7 @@ final class PhabricatorEnv {
|
||||||
private static $repairSource;
|
private static $repairSource;
|
||||||
private static $overrideSource;
|
private static $overrideSource;
|
||||||
private static $requestBaseURI;
|
private static $requestBaseURI;
|
||||||
|
private static $cache;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @phutil-external-symbol class PhabricatorStartup
|
* @phutil-external-symbol class PhabricatorStartup
|
||||||
|
@ -112,6 +113,8 @@ final class PhabricatorEnv {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function buildConfigurationSourceStack() {
|
private static function buildConfigurationSourceStack() {
|
||||||
|
self::dropConfigCache();
|
||||||
|
|
||||||
$stack = new PhabricatorConfigStackSource();
|
$stack = new PhabricatorConfigStackSource();
|
||||||
self::$sourceStack = $stack;
|
self::$sourceStack = $stack;
|
||||||
|
|
||||||
|
@ -160,6 +163,7 @@ final class PhabricatorEnv {
|
||||||
self::$sourceStack->pushSource(self::$repairSource);
|
self::$sourceStack->pushSource(self::$repairSource);
|
||||||
}
|
}
|
||||||
self::$repairSource->setKeys(array($key => $value));
|
self::$repairSource->setKeys(array($key => $value));
|
||||||
|
self::dropConfigCache();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function overrideConfig($key, $value) {
|
public static function overrideConfig($key, $value) {
|
||||||
|
@ -169,6 +173,7 @@ final class PhabricatorEnv {
|
||||||
self::$sourceStack->pushSource(self::$overrideSource);
|
self::$sourceStack->pushSource(self::$overrideSource);
|
||||||
}
|
}
|
||||||
self::$overrideSource->setKeys(array($key => $value));
|
self::$overrideSource->setKeys(array($key => $value));
|
||||||
|
self::dropConfigCache();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getUnrepairedEnvConfig($key, $default = null) {
|
public static function getUnrepairedEnvConfig($key, $default = null) {
|
||||||
|
@ -220,8 +225,17 @@ final class PhabricatorEnv {
|
||||||
* @task read
|
* @task read
|
||||||
*/
|
*/
|
||||||
public static function getEnvConfig($key) {
|
public static function getEnvConfig($key) {
|
||||||
|
if (isset(self::$cache[$key])) {
|
||||||
|
return self::$cache[$key];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (array_key_exists($key, self::$cache)) {
|
||||||
|
return self::$cache[$key];
|
||||||
|
}
|
||||||
|
|
||||||
$result = self::$sourceStack->getKeys(array($key));
|
$result = self::$sourceStack->getKeys(array($key));
|
||||||
if (array_key_exists($key, $result)) {
|
if (array_key_exists($key, $result)) {
|
||||||
|
self::$cache[$key] = $result[$key];
|
||||||
return $result[$key];
|
return $result[$key];
|
||||||
} else {
|
} else {
|
||||||
throw new Exception("No config value specified for key '{$key}'.");
|
throw new Exception("No config value specified for key '{$key}'.");
|
||||||
|
@ -335,6 +349,7 @@ final class PhabricatorEnv {
|
||||||
* @task test
|
* @task test
|
||||||
*/
|
*/
|
||||||
private static function pushTestEnvironment() {
|
private static function pushTestEnvironment() {
|
||||||
|
self::dropConfigCache();
|
||||||
$source = new PhabricatorConfigDictionarySource(array());
|
$source = new PhabricatorConfigDictionarySource(array());
|
||||||
self::$sourceStack->pushSource($source);
|
self::$sourceStack->pushSource($source);
|
||||||
return spl_object_hash($source);
|
return spl_object_hash($source);
|
||||||
|
@ -345,6 +360,7 @@ final class PhabricatorEnv {
|
||||||
* @task test
|
* @task test
|
||||||
*/
|
*/
|
||||||
public static function popTestEnvironment($key) {
|
public static function popTestEnvironment($key) {
|
||||||
|
self::dropConfigCache();
|
||||||
$source = self::$sourceStack->popSource();
|
$source = self::$sourceStack->popSource();
|
||||||
$stack_key = spl_object_hash($source);
|
$stack_key = spl_object_hash($source);
|
||||||
if ($stack_key !== $key) {
|
if ($stack_key !== $key) {
|
||||||
|
@ -478,4 +494,8 @@ final class PhabricatorEnv {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function dropConfigCache() {
|
||||||
|
self::$cache = array();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue