mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-19 11:11:10 +01:00
Stop markup cache from hitting cache O(N^2) times
Summary: The intent of getOrBuildEngine() is to save some boilerplate in cases where we're just using a standard engine, but it didn't get cached so we'd rebuilt it over and over again. This was especially bad in Differential with a large number of inlines. Test Plan: "Query" tab of services is no longer quite so ridiculous in Differential. Reviewers: btrahan, dctrwatson Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D8352
This commit is contained in:
parent
7f5b15c6fa
commit
7ff2110655
2 changed files with 14 additions and 17 deletions
|
@ -903,9 +903,6 @@ final class DifferentialRevisionViewController extends DifferentialController {
|
|||
->needComments(true)
|
||||
->execute();
|
||||
|
||||
$engine = id(new PhabricatorMarkupEngine())
|
||||
->setViewer($viewer);
|
||||
|
||||
$timeline = id(new DifferentialTransactionView())
|
||||
->setUser($viewer)
|
||||
->setObjectPHID($revision->getPHID())
|
||||
|
|
|
@ -149,23 +149,23 @@ class PhabricatorApplicationTransactionView extends AphrontView {
|
|||
}
|
||||
|
||||
protected function getOrBuildEngine() {
|
||||
if ($this->engine) {
|
||||
return $this->engine;
|
||||
}
|
||||
if (!$this->engine) {
|
||||
$field = PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT;
|
||||
|
||||
$field = PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT;
|
||||
|
||||
$engine = id(new PhabricatorMarkupEngine())
|
||||
->setViewer($this->getUser());
|
||||
foreach ($this->transactions as $xaction) {
|
||||
if (!$xaction->hasComment()) {
|
||||
continue;
|
||||
$engine = id(new PhabricatorMarkupEngine())
|
||||
->setViewer($this->getUser());
|
||||
foreach ($this->transactions as $xaction) {
|
||||
if (!$xaction->hasComment()) {
|
||||
continue;
|
||||
}
|
||||
$engine->addObject($xaction->getComment(), $field);
|
||||
}
|
||||
$engine->addObject($xaction->getComment(), $field);
|
||||
}
|
||||
$engine->process();
|
||||
$engine->process();
|
||||
|
||||
return $engine;
|
||||
$this->engine = $engine;
|
||||
}
|
||||
|
||||
return $this->engine;
|
||||
}
|
||||
|
||||
private function buildChangeDetailsLink(
|
||||
|
|
Loading…
Reference in a new issue