/lib/vendor/symfony/lib/plugins/sfPropelPlugin/lib/vendor/phing/tasks/ext/phpdoc/PhpDocumentorTask.php
PHP | 460 lines | 197 code | 65 blank | 198 comment | 24 complexity | bc92b0ecd002b9cf55f4d7e7b200ab0e MD5 | raw file
- <?php
- /**
- * $Id: PHPDocumentorTask.php 144 2007-02-05 15:19:00Z hans $
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- * This software consists of voluntary contributions made by many individuals
- * and is licensed under the LGPL. For more information please see
- * <http://phing.info>.
- */
- require_once 'phing/Task.php';
- /**
- * Task to run PhpDocumentor.
- *
- * @author Hans Lellelid <hans@xmpl.org>
- * @author Michiel Rook <michiel.rook@gmail.com>
- * @version $Id$
- * @package phing.tasks.ext.phpdoc
- */
- class PhpDocumentorTask extends Task
- {
-
- /**
- * @var string Title for browser window / package index.
- */
- protected $title;
-
- /**
- * @var PhingFile The target directory for output files.
- */
- protected $destdir;
- /**
- * @var array FileSet[] Filesets for files to parse.
- */
- protected $filesets = array();
-
- /**
- * @var array FileSet[] Project documentation (README/INSTALL/CHANGELOG) files.
- */
- protected $projDocFilesets = array();
-
- /**
- * @var string Package output format.
- */
- protected $output;
- /**
- * @var boolean Whether to generate sourcecode for each file parsed.
- */
- protected $linksource = false;
-
- /**
- * @var boolean Whether to parse private members.
- */
- protected $parsePrivate = false;
-
- /**
- * @var boolean Whether to use javadoc descriptions (more primitive).
- */
- protected $javadocDesc = false;
-
- /**
- * @var PhingFile Base directory for locating template files.
- */
- protected $templateBase;
-
- /**
- * @var boolean Wheter to suppress output.
- */
- protected $quiet = false;
-
- /**
- * @var string Comma-separated list of packages to output.
- */
- protected $packages;
-
- /**
- * @var string Comma-separated list of tags to ignore.
- */
- protected $ignoreTags;
-
- /**
- * @var string Default package name.
- */
- protected $defaultPackageName;
-
- /**
- * @var string Default category name.
- */
- protected $defaultCategoryName;
-
- /**
- * @var PhingFile Directory in which to look for examples.
- */
- protected $examplesDir;
-
- /**
- * @var PhingFile Directory in which to look for configuration files.
- */
- protected $configDir;
-
- /**
- * @var boolean Whether to parse as a PEAR repository.
- */
- protected $pear = false;
- /**
- * @var boolean Control whether or not warnings will be shown for
- * undocumented elements. Useful for identifying classes and
- * methods that haven't yet been documented.
- */
- protected $undocumentedelements = false;
- /**
- * @var string custom tags, will be recognized and put in tags[] instead of
- * unknowntags[].
- */
- protected $customtags = '';
-
- /**
- * Set the title for the generated documentation
- */
- public function setTitle($title) {
- $this->title = $title;
- }
- /**
- * Set the destination directory for the generated documentation
- */
- public function setDestdir(PhingFile $destdir) {
- $this->destdir = $destdir;
- }
-
- /**
- * Alias for {@link setDestdir()).
- * @see setDestdir()
- */
- public function setTarget(PhingFile $destdir) {
- $this->setDestdir($destdir);
- }
- /**
- * Set the output format (e.g. HTML:Smarty:PHP).
- * @param string $output
- */
- public function setOutput($output) {
- $this->output = $output;
- }
- /**
- * Set whether to generate sourcecode for each file parsed
- * @param boolean
- */
- public function setSourcecode($b) {
- $this->linksource = $b;
- }
-
- /**
- * Set whether to suppress output.
- * @param boolean $b
- */
- public function setQuiet($b) {
- $this->quiet = $b;
- }
-
- /**
- * Should private members/classes be documented
- * @param boolean
- */
- public function setParseprivate($parseprivate) {
- $this->parsePrivate = $parseprivate;
- }
-
- /**
- * Whether to use javadoc descriptions (more primitive).
- * @param boolean
- */
- public function setJavadocdesc($javadoc) {
- $this->javadocDesc = $javadoc;
- }
-
- /**
- * Set (comma-separated) list of packages to output.
- *
- * @param string $packages
- */
- public function setPackageoutput($packages) {
- $this->packages = $packages;
- }
-
- /**
- * Set (comma-separated) list of tags to ignore.
- *
- * @param string $tags
- */
- public function setIgnoretags($tags) {
- $this->ignoreTags = $tags;
- }
-
- /**
- * Set a directory to search for examples in.
- * @param PhingFile $d
- */
- public function setExamplesdir(PhingFile $d) {
- $this->examplesDir = $d;
- }
-
- /**
- * Set a directory to search for configuration files in.
- * @param PhingFile $d
- */
- public function setConfigdir(PhingFile $d) {
- $this->configDir = $d;
- }
-
- /**
- * Sets the default package name.
- * @param string $name
- */
- public function setDefaultpackagename($name) {
- $this->defaultPackageName = $name;
- }
-
- /**
- * Sets the default category name.
- * @param string $name
- */
- public function setDefaultcategoryname($name) {
- $this->defaultCategoryName = $name;
- }
-
- /**
- * Set whether to parse as PEAR repository.
- * @param boolean $b
- */
- public function setPear($b) {
- $this->pear = $b;
- }
-
- /**
- * Creates a FileSet.
- * @return FileSet
- */
- public function createFileset() {
- $num = array_push($this->filesets, new FileSet());
- return $this->filesets[$num-1];
- }
-
- /**
- * Creates a readme/install/changelog fileset.
- * @return FileSet
- */
- public function createProjdocfileset() {
- $num = array_push($this->projDocFilesets, new FileSet());
- return $this->projDocFilesets[$num-1];
- }
-
- /**
- * Control whether or not warnings will be shown for undocumented elements.
- * Useful for identifying classes and methods that haven't yet been
- * documented.
- * @param boolean $b
- */
- public function setUndocumentedelements($b) {
- $this->undocumentedelements = $b;
- }
- /**
- * custom tags, will be recognized and put in tags[] instead of
- * unknowntags[].
- *
- * @param string $sCustomtags
- */
- public function setCustomtags($sCustomtags) {
- $this->customtags = $sCustomtags;
- }
- /**
- * Set base location of all templates for this parse.
- *
- * @param PhingFile $destdir
- */
- public function setTemplateBase(PhingFile $oTemplateBase) {
- $this->templateBase = $oTemplateBase;
- }
- /**
- * Searches include_path for PhpDocumentor install and adjusts include_path appropriately.
- * @throws BuildException - if unable to find PhpDocumentor on include_path
- */
- protected function findPhpDocumentorInstall()
- {
- $found = null;
- foreach(explode(PATH_SEPARATOR, get_include_path()) as $path) {
- $testpath = $path . DIRECTORY_SEPARATOR . 'PhpDocumentor';
- if (file_exists($testpath)) {
- $found = $testpath;
- break;
- }
- }
- if (!$found) {
- throw new BuildException("PhpDocumentor task depends on PhpDocumentor being installed and on include_path.", $this->getLocation());
- }
- // otherwise, adjust the include_path to path to include the PhpDocumentor directory ...
- set_include_path(get_include_path() . PATH_SEPARATOR . $found);
- include_once ("phpDocumentor/Setup.inc.php");
- if (!class_exists('phpDocumentor_setup')) {
- throw new BuildException("Error including PhpDocumentor setup class file.");
- }
- }
-
- /**
- * Load the necessary environment for running PhpDoc.
- *
- * @throws BuildException - if the phpdoc classes can't be loaded.
- */
- public function init()
- {
- $this->findPhpDocumentorInstall();
- include_once 'phing/tasks/ext/phpdoc/PhingPhpDocumentorSetup.php';
- }
-
- /**
- * Main entrypoint of the task
- */
- function main()
- {
- $this->validate();
- $configdir = $this->configDir ? $this->configDir->getAbsolutePath() : null;
- $phpdoc = new PhingPhpDocumentorSetup($configdir);
- $this->setPhpDocumentorOptions($phpdoc);
- //$phpdoc->readCommandLineSettings();
- $phpdoc->setupConverters($this->output);
- $phpdoc->createDocs();
- }
-
- /**
- * Validates that necessary minimum options have been set.
- * @throws BuildException if validation doesn't pass
- */
- protected function validate()
- {
- if (!$this->destdir) {
- throw new BuildException("You must specify a destdir for phpdoc.", $this->getLocation());
- }
- if (!$this->output) {
- throw new BuildException("You must specify an output format for phpdoc (e.g. HTML:frames:default).", $this->getLocation());
- }
- if (empty($this->filesets)) {
- throw new BuildException("You have not specified any files to include (<fileset>) for phpdoc.", $this->getLocation());
- }
- }
-
- /**
- * Sets the options on the passed-in phpdoc setup object.
- * @param PhingPhpDocumentorSetup $phpdoc
- */
- protected function setPhpDocumentorOptions(PhingPhpDocumentorSetup $phpdoc)
- {
-
- // Title MUST be set first ... (because it re-initializes the internal state of the PhpDocu renderer)
- if ($this->title) {
- $phpdoc->setTitle($this->title);
- }
-
- if ($this->parsePrivate) {
- $phpdoc->setParsePrivate();
- }
-
- if ($this->javadocDesc) {
- $phpdoc->setJavadocDesc();
- }
-
- if ($this->quiet) {
- $phpdoc->setQuietMode();
- }
-
- if ($this->destdir) {
- $phpdoc->setTargetDir($this->destdir->getAbsolutePath());
- }
-
- if ($this->packages) {
- $phpdoc->setPackageOutput($this->packages);
- }
-
- if ($this->templateBase) {
- $phpdoc->setTemplateBase($this->templateBase->getAbsolutePath());
- }
-
- if ($this->linksource) {
- $phpdoc->setGenerateSourcecode($this->linksource);
- }
-
- if ($this->examplesDir) {
- $phpdoc->setExamplesDir($this->examplesDir->getAbsolutePath());
- }
-
- if ($this->ignoreTags) {
- $phpdoc->setIgnoreTags($this->ignoreTags);
- }
-
- if ($this->defaultPackageName) {
- $phpdoc->setDefaultPackageName($this->defaultPackageName);
- }
-
- if ($this->defaultCategoryName) {
- $phpdoc->setDefaultCategoryName($this->defaultCategoryName);
- }
-
- if ($this->pear) {
- $phpdoc->setPear($this->pear);
- }
-
- // append any files in filesets
- $filesToParse = array();
- foreach($this->filesets as $fs) {
- $files = $fs->getDirectoryScanner($this->project)->getIncludedFiles();
- foreach($files as $filename) {
- $f = new PhingFile($fs->getDir($this->project), $filename);
- $filesToParse[] = $f->getAbsolutePath();
- }
- }
- //print_r(implode(",", $filesToParse));
- $phpdoc->setFilesToParse(implode(",", $filesToParse));
-
-
- // append any files in filesets
- $ricFiles = array();
- foreach($this->projDocFilesets as $fs) {
- $files = $fs->getDirectoryScanner($this->project)->getIncludedFiles();
- foreach($files as $filename) {
- $f = new PhingFile($fs->getDir($this->project), $filename);
- $ricFiles[] = $f->getAbsolutePath();
- }
- }
- $phpdoc->setRicFiles($ricFiles);
- if ($this->undocumentedelements) {
- $phpdoc->setUndocumentedelements($this->undocumentedelements);
- }
- if ($this->customtags) {
- $phpdoc->setCustomtags($this->customtags);
- }
- }
- }