mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 02:10:59 +01:00
Clean up some more Diviner stuff
Summary: Ref T988. - Render "Implements:" as tags, too. - Minor CSS tweak to tags in property lists. - Add a bunch of group patterns to the Phabricator book. - Fix some stuff with how hashes are computed and cached. - Minor tweak to reuse the Diviner engine for slightly improved performance. Test Plan: Regenerated and looked at documentation. Reviewers: chad Reviewed By: chad CC: aran Maniphest Tasks: T3811, T988 Differential Revision: https://secure.phabricator.com/D6912
This commit is contained in:
parent
f1dc56a687
commit
194245ed62
9 changed files with 349 additions and 63 deletions
|
@ -1149,7 +1149,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'diviner-shared-css' =>
|
'diviner-shared-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/4237d999/rsrc/css/diviner/diviner-shared.css',
|
'uri' => '/res/bcc425bb/rsrc/css/diviner/diviner-shared.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -3385,7 +3385,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'phabricator-property-list-view-css' =>
|
'phabricator-property-list-view-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/145d1f9a/rsrc/css/layout/phabricator-property-list-view.css',
|
'uri' => '/res/fdcbf4ab/rsrc/css/layout/phabricator-property-list-view.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -4171,7 +4171,7 @@ celerity_register_resource_map(array(
|
||||||
), array(
|
), array(
|
||||||
'packages' =>
|
'packages' =>
|
||||||
array(
|
array(
|
||||||
'471e18ad' =>
|
'3806f0da' =>
|
||||||
array(
|
array(
|
||||||
'name' => 'core.pkg.css',
|
'name' => 'core.pkg.css',
|
||||||
'symbols' =>
|
'symbols' =>
|
||||||
|
@ -4218,7 +4218,7 @@ celerity_register_resource_map(array(
|
||||||
39 => 'phabricator-property-list-view-css',
|
39 => 'phabricator-property-list-view-css',
|
||||||
40 => 'phabricator-tag-view-css',
|
40 => 'phabricator-tag-view-css',
|
||||||
),
|
),
|
||||||
'uri' => '/res/pkg/471e18ad/core.pkg.css',
|
'uri' => '/res/pkg/3806f0da/core.pkg.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
),
|
),
|
||||||
'8977e356' =>
|
'8977e356' =>
|
||||||
|
@ -4409,15 +4409,15 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'reverse' =>
|
'reverse' =>
|
||||||
array(
|
array(
|
||||||
'aphront-dialog-view-css' => '471e18ad',
|
'aphront-dialog-view-css' => '3806f0da',
|
||||||
'aphront-error-view-css' => '471e18ad',
|
'aphront-error-view-css' => '3806f0da',
|
||||||
'aphront-list-filter-view-css' => '471e18ad',
|
'aphront-list-filter-view-css' => '3806f0da',
|
||||||
'aphront-pager-view-css' => '471e18ad',
|
'aphront-pager-view-css' => '3806f0da',
|
||||||
'aphront-panel-view-css' => '471e18ad',
|
'aphront-panel-view-css' => '3806f0da',
|
||||||
'aphront-table-view-css' => '471e18ad',
|
'aphront-table-view-css' => '3806f0da',
|
||||||
'aphront-tokenizer-control-css' => '471e18ad',
|
'aphront-tokenizer-control-css' => '3806f0da',
|
||||||
'aphront-tooltip-css' => '471e18ad',
|
'aphront-tooltip-css' => '3806f0da',
|
||||||
'aphront-typeahead-control-css' => '471e18ad',
|
'aphront-typeahead-control-css' => '3806f0da',
|
||||||
'differential-changeset-view-css' => '44bfe40c',
|
'differential-changeset-view-css' => '44bfe40c',
|
||||||
'differential-core-view-css' => '44bfe40c',
|
'differential-core-view-css' => '44bfe40c',
|
||||||
'differential-inline-comment-editor' => 'd07a3bc2',
|
'differential-inline-comment-editor' => 'd07a3bc2',
|
||||||
|
@ -4431,7 +4431,7 @@ celerity_register_resource_map(array(
|
||||||
'differential-table-of-contents-css' => '44bfe40c',
|
'differential-table-of-contents-css' => '44bfe40c',
|
||||||
'diffusion-commit-view-css' => 'c8ce2d88',
|
'diffusion-commit-view-css' => 'c8ce2d88',
|
||||||
'diffusion-icons-css' => 'c8ce2d88',
|
'diffusion-icons-css' => 'c8ce2d88',
|
||||||
'global-drag-and-drop-css' => '471e18ad',
|
'global-drag-and-drop-css' => '3806f0da',
|
||||||
'inline-comment-summary-css' => '44bfe40c',
|
'inline-comment-summary-css' => '44bfe40c',
|
||||||
'javelin-aphlict' => '8977e356',
|
'javelin-aphlict' => '8977e356',
|
||||||
'javelin-behavior' => '2dbbb7d1',
|
'javelin-behavior' => '2dbbb7d1',
|
||||||
|
@ -4504,55 +4504,55 @@ celerity_register_resource_map(array(
|
||||||
'javelin-util' => '2dbbb7d1',
|
'javelin-util' => '2dbbb7d1',
|
||||||
'javelin-vector' => '2dbbb7d1',
|
'javelin-vector' => '2dbbb7d1',
|
||||||
'javelin-workflow' => '2dbbb7d1',
|
'javelin-workflow' => '2dbbb7d1',
|
||||||
'lightbox-attachment-css' => '471e18ad',
|
'lightbox-attachment-css' => '3806f0da',
|
||||||
'maniphest-task-summary-css' => '0a9e494f',
|
'maniphest-task-summary-css' => '0a9e494f',
|
||||||
'maniphest-transaction-detail-css' => '0a9e494f',
|
'maniphest-transaction-detail-css' => '0a9e494f',
|
||||||
'phabricator-action-list-view-css' => '471e18ad',
|
'phabricator-action-list-view-css' => '3806f0da',
|
||||||
'phabricator-application-launch-view-css' => '471e18ad',
|
'phabricator-application-launch-view-css' => '3806f0da',
|
||||||
'phabricator-busy' => '8977e356',
|
'phabricator-busy' => '8977e356',
|
||||||
'phabricator-content-source-view-css' => '44bfe40c',
|
'phabricator-content-source-view-css' => '44bfe40c',
|
||||||
'phabricator-core-css' => '471e18ad',
|
'phabricator-core-css' => '3806f0da',
|
||||||
'phabricator-crumbs-view-css' => '471e18ad',
|
'phabricator-crumbs-view-css' => '3806f0da',
|
||||||
'phabricator-drag-and-drop-file-upload' => 'd07a3bc2',
|
'phabricator-drag-and-drop-file-upload' => 'd07a3bc2',
|
||||||
'phabricator-dropdown-menu' => '8977e356',
|
'phabricator-dropdown-menu' => '8977e356',
|
||||||
'phabricator-file-upload' => '8977e356',
|
'phabricator-file-upload' => '8977e356',
|
||||||
'phabricator-filetree-view-css' => '471e18ad',
|
'phabricator-filetree-view-css' => '3806f0da',
|
||||||
'phabricator-flag-css' => '471e18ad',
|
'phabricator-flag-css' => '3806f0da',
|
||||||
'phabricator-header-view-css' => '471e18ad',
|
'phabricator-header-view-css' => '3806f0da',
|
||||||
'phabricator-hovercard' => '8977e356',
|
'phabricator-hovercard' => '8977e356',
|
||||||
'phabricator-jump-nav' => '471e18ad',
|
'phabricator-jump-nav' => '3806f0da',
|
||||||
'phabricator-keyboard-shortcut' => '8977e356',
|
'phabricator-keyboard-shortcut' => '8977e356',
|
||||||
'phabricator-keyboard-shortcut-manager' => '8977e356',
|
'phabricator-keyboard-shortcut-manager' => '8977e356',
|
||||||
'phabricator-main-menu-view' => '471e18ad',
|
'phabricator-main-menu-view' => '3806f0da',
|
||||||
'phabricator-menu-item' => '8977e356',
|
'phabricator-menu-item' => '8977e356',
|
||||||
'phabricator-nav-view-css' => '471e18ad',
|
'phabricator-nav-view-css' => '3806f0da',
|
||||||
'phabricator-notification' => '8977e356',
|
'phabricator-notification' => '8977e356',
|
||||||
'phabricator-notification-css' => '471e18ad',
|
'phabricator-notification-css' => '3806f0da',
|
||||||
'phabricator-notification-menu-css' => '471e18ad',
|
'phabricator-notification-menu-css' => '3806f0da',
|
||||||
'phabricator-object-item-list-view-css' => '471e18ad',
|
'phabricator-object-item-list-view-css' => '3806f0da',
|
||||||
'phabricator-object-selector-css' => '44bfe40c',
|
'phabricator-object-selector-css' => '44bfe40c',
|
||||||
'phabricator-phtize' => '8977e356',
|
'phabricator-phtize' => '8977e356',
|
||||||
'phabricator-prefab' => '8977e356',
|
'phabricator-prefab' => '8977e356',
|
||||||
'phabricator-project-tag-css' => '0a9e494f',
|
'phabricator-project-tag-css' => '0a9e494f',
|
||||||
'phabricator-property-list-view-css' => '471e18ad',
|
'phabricator-property-list-view-css' => '3806f0da',
|
||||||
'phabricator-remarkup-css' => '471e18ad',
|
'phabricator-remarkup-css' => '3806f0da',
|
||||||
'phabricator-shaped-request' => 'd07a3bc2',
|
'phabricator-shaped-request' => 'd07a3bc2',
|
||||||
'phabricator-side-menu-view-css' => '471e18ad',
|
'phabricator-side-menu-view-css' => '3806f0da',
|
||||||
'phabricator-standard-page-view' => '471e18ad',
|
'phabricator-standard-page-view' => '3806f0da',
|
||||||
'phabricator-tag-view-css' => '471e18ad',
|
'phabricator-tag-view-css' => '3806f0da',
|
||||||
'phabricator-textareautils' => '8977e356',
|
'phabricator-textareautils' => '8977e356',
|
||||||
'phabricator-tooltip' => '8977e356',
|
'phabricator-tooltip' => '8977e356',
|
||||||
'phabricator-transaction-view-css' => '471e18ad',
|
'phabricator-transaction-view-css' => '3806f0da',
|
||||||
'phabricator-zindex-css' => '471e18ad',
|
'phabricator-zindex-css' => '3806f0da',
|
||||||
'phui-button-css' => '471e18ad',
|
'phui-button-css' => '3806f0da',
|
||||||
'phui-form-css' => '471e18ad',
|
'phui-form-css' => '3806f0da',
|
||||||
'phui-form-view-css' => '471e18ad',
|
'phui-form-view-css' => '3806f0da',
|
||||||
'phui-icon-view-css' => '471e18ad',
|
'phui-icon-view-css' => '3806f0da',
|
||||||
'phui-spacing-css' => '471e18ad',
|
'phui-spacing-css' => '3806f0da',
|
||||||
'sprite-apps-large-css' => '471e18ad',
|
'sprite-apps-large-css' => '3806f0da',
|
||||||
'sprite-gradient-css' => '471e18ad',
|
'sprite-gradient-css' => '3806f0da',
|
||||||
'sprite-icons-css' => '471e18ad',
|
'sprite-icons-css' => '3806f0da',
|
||||||
'sprite-menu-css' => '471e18ad',
|
'sprite-menu-css' => '3806f0da',
|
||||||
'syntax-highlighting-css' => '471e18ad',
|
'syntax-highlighting-css' => '3806f0da',
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
|
@ -21,7 +21,9 @@ final class DivinerAtom {
|
||||||
private $docblockText;
|
private $docblockText;
|
||||||
private $docblockMeta;
|
private $docblockMeta;
|
||||||
private $warnings = array();
|
private $warnings = array();
|
||||||
|
private $parent;
|
||||||
private $parentHash;
|
private $parentHash;
|
||||||
|
private $children = array();
|
||||||
private $childHashes = array();
|
private $childHashes = array();
|
||||||
private $context;
|
private $context;
|
||||||
private $extends = array();
|
private $extends = array();
|
||||||
|
@ -209,7 +211,8 @@ final class DivinerAtom {
|
||||||
mpull($this->links, 'toHash'),
|
mpull($this->links, 'toHash'),
|
||||||
);
|
);
|
||||||
|
|
||||||
return md5(serialize($parts)).'N';
|
$this->hash = md5(serialize($parts)).'N';
|
||||||
|
return $this->hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setLength($length) {
|
public function setLength($length) {
|
||||||
|
@ -236,6 +239,9 @@ final class DivinerAtom {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getChildHashes() {
|
public function getChildHashes() {
|
||||||
|
if (!$this->childHashes && $this->children) {
|
||||||
|
$this->childHashes = mpull($this->children, 'getHash');
|
||||||
|
}
|
||||||
return $this->childHashes;
|
return $this->childHashes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -247,13 +253,32 @@ final class DivinerAtom {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function hasParent() {
|
||||||
|
return $this->parent || $this->parentHash;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setParent(DivinerAtom $atom) {
|
||||||
|
if ($this->parentHash) {
|
||||||
|
throw new Exception("Parent hash has already been computed!");
|
||||||
|
}
|
||||||
|
$this->parent = $atom;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getParentHash() {
|
public function getParentHash() {
|
||||||
|
if ($this->parent && !$this->parentHash) {
|
||||||
|
$this->parentHash = $this->parent->getHash();
|
||||||
|
}
|
||||||
return $this->parentHash;
|
return $this->parentHash;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addChild(DivinerAtom $atom) {
|
public function addChild(DivinerAtom $atom) {
|
||||||
$atom->setParentHash($this->getHash());
|
if ($this->childHashes) {
|
||||||
$this->addChildHash($atom->getHash());
|
throw new Exception("Child hashes have already been computed!");
|
||||||
|
}
|
||||||
|
|
||||||
|
$atom->setParent($this);
|
||||||
|
$this->children[] = $atom;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,8 @@ final class DivinerAtomController extends DivinerController {
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
$viewer = $request->getUser();
|
$viewer = $request->getUser();
|
||||||
|
|
||||||
|
require_celerity_resource('diviner-shared-css');
|
||||||
|
|
||||||
$book = id(new DivinerBookQuery())
|
$book = id(new DivinerBookQuery())
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
->withNames(array($this->bookName))
|
->withNames(array($this->bookName))
|
||||||
|
@ -260,10 +262,7 @@ final class DivinerAtomController extends DivinerController {
|
||||||
if ($lineage) {
|
if ($lineage) {
|
||||||
$tags = array();
|
$tags = array();
|
||||||
foreach ($lineage as $item) {
|
foreach ($lineage as $item) {
|
||||||
$tags[] = id(new PhabricatorTagView())
|
$tags[] = $this->renderAtomTag($item);
|
||||||
->setType(PhabricatorTagView::TYPE_OBJECT)
|
|
||||||
->setName($item->getName())
|
|
||||||
->setHref($item->getURI());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$tags = phutil_implode_html(" \xE2\x96\xB6 ", $tags);
|
$tags = phutil_implode_html(" \xE2\x96\xB6 ", $tags);
|
||||||
|
@ -277,9 +276,12 @@ final class DivinerAtomController extends DivinerController {
|
||||||
$via = $spec['via'];
|
$via = $spec['via'];
|
||||||
$iface = $spec['interface'];
|
$iface = $spec['interface'];
|
||||||
if ($via == $symbol) {
|
if ($via == $symbol) {
|
||||||
$items[] = $iface->getName();
|
$items[] = $this->renderAtomTag($iface);
|
||||||
} else {
|
} else {
|
||||||
$items[] = $iface->getName().' (via '.$via->getName().')';
|
$items[] = array(
|
||||||
|
$this->renderAtomTag($iface),
|
||||||
|
" \xE2\x97\x80 ",
|
||||||
|
$this->renderAtomTag($via));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -290,6 +292,13 @@ final class DivinerAtomController extends DivinerController {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function renderAtomTag(DivinerLiveSymbol $symbol) {
|
||||||
|
return id(new PhabricatorTagView())
|
||||||
|
->setType(PhabricatorTagView::TYPE_OBJECT)
|
||||||
|
->setName($symbol->getName())
|
||||||
|
->setHref($symbol->getURI());
|
||||||
|
}
|
||||||
|
|
||||||
private function getExtendsLineage(DivinerLiveSymbol $symbol) {
|
private function getExtendsLineage(DivinerLiveSymbol $symbol) {
|
||||||
foreach ($symbol->getExtends() as $extends) {
|
foreach ($symbol->getExtends() as $extends) {
|
||||||
if ($extends->getType() == 'class') {
|
if ($extends->getType() == 'class') {
|
||||||
|
@ -521,7 +530,7 @@ final class DivinerAtomController extends DivinerController {
|
||||||
if ($parameters !== null) {
|
if ($parameters !== null) {
|
||||||
$pout = array();
|
$pout = array();
|
||||||
foreach ($parameters as $parameter) {
|
foreach ($parameters as $parameter) {
|
||||||
$pout[] = $parameter['name'];
|
$pout[] = idx($parameter, 'name', '...');
|
||||||
}
|
}
|
||||||
$out = array($out, '('.implode(', ', $pout).')');
|
$out = array($out, '('.implode(', ', $pout).')');
|
||||||
}
|
}
|
||||||
|
|
|
@ -153,13 +153,7 @@ final class DivinerLiveSymbol extends DivinerDAO
|
||||||
|
|
||||||
|
|
||||||
public function newMarkupEngine($field) {
|
public function newMarkupEngine($field) {
|
||||||
$engine = PhabricatorMarkupEngine::newMarkupEngine(array());
|
return PhabricatorMarkupEngine::getEngine('diviner');
|
||||||
|
|
||||||
$engine->setConfig('preserve-linebreaks', false);
|
|
||||||
// $engine->setConfig('diviner.renderer', new DivinerDefaultRenderer());
|
|
||||||
$engine->setConfig('header.generate-toc', true);
|
|
||||||
|
|
||||||
return $engine;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -105,7 +105,7 @@ final class DivinerAtomizeWorkflow extends DivinerWorkflow {
|
||||||
$atoms = $atomizer->atomize($file, $data, $context);
|
$atoms = $atomizer->atomize($file, $data, $context);
|
||||||
|
|
||||||
foreach ($atoms as $atom) {
|
foreach ($atoms as $atom) {
|
||||||
if (!$atom->getParentHash()) {
|
if (!$atom->hasParent()) {
|
||||||
$file_atom->addChild($atom);
|
$file_atom->addChild($atom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,15 +11,260 @@
|
||||||
},
|
},
|
||||||
"exclude" : [
|
"exclude" : [
|
||||||
"(^externals/)",
|
"(^externals/)",
|
||||||
|
"(^webroot/rsrc/externals/)",
|
||||||
"(^scripts/)",
|
"(^scripts/)",
|
||||||
"(^support/)",
|
"(^support/)",
|
||||||
"(^resources/)",
|
"(^resources/)",
|
||||||
"(^src/docs/user/)"
|
"(^src/docs/user/)"
|
||||||
],
|
],
|
||||||
"groups" : {
|
"groups" : {
|
||||||
|
"arcanist" : {
|
||||||
|
"name" : "Arcanist Integration",
|
||||||
|
"include" : "(^src/applications/arcanist/)"
|
||||||
|
},
|
||||||
|
"audit" : {
|
||||||
|
"name" : "Audit",
|
||||||
|
"include" : "(^src/applications/audit/)"
|
||||||
|
},
|
||||||
|
"auth" : {
|
||||||
|
"name" : "Auth",
|
||||||
|
"include" : "(^src/applications/auth/)"
|
||||||
|
},
|
||||||
|
"baseapp" : {
|
||||||
|
"name" : "Application Basics",
|
||||||
|
"include" : "(^src/applications/base/)"
|
||||||
|
},
|
||||||
|
"cache" : {
|
||||||
|
"name" : "Cache",
|
||||||
|
"include" : "(^src/applications/cache/)"
|
||||||
|
},
|
||||||
|
"calendar" : {
|
||||||
|
"name" : "Calendar",
|
||||||
|
"include" : "(^src/applications/calendar/)"
|
||||||
|
},
|
||||||
|
"chatlog" : {
|
||||||
|
"name" : "Chatlog",
|
||||||
|
"include" : "(^src/applications/chatlog/)"
|
||||||
|
},
|
||||||
|
"conduit" : {
|
||||||
|
"name" : "Conduit",
|
||||||
|
"include" : "(^src/applications/conduit/)"
|
||||||
|
},
|
||||||
|
"config" : {
|
||||||
|
"name" : "Config",
|
||||||
|
"include" : "(^src/applications/config/)"
|
||||||
|
},
|
||||||
|
"conpherence" : {
|
||||||
|
"name" : "Conpherence",
|
||||||
|
"include" : "(^src/applications/conpherence/)"
|
||||||
|
},
|
||||||
|
"countdown" : {
|
||||||
|
"name" : "Countdown",
|
||||||
|
"include" : "(^src/applications/countdown/)"
|
||||||
|
},
|
||||||
|
"daemon" : {
|
||||||
|
"name" : "Daemons",
|
||||||
|
"include" : "(^src/applications/daemon/)"
|
||||||
|
},
|
||||||
|
"differential" : {
|
||||||
|
"name" : "Differential",
|
||||||
|
"include" : "(^src/applications/differential/)"
|
||||||
|
},
|
||||||
|
"diffusion" : {
|
||||||
|
"name" : "Diffusion",
|
||||||
|
"include" : "(^src/applications/diffusion/)"
|
||||||
|
},
|
||||||
|
"directory" : {
|
||||||
|
"name" : "Directory",
|
||||||
|
"include" : "(^src/applications/directory/)"
|
||||||
|
},
|
||||||
|
"diviner" : {
|
||||||
|
"name" : "Diviner",
|
||||||
|
"include" : "(^src/applications/diviner/)"
|
||||||
|
},
|
||||||
|
"doorkeeper" : {
|
||||||
|
"name" : "Doorkeeper",
|
||||||
|
"include" : "(^src/applications/doorkeeper/)"
|
||||||
|
},
|
||||||
|
"draft" : {
|
||||||
|
"name" : "Draft",
|
||||||
|
"include" : "(^src/applications/draft/)"
|
||||||
|
},
|
||||||
|
"drydock" : {
|
||||||
|
"name" : "Drydock",
|
||||||
|
"include" : "(^src/applications/drydock/)"
|
||||||
|
},
|
||||||
|
"fact" : {
|
||||||
|
"name" : "Fact",
|
||||||
|
"include" : "(^src/applications/fact/)"
|
||||||
|
},
|
||||||
|
"feed" : {
|
||||||
|
"name" : "Feed",
|
||||||
|
"include" : "(^src/applications/feed/)"
|
||||||
|
},
|
||||||
|
"files" : {
|
||||||
|
"name" : "Files",
|
||||||
|
"include" : "(^src/applications/files/)"
|
||||||
|
},
|
||||||
|
"flag" : {
|
||||||
|
"name" : "Flags",
|
||||||
|
"include" : "(^src/applications/flag/)"
|
||||||
|
},
|
||||||
|
"harbormaster" : {
|
||||||
|
"name" : "Harbormaster",
|
||||||
|
"include" : "(^src/applications/harbormaster/)"
|
||||||
|
},
|
||||||
|
"help" : {
|
||||||
|
"name" : "Help",
|
||||||
|
"include" : "(^src/applications/help/)"
|
||||||
|
},
|
||||||
|
"herald" : {
|
||||||
|
"name" : "Herald",
|
||||||
|
"include" : "(^src/applications/herald/)"
|
||||||
|
},
|
||||||
|
"legalpad" : {
|
||||||
|
"name" : "Legalpad",
|
||||||
|
"include" : "(^src/applications/legalpad/)"
|
||||||
|
},
|
||||||
|
"lipsum" : {
|
||||||
|
"name" : "Lipsum",
|
||||||
|
"include" : "(^src/applications/lipsum/)"
|
||||||
|
},
|
||||||
|
"macro" : {
|
||||||
|
"name" : "Macro",
|
||||||
|
"include" : "(^src/applications/macro/)"
|
||||||
|
},
|
||||||
|
"mailinglists" : {
|
||||||
|
"name" : "Mailing Lists",
|
||||||
|
"include" : "(^src/applications/mailinglists/)"
|
||||||
|
},
|
||||||
|
"maniphest" : {
|
||||||
|
"name" : "Maniphest",
|
||||||
|
"include" : "(^src/applications/maniphest/)"
|
||||||
|
},
|
||||||
|
"meta" : {
|
||||||
|
"name" : "Meta",
|
||||||
|
"include" : "(^src/applications/meta/)"
|
||||||
|
},
|
||||||
|
"metamta" : {
|
||||||
|
"name" : "MetaMTA",
|
||||||
|
"include" : "(^src/applications/metamta/)"
|
||||||
|
},
|
||||||
|
"notification" : {
|
||||||
|
"name" : "Notifications",
|
||||||
|
"include" : "(^src/applications/notification/)"
|
||||||
|
},
|
||||||
|
"oauthserver" : {
|
||||||
|
"name" : "OAuth Server",
|
||||||
|
"include" : "(^src/applications/oauthserver/)"
|
||||||
|
},
|
||||||
|
"owners" : {
|
||||||
|
"name" : "Owners",
|
||||||
|
"include" : "(^src/applications/owners/)"
|
||||||
|
},
|
||||||
"paste" : {
|
"paste" : {
|
||||||
"name" : "Paste",
|
"name" : "Paste",
|
||||||
"include" : "(^src/applications/paste/)"
|
"include" : "(^src/applications/paste/)"
|
||||||
|
},
|
||||||
|
"people" : {
|
||||||
|
"name" : "People",
|
||||||
|
"include" : "(^src/applications/people/)"
|
||||||
|
},
|
||||||
|
"phame" : {
|
||||||
|
"name" : "Phame",
|
||||||
|
"include" : "(^src/applications/phame/)"
|
||||||
|
},
|
||||||
|
"phid" : {
|
||||||
|
"name" : "PHIDs",
|
||||||
|
"include" : "(^src/applications/phid/)"
|
||||||
|
},
|
||||||
|
"phlux" : {
|
||||||
|
"name" : "Phlux",
|
||||||
|
"include" : "(^src/applications/phlux/)"
|
||||||
|
},
|
||||||
|
"pholio" : {
|
||||||
|
"name" : "Pholio",
|
||||||
|
"include" : "(^src/applications/pholio/)"
|
||||||
|
},
|
||||||
|
"phortune" : {
|
||||||
|
"name" : "Phortune",
|
||||||
|
"include" : "(^src/applications/phortune/)"
|
||||||
|
},
|
||||||
|
"phpast" : {
|
||||||
|
"name" : "PHPAST",
|
||||||
|
"include" : "(^src/applications/phpast/)"
|
||||||
|
},
|
||||||
|
"phrequent" : {
|
||||||
|
"name" : "Phrequent",
|
||||||
|
"include" : "(^src/applications/phrequent/)"
|
||||||
|
},
|
||||||
|
"phriction" : {
|
||||||
|
"name" : "Phriction",
|
||||||
|
"include" : "(^src/applications/phriction/)"
|
||||||
|
},
|
||||||
|
"policy" : {
|
||||||
|
"name" : "Policy",
|
||||||
|
"include" : "(^src/applications/policy/)"
|
||||||
|
},
|
||||||
|
"ponder" : {
|
||||||
|
"name" : "Ponder",
|
||||||
|
"include" : "(^src/applications/ponder/)"
|
||||||
|
},
|
||||||
|
"project" : {
|
||||||
|
"name" : "Projects",
|
||||||
|
"include" : "(^src/applications/project/)"
|
||||||
|
},
|
||||||
|
"releeph" : {
|
||||||
|
"name" : "Releeph",
|
||||||
|
"include" : "(^src/applications/releeph/)"
|
||||||
|
},
|
||||||
|
"remarkup" : {
|
||||||
|
"name" : "Remarkup",
|
||||||
|
"include" : "(^src/applications/remarkup/)"
|
||||||
|
},
|
||||||
|
"repository" : {
|
||||||
|
"name" : "Repositories",
|
||||||
|
"include" : "(^src/applications/repository/)"
|
||||||
|
},
|
||||||
|
"search" : {
|
||||||
|
"name" : "Search",
|
||||||
|
"include" : "(^src/applications/search/)"
|
||||||
|
},
|
||||||
|
"settings" : {
|
||||||
|
"name" : "Settings",
|
||||||
|
"include" : "(^src/applications/settings/)"
|
||||||
|
},
|
||||||
|
"slowvote" : {
|
||||||
|
"name" : "Slowvote",
|
||||||
|
"include" : "(^src/applications/slowvote/)"
|
||||||
|
},
|
||||||
|
"subscriptions" : {
|
||||||
|
"name" : "Subscriptions",
|
||||||
|
"include" : "(^src/applications/subscriptions/)"
|
||||||
|
},
|
||||||
|
"system" : {
|
||||||
|
"name" : "System",
|
||||||
|
"include" : "(^src/applications/system/)"
|
||||||
|
},
|
||||||
|
"tokens" : {
|
||||||
|
"name" : "Tokens",
|
||||||
|
"include" : "(^src/applications/tokens/)"
|
||||||
|
},
|
||||||
|
"transactions" : {
|
||||||
|
"name" : "Transactions",
|
||||||
|
"include" : "(^src/applications/transactions/)"
|
||||||
|
},
|
||||||
|
"typeahead" : {
|
||||||
|
"name" : "Typeahead",
|
||||||
|
"include" : "(^src/applications/typeahead/)"
|
||||||
|
},
|
||||||
|
"uiexample" : {
|
||||||
|
"name" : "UI Examples",
|
||||||
|
"include" : "(^src/applications/uiexample/)"
|
||||||
|
},
|
||||||
|
"xhprof" : {
|
||||||
|
"name" : "XHProf",
|
||||||
|
"include" : "(^src/applications/xhprof/)"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -359,6 +359,12 @@ final class PhabricatorMarkupEngine {
|
||||||
case 'default':
|
case 'default':
|
||||||
$engine = self::newMarkupEngine(array());
|
$engine = self::newMarkupEngine(array());
|
||||||
break;
|
break;
|
||||||
|
case 'diviner':
|
||||||
|
$engine = self::newMarkupEngine(array());
|
||||||
|
$engine->setConfig('preserve-linebreaks', false);
|
||||||
|
// $engine->setConfig('diviner.renderer', new DivinerDefaultRenderer());
|
||||||
|
$engine->setConfig('header.generate-toc', true);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Exception("Unknown engine ruleset: {$ruleset}!");
|
throw new Exception("Unknown engine ruleset: {$ruleset}!");
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,3 +107,4 @@
|
||||||
.diviner-document-section .phabricator-header-shell + .phabricator-remarkup {
|
.diviner-document-section .phabricator-header-shell + .phabricator-remarkup {
|
||||||
padding-top: 0;
|
padding-top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -114,3 +114,9 @@
|
||||||
margin: auto;
|
margin: auto;
|
||||||
max-width: 95%;
|
max-width: 95%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* When tags appear in property lists, give them a little more vertical
|
||||||
|
spacing. */
|
||||||
|
.phabricator-property-list-view .phabricator-tag-view {
|
||||||
|
margin: 2px 0;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue