Allow DivinerPublisher to be specified as a flag
				
					
				
			Summary: Allow the `DivinerPublisher` subclass to be specified via `./bin/divner generate --publisher ...`. In particular, this allows use of the (mostly broken) `DivinerStaticPublisher`. Test Plan: Ran `./bin/diviner generate --publisher DivinerStaticPublisher` Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: Korvin, epriestley Differential Revision: https://secure.phabricator.com/D11588
This commit is contained in:
		| @@ -42,6 +42,7 @@ abstract class DivinerPublisher { | ||||
|     $this->atomCache = $cache; | ||||
|     $graph_map = $this->atomCache->getGraphMap(); | ||||
|     $this->atomGraphHashToNodeHashMap = array_flip($graph_map); | ||||
|     return $this; | ||||
|   } | ||||
|  | ||||
|   protected function getAtomFromGraphHash($graph_hash) { | ||||
|   | ||||
| @@ -19,6 +19,12 @@ final class DivinerGenerateWorkflow extends DivinerWorkflow { | ||||
|             'param' => 'path', | ||||
|             'help' => pht('Path to a Diviner book configuration.'), | ||||
|           ), | ||||
|           array( | ||||
|             'name' => 'publisher', | ||||
|             'param' => 'class', | ||||
|             'help' => pht('Specify a subclass of %s.', 'DivinerPublisher'), | ||||
|             'default' => 'DivinerLivePublisher', | ||||
|           ), | ||||
|         )); | ||||
|   } | ||||
|  | ||||
| @@ -164,7 +170,22 @@ final class DivinerGenerateWorkflow extends DivinerWorkflow { | ||||
|     $this->buildAtomCache(); | ||||
|     $this->buildGraphCache(); | ||||
|  | ||||
|     $this->publishDocumentation($args->getArg('clean')); | ||||
|     $publisher_class = $args->getArg('publisher'); | ||||
|     $symbols = id(new PhutilSymbolLoader()) | ||||
|       ->setName($publisher_class) | ||||
|       ->setConcreteOnly(true) | ||||
|       ->setAncestorClass('DivinerPublisher') | ||||
|       ->selectAndLoadSymbols(); | ||||
|     if (!$symbols) { | ||||
|       throw new Exception( | ||||
|         pht( | ||||
|           "Publisher class '%s' must be a concrete subclass of %s.", | ||||
|           $publisher_class, | ||||
|           'DivinerPublisher')); | ||||
|     } | ||||
|     $publisher = newv($publisher_class, array()); | ||||
|  | ||||
|     $this->publishDocumentation($args->getArg('clean'), $publisher); | ||||
|   } | ||||
|  | ||||
| /* -(  Atom Cache  )--------------------------------------------------------- */ | ||||
| @@ -497,18 +518,18 @@ final class DivinerGenerateWorkflow extends DivinerWorkflow { | ||||
|     return md5(serialize($inputs)).'G'; | ||||
|   } | ||||
|  | ||||
|   private function publishDocumentation($clean) { | ||||
|   private function publishDocumentation($clean, DivinerPublisher $publisher) { | ||||
|     $atom_cache = $this->getAtomCache(); | ||||
|     $graph_map = $atom_cache->getGraphMap(); | ||||
|  | ||||
|     $this->log(pht('PUBLISHING DOCUMENTATION')); | ||||
|  | ||||
|     $publisher = new DivinerLivePublisher(); | ||||
|     $publisher->setDropCaches($clean); | ||||
|     $publisher->setConfig($this->getAllConfig()); | ||||
|     $publisher->setAtomCache($atom_cache); | ||||
|     $publisher->setRenderer(new DivinerDefaultRenderer()); | ||||
|     $publisher->publishAtoms(array_values($graph_map)); | ||||
|     $publisher | ||||
|       ->setDropCaches($clean) | ||||
|       ->setConfig($this->getAllConfig()) | ||||
|       ->setAtomCache($atom_cache) | ||||
|       ->setRenderer(new DivinerDefaultRenderer()) | ||||
|       ->publishAtoms(array_values($graph_map)); | ||||
|  | ||||
|     $this->log(pht('Done.')); | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Joshua Spence
					Joshua Spence