Source for file phpdoc.php
Documentation is available at phpdoc.php
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
* Web Interface to phpDocumentor
* @deprecated in favor of docbuilder (see {@link docbuilder/config.php})
// An HTML interface for Joshua Eichorn's phpDocumentor
// phpDocumentor, a program for creating javadoc style documentation from php code
// Copyright (C) 2000-2002 Joshua Eichorn
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
// Copyleft 2001 Juan Pablo Morales
// set up include path so we can find all files, no matter what
// add my directory to the include path, and make it first, should fix any errors
if (substr(PHP_OS, 0, 3) == 'WIN')
ini_set('include_path',$GLOBALS['_phpDocumentor_install_dir']. ';'. ini_get('include_path'));
ini_set('include_path',$GLOBALS['_phpDocumentor_install_dir']. ':'. ini_get('include_path'));
* common file information
include_once("phpDocumentor/common.inc.php");
print "phpDocumentor requires PHP version 4.1.0 or greater to function";
// find the .ini directory by parsing phpDocumentor.ini and extracting _phpDocumentor_options[userdir]
if (isset ($ini['_phpDocumentor_options']['userdir']))
$configdir = $ini['_phpDocumentor_options']['userdir'];
$configdir = $_phpDocumentor_install_dir . '/user';
// allow the user to change this at runtime
if (!empty($_REQUEST['altuserdir'])) $configdir = $_REQUEST['altuserdir'];
<?php if(!isset ($_GET['submit']) || !empty($_REQUEST['altuserdir'])) {
<script type="text/javascript" language="Javascript">
Creates some global variables
function initializate() {
//The "platform independent" newLine
//Taken from http://developer.netscape.com/docs/manuals/communicator/jsref/brow1.htm#1010426
if (navigator.appVersion.lastIndexOf('Win') != -1)
/* for($a=0;$a<document.dataForm.elements.length;$a++) {
alert("The name is '"+document.dataForm.elements[$a].name+"' "+$a);
/**Adds the contents of the help box as a directory
function addDirectory($object) {
$object.value = prepareString($object.value)+document.helpForm.fileName.value;
/**Adds the contents of the converter box to the converters list
function addConverter($object) {
$object.value = prepareString($object.value)+document.dataForm.ConverterSetting.value;
/**Adds the contents of the help box as a file to the given control
function addFile($object) {
$object.value = prepareString($object.value)+document.helpForm.fileName.value;
/**Takes a given string and leaves it ready to add a new string
That is, puts the comma and the new line if needed
function prepareString($myString) {
//First verify that a comma is not at the end
if($myString.lastIndexOf(",") >= $myString.length-2) {
//We have a comma at the end
if($myString.length > 0) {
/**Do the validation needed before sending the from and return a truth value indicating if the form can be sent
//Take out all newLines and change them by nothing
//This could be done by using javascript function's replacebut that was implemented only until Navigator 4.0 and so it is better to use more backward compatible functions like substr
document.dataForm.elements[0].value= stripNewLines(document.dataForm.elements[0].value);
document.dataForm.elements[1].value= stripNewLines(document.dataForm.elements[1].value);
document.dataForm.elements[2].value= stripNewLines(document.dataForm.elements[2].value);
document.dataForm.elements[3].value= stripNewLines(document.dataForm.elements[3].value);
document.dataForm.elements[4].value= stripNewLines(document.dataForm.elements[4].value);
document.dataForm.elements[5].value= stripNewLines(document.dataForm.elements[5].value);
document.dataForm.elements[6].value= stripNewLines(document.dataForm.elements[6].value);
document.dataForm.elements[7].value= stripNewLines(document.dataForm.elements[7].value);
//By returning true we are allowing the form to be submitted
/**Takes a string and removes all the ocurrences of new lines
Could have been implemented a lot easier with replace but it's not very backwards compatible
function stripNewLines($myString) {
return myReplace($myString,$newLine,'');
function myReplace($string,$text,$by) {
// Replaces text with by in string
var $strLength = $string.length, $txtLength = $text.length;
if (($strLength == 0) || ($txtLength == 0)) return $string;
var $i = $string.indexOf($text);
if ((!$i) && ($text != $string.substring(0,$txtLength))) return $string;
if ($i == -1) return $string;
var $newstr = $string.substring(0,$i) + $by;
if ($i+$txtLength < $strLength)
$newstr += myReplace($string.substring($i+$txtLength,$strLength),$text,$by);
//Find out if we are submitting and if we are, send it
// This code originally by Joshua Eichorn on phpdoc.php
if(isset ($_GET['submit']) && empty($_REQUEST['altuserdir'])) {
echo "<body bgcolor=\"#ffffff\">";
echo "<h1>Parsing Files ...</h1>";
include("phpDocumentor/phpdoc.inc");
echo "<h1>Operation Completed!!</h1>";
<body bgcolor="#ffffff" onload="javascript:initializate()">
<form name="dataForm" action="phpdoc.php" method="GET" onsubmit=
<table cellpadding="0" cellspacing="0" border="0" width="80%"
<table cellpadding="0" cellspacing="1" border="0" width=
<b>Use a pre-created config file for form values.</b>
Normally, phpDocumentor uses the form values from this form to set up parsing. In version 1.2,
phpDocumentor allows you to "save" form values in configuration files so that you can replicate
common complicated documentation tasks with only one time. Just choose a config file below or create a
new one and refresh this page to choose it.<hr /><b>change config directory:</b><input size="20" type="text" name="altuserdir" value=""> <?php if (!empty($_REQUEST['altuserdir'])) print '<br><i>changed to <b>"'. $_REQUEST['altuserdir']. '"</b></i>'; ?>
<b>Choose a config:</b> <select name="setting[useconfig]">
<option value="" <?php if (empty($_REQUEST['altuserdir'])) print 'selected'; ?>>don't use config file</option>
if (!empty($_REQUEST['altuserdir'])) $path = $configdir . PATH_DELIMITER;
foreach($dirs as $configfile)
print '<option value="'. $path. $configfile. '"'. $sel. '>'. $configfile. ".ini</option>\n";
</select><input type="SUBMIT" value=
"Go" name="submitButton"><br>
<b>Generated Documentation Title</b>
Choose a title for the generated documentation<br>
<input type="TEXT" name="setting[title]" size=
"80" value="Generated Documentation"><br>
<b>Default Package Name</b>
Choose a name for the default package<br>
<input type="TEXT" name="setting[defaultpackagename]" size=
"80" value="default"><br>
Target is the directory where
the output produced by phpDocumentor will reside<br>
<input type="TEXT" name="setting[target]" size=
"javascript:addDirectory(document.dataForm.elements[5])">
Add the directory in the help box</a>
Custom Tags is a comma-separated list of tags
you want phpDocumentor to include as valid tags
in this parse. An example would be "value, size"
to allow @value and @size tags.
<input type="TEXT" name="setting[customtags]" size=
The parameter packages is a group of comma
separated names of abstract packages that will
be processed by phpDocumentor. All package names must be
<textarea rows="3" cols="80" name=
"setting[packageoutput]"></textarea> <br>
This is a group of comma-separated names of php files
or tutorials that will be processed by phpDocumentor.<br>
<textarea rows="6" cols="80" name=
"setting[filename]"></textarea> <br>
"javascript:addFile(document.dataForm.elements[8])">
Add the file in the help box</a>
<b>Directory to parse</b>
This is a group of comma-separated directories where php files
or tutorials are found that will be processed by phpDocumentor.
phpDocumentor automatically parses subdirectories<br>
<textarea rows="6" cols="80" name="setting[directory]"></textarea> <br>
"javascript:addDirectory(document.dataForm.elements[9])">
Add the directory in the help box</a>
<b>Output Information</b>
Output Information is a comma-separated list of <b>Outputformat:Converter:Templates</b>
to apply to the output. The Converters must be classes descended from Converter
defined in the phpDocumentor files, or parsing will not work. Outputformat
may be HTML, XML, PDF, or CHM (case-sensitive) in version 1.2. There is only one Converter
for both CHM and PDF, <b>default</b>. There are 2 HTML Converters,
<b>frames</b> and <b>Smarty</b>. <b>frames templates</b> may be any of:<br><br>
<b>default, l0l33t, phpdoc.de, phphtmllib, phpedit, DOM/default, DOM/l0l33t, or DOM/phpdoc.de</b>.
<b>Smarty templates</b> may be any of:<br><br>
There is only 1 template for all other Converters, <b>default</b>
<br>Output type:Converter name:template name <input type=
"TEXT" name="setting[output]" value=
"HTML:Smarty:default" size="80"><br>
<select name="ConverterSetting">
<option value="HTML:frames:default">HTML:frames:default</option>
<option value="HTML:frames:l0l33t">HTML:frames:l0l33t</option>
<option value="HTML:frames:phpdoc.de">HTML:frames:phpdoc.de</option>
<option value="HTML:frames:phphtmllib">HTML:frames:phphtmllib</option>
<option value="HTML:frames:phpedit">HTML:frames:phpedit</option>
<option value="HTML:frames:DOM/default">HTML:frames:DOM/default</option>
<option value="HTML:frames:DOM/l0l33t">HTML:frames:DOM/l0l33t</option>
<option value="HTML:frames:DOM/phpdoc.de">HTML:frames:DOM/phpdoc.de</option>
<option value="HTML:Smarty:default" SELECTED>HTML:Smarty:default</option>
<option value="HTML:Smarty:PHP">HTML:Smarty:PHP</option>
<option value="PDF:default:default">PDF:default:default</option>
<option value="CHM:default:default">CHM:default:default</option>
<option value="XML:DocBook/peardoc2:default">XML:DocBook/peardoc2:default</option>
"javascript:addConverter(document.dataForm.elements[10])">
Add the converter in the help box</a>
A list of files (full path or filename), and patterns
to ignore. Patterns may use wildcards * and ?. To
ignore all subdirectories named "test" for example,
using "test/" To ignore all files and directories
with test in their name use "*test*"
<textarea rows="6" cols="80" name="setting[ignore]"></textarea> <br>
"javascript:addDirectory(document.dataForm.elements[12])">
Add the directory in the help box</a>
<b>Parse @access private</b>
The parameter Parse @access private tells phpDocumentor
whether to parse elements with an "@access private" tag in their docblock<br>
<input type="checkbox" name="setting[parseprivate]" value="on">Parse private <br>
<b>JavaDoc-compliant Description parsing.</b>
Normally, phpDocumentor uses several rules to determine the short description. This switch
asks phpDocumentor to simply search for the first period (.) and use it to delineate the short
description. In addition, the short description will not be separated from the long description<br>
<input type="checkbox" name="setting[javadocdesc]" value="on">JavaDoc-compliant Description <br>
<input type="HIDDEN" name="interface" value="web"> <input type=
"HIDDEN" name="submit" value="true"> <input type="SUBMIT" value=
"Send Form" name="submitButton">
<table cellpadding="0" cellspacing="0" border="0" width="80%" bgcolor=
<table cellpadding="0" cellspacing="1" border="0" width=
Since remember long path is not that easy here is a
little file control to view names of files that can
the be aggregated to the different properties
<form name="helpForm" action="" method="get"
enctype="multipart/form-data">
<input size="80" type="file" name="fileName">
<b>Web-Interface Author:</b>
If you have any problems with phpDocumentor, please visit the website: <a
href='http://phpdocu.sourceforge.net'>phpdocu.sourceforge.net</a> and
<!-- Created: Tue Jun 26 18:52:40 MEST 2001 -->
Last modified: $Date: 2005/10/17 18:15:16 $
Revision: $Revision: 1.1 $
<?php } //End the else that prints all code
|