sintonia/library/phing/tasks/ext/phpdoc/PhpDocumentorTask.php

486 lines
13 KiB
PHP

<?php
/**
* $Id: PhpDocumentorTask.php 905 2010-10-05 16:28:03Z mrook $
*
* 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: PhpDocumentorTask.php 905 2010-10-05 16:28:03Z mrook $
* @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 = '';
/**
* @var string files to ignore
*/
protected $ignore = '';
/**
* 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->setLinksource($b);
}
/**
* Set whether to generate sourcecode for each file parsed
* @param boolean
*/
public function setLinksource($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;
}
/**
* Set files to ignore
* @param string $sIgnore
*/
public function setIgnore($sIgnore) {
$this->ignore = $sIgnore;
}
/**
* 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);
}
if ($this->ignore) {
$phpdoc->setIgnore($this->ignore);
}
// 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->getName();
}
}
$phpdoc->setRicFiles($ricFiles);
if ($this->undocumentedelements) {
$phpdoc->setUndocumentedelements($this->undocumentedelements);
}
if ($this->customtags) {
$phpdoc->setCustomtags($this->customtags);
}
}
}