1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 14:51:06 +01:00

Add a ref cache and index construction to Diviner

Summary: Cache refs in a single large index; rebuild the main index from them.

Test Plan: {F32334}

Reviewers: btrahan, vrana, chad

Reviewed By: chad

CC: aran

Maniphest Tasks: T988

Differential Revision: https://secure.phabricator.com/D4900
This commit is contained in:
epriestley 2013-02-17 15:40:11 -08:00
parent c7e12c6a85
commit a5fb482a00
6 changed files with 157 additions and 5 deletions

View file

@ -284,11 +284,17 @@ final class DivinerAtom {
} }
public function getRef() { public function getRef() {
$group = null;
if ($this->docblockMeta) {
$group = $this->getDocblockMetaValue('group');
}
return id(new DivinerAtomRef()) return id(new DivinerAtomRef())
->setBook($this->getBook()) ->setBook($this->getBook())
->setContext($this->getContext()) ->setContext($this->getContext())
->setType($this->getType()) ->setType($this->getType())
->setName($this->getName()); ->setName($this->getName())
->setGroup($group);
} }
public static function newFromDictionary(array $dictionary) { public static function newFromDictionary(array $dictionary) {

View file

@ -6,6 +6,39 @@ final class DivinerAtomRef {
private $context; private $context;
private $type; private $type;
private $name; private $name;
private $group;
private $summary;
private $index;
public function getSortKey() {
return implode(
"\0",
array(
$this->getName(),
$this->getType(),
$this->getContext(),
$this->getBook(),
$this->getIndex(),
));
}
public function setIndex($index) {
$this->index = $index;
return $this;
}
public function getIndex() {
return $this->index;
}
public function setSummary($summary) {
$this->summary = $summary;
return $this;
}
public function getSummary() {
return $this->summary;
}
public function setName($name) { public function setName($name) {
$normal_name = self::normalizeString($name); $normal_name = self::normalizeString($name);
@ -53,17 +86,34 @@ final class DivinerAtomRef {
return $this->book; return $this->book;
} }
public function setGroup($group) {
$this->group = $group;
return $this;
}
public function getGroup() {
return $this->group;
}
public function toDictionary() { public function toDictionary() {
return array( return array(
'book' => $this->getBook(), 'book' => $this->getBook(),
'context' => $this->getContext(), 'context' => $this->getContext(),
'type' => $this->getType(), 'type' => $this->getType(),
'name' => $this->getName(), 'name' => $this->getName(),
'group' => $this->getGroup(),
'index' => $this->getIndex(),
'summary' => $this->getSummary(),
); );
} }
public function toHash() { public function toHash() {
$dict = $this->toDictionary(); $dict = $this->toDictionary();
unset($dict['group']);
unset($dict['index']);
unset($dict['summary']);
ksort($dict); ksort($dict);
return md5(serialize($dict)).'S'; return md5(serialize($dict)).'S';
} }
@ -74,6 +124,9 @@ final class DivinerAtomRef {
$obj->context = idx($dict, 'context'); $obj->context = idx($dict, 'context');
$obj->type = idx($dict, 'type'); $obj->type = idx($dict, 'type');
$obj->name = idx($dict, 'name'); $obj->name = idx($dict, 'name');
$obj->group = idx($dict, 'group');
$obj->index = idx($dict, 'index');
$obj->summary = idx($dict, 'summary');
return $obj; return $obj;
} }

View file

@ -3,6 +3,7 @@
final class DivinerPublishCache extends DivinerDiskCache { final class DivinerPublishCache extends DivinerDiskCache {
private $pathMap; private $pathMap;
private $index;
public function __construct($cache_directory) { public function __construct($cache_directory) {
return parent::__construct($cache_directory, 'diviner-publish-cache'); return parent::__construct($cache_directory, 'diviner-publish-cache');
@ -42,4 +43,31 @@ final class DivinerPublishCache extends DivinerDiskCache {
} }
/* -( Index )-------------------------------------------------------------- */
public function getIndex() {
if ($this->index === null) {
$this->index = $this->getCache()->getKey('index', array());
}
return $this->index;
}
public function writeIndex() {
$this->getCache()->setKey('index', $this->getIndex());
}
public function deleteAtomFromIndex($hash) {
$index = $this->getIndex();
unset($index[$hash]);
$this->index = $index;
return $this;
}
public function addAtomToIndex($hash, array $data) {
$index = $this->getIndex();
$index[$hash] = $data;
$this->index = $index;
return $this;
}
} }

View file

@ -53,14 +53,15 @@ final class DivinerStaticPublisher extends DivinerPublisher {
$cache->removeAtomPathsFromCache($hash); $cache->removeAtomPathsFromCache($hash);
$cache->deleteRenderCache($hash); $cache->deleteRenderCache($hash);
$cache->deleteAtomFromIndex($hash);
} }
$cache->writePathMap();
} }
protected function createDocumentsByHash(array $hashes) { protected function createDocumentsByHash(array $hashes) {
$indexes = array(); $indexes = array();
$cache = $this->getPublishCache();
foreach ($hashes as $hash) { foreach ($hashes as $hash) {
$atom = $this->getAtomFromGraphHash($hash); $atom = $this->getAtomFromGraphHash($hash);
@ -76,12 +77,50 @@ final class DivinerStaticPublisher extends DivinerPublisher {
$indexes[$index] = $atom; $indexes[$index] = $atom;
$paths[] = $index; $paths[] = $index;
} }
$this->addAtomToIndex($hash, $atom);
} }
$this->getPublishCache()->addAtomPathsToCache($hash, $paths); $cache->addAtomPathsToCache($hash, $paths);
} }
$this->getPublishCache()->writePathMap(); foreach ($indexes as $index => $atoms) {
// TODO: Publish disambiguation pages.
}
$this->publishIndex();
$cache->writePathMap();
$cache->writeIndex();
}
private function publishIndex() {
$index = $this->getPublishCache()->getIndex();
$refs = array();
foreach ($index as $hash => $dictionary) {
$refs[$hash] = DivinerAtomRef::newFromDictionary($dictionary);
}
$content = $this->getRenderer()->renderAtomIndex($refs);
$path = implode(
DIRECTORY_SEPARATOR,
array(
$this->getConfig('root'),
'docs',
$this->getConfig('name'),
'index.html',
));
Filesystem::writeFile($path, $content);
}
private function addAtomToIndex($hash, DivinerAtom $atom) {
$ref = $atom->getRef();
$ref->setIndex($this->getAtomSimilarIndex($atom));
$ref->setSummary($this->getRenderer()->renderAtomSummary($atom));
$this->getPublishCache()->addAtomToIndex($hash, $ref->toDictionary());
} }
private function writeDocument(DivinerAtom $atom, $content) { private function writeDocument(DivinerAtom $atom, $content) {

View file

@ -6,4 +6,28 @@ final class DivinerDefaultRenderer extends DivinerRenderer {
return "ATOM: ".$atom->getType()." ".$atom->getName()."!"; return "ATOM: ".$atom->getType()." ".$atom->getName()."!";
} }
public function renderAtomSummary(DivinerAtom $atom) {
return "A lovely atom named ".$atom->getName();
}
public function renderAtomIndex(array $refs) {
$refs = msort($refs, 'getSortKey');
$groups = mgroup($refs, 'getGroup');
$out = array();
foreach ($groups as $group_key => $refs) {
$out[] = '<h1>'.$group_key.'</h1>';
$out[] = '<ul>';
foreach ($refs as $ref) {
$out[] = '<li>'.$ref->getName().' - '.$ref->getSummary().'</li>';
}
$out[] = '</ul>';
}
$out = implode("\n", $out);
return $out;
}
} }

View file

@ -3,5 +3,7 @@
abstract class DivinerRenderer { abstract class DivinerRenderer {
abstract public function renderAtom(DivinerAtom $atom); abstract public function renderAtom(DivinerAtom $atom);
abstract public function renderAtomSummary(DivinerAtom $atom);
abstract public function renderAtomIndex(array $refs);
} }