PHP Document 代碼注釋規范
PHPDocumentor是一個用PHP寫的工具,對于有規范注釋的php程序,它能夠快速生成具有相互參照,索引等功能的API文檔。老的版本是 phpdoc。
1. 什么是phpDocumentor ?PHPDocumentor是一個用PHP寫的工具,對于有規范注釋的php程序,它能夠快速生成具有相互參照,索引等功能的API文檔。老的版本是 phpdoc,從1.3.0開始,更名為phpDocumentor,新的版本加上了對php5語法的支持,同時,可以通過在客戶端瀏覽器上操作生成文檔,文檔可以轉換為PDF,HTML,CHM幾種形式,非常的方便。PHPDocumentor工作時,會掃描指定目錄下面的php源代碼,掃描其中的關鍵字,截取需要分析的注釋,然后分析注釋中的專用的tag,生成 xml文件,接著根據已經分析完的類和模塊的信息,建立相應的索引,生成xml文件,對于生成的xml文件,使用定制的模板輸出為指定格式的文件。2. 安裝phpDocumentor和其他pear下的模塊一樣,phpDocumentor的安裝也分為自動安裝和手動安裝兩種方式,兩種方式都非常方便:a. 通過pear 自動安裝在命令行下輸入pear install PhpDocumentorb. 手動安裝在http://manual.phpdoc.org/下載最新版本的PhpDocumentor(現在是1.4.0),把內容解壓即可。3.怎樣使用PhpDocumentor生成文檔命令行方式:在phpDocumentor所在目錄下,輸入Php –h會得到一個詳細的參數表,其中幾個重要的參數如下:-f 要進行分析的文件名,多個文件用逗號隔開-d 要分析的目錄,多個目錄用逗號分割-t 生成的文檔的存放路徑-o 輸出的文檔格式,結構為輸出格式:轉換器名:模板目錄。例如:phpdoc -o HTML:frames:earthli -f test.php -t docsWeb界面生成在新的phpdoc中,除了在命令行下生成文檔外,還可以在客戶端瀏覽器上操作生成文檔,具體方法是先把PhpDocumentor的內容放在apache目錄下使得通過瀏覽器可以訪問到,訪問后顯示如下的界面:點擊files按鈕,選擇要處理的php文件或文件夾,還可以通過該指定該界面下的Files to ignore來忽略對某些文件的處理。然后點擊output按鈕來選擇生成文檔的存放路徑和格式.最后點擊create,phpdocumentor就會自動開始生成文檔了,最下方會顯示生成的進度及狀態,如果成功,會顯示Total Documentation Time: 1 secondsdoneOperation Completed!!然后,我們就可以通過查看生成的文檔了,如果是pdf格式的,名字默認為documentation.pdf。4.給php代碼添加規范的注釋PHPDocument是從你的源代碼的注釋中生成文檔,因此在給你的程序做注釋的過程,也就是你編制文檔的過程。從這一點上講,PHPdoc促使你要養成良好的編程習慣,盡量使用規范,清晰文字為你的程序做注釋,同時多多少少也避免了事后編制文檔和文檔的更新不同步的一些問題。在phpdocumentor中,注釋分為文檔性注釋和非文檔性注釋。所謂文檔性注釋,是那些放在特定關鍵字前面的多行注釋,特定關鍵字是指能夠被phpdoc分析的關鍵字,例如class,var等,具體的可參加附錄1.那些沒有在關鍵字前面或者不規范的注釋就稱作非文檔性注釋,這些注釋將不會被phpdoc所分析,也不會出現在你產生的api文當中。3.2如何書寫文檔性注釋:所有的文檔性注釋都是由/**開始的一個多行注釋,在phpDocumentor里稱為DocBlock, DocBlock是指軟件開發人員編寫的關于某個關鍵字的幫助信息,使得其他人能夠通過它知道這個關鍵字的具體用途,如何使用。 PhpDocumentor規定一個DocBlock包含如下信息:1. 功能簡述區2. 詳細說明區3. 標記tag文檔性注釋的第一行是功能描述區,正文一般是簡明扼要地說明這個類,方法或者函數的功能,功能簡述的正文在生成的文檔中將顯示在索引區。功能描述區的內容可以通過一個空行或者 . 來結束在功能描述區后是一個空行,接著是詳細說明區,. 這部分主要是詳細說明你的API的功能,用途,如果可能,也可以有用法舉例等等。在這部分,你應該著重闡明你的API函數或者方法的通常的用途,用法,并且指明是否是跨平臺的(如果涉及到),對于和平臺相關的信息,你要和那些通用的信息區別對待,通常的做法是另起一行,然后寫出在某個特定平臺上的注意事項或者是特別的信息,這些信息應該足夠,以便你的讀者能夠編寫相應的測試信息,比如邊界條件,參數范圍,斷點等等。之后同樣是一個空白行,然后是文檔的標記tag,指明一些技術上的信息,主要是最主要的是調用參數類型,返回值極其類型,繼承關系,相關方法/函數等等。關于文檔標記,詳細的請參考第四節:文檔標記。文檔注釋中還可以使用例如<b> <code>這樣的標簽,詳細介紹請參考附錄二。下面是一個文檔注釋的例子
/*** 函數add,實現兩個數的加法** 一個簡單的加法計算,函數接受兩個數a、b,返回他們的和c** @param int 加數* @param int 被加數* @return integer*/function Add($a, $b) {return $a+$b;}
生成文檔如下:Addinteger Add( int $a, int $b)[line 45]函數add,實現兩個數的加法Constants 一個簡單的加法計算,函數接受兩個數a、b,返回他們的和cParameters• int $a - 加數• int $b - 被加數5.文檔標記:文檔標記的使用范圍是指該標記可以用來修飾的關鍵字,或其他文檔標記。所有的文檔標記都是在每一行的 * 后面以@開頭。如果在一段話的中間出來@的標記,這個標記將會被當做普通內容而被忽略掉。@access使用范圍:class,function,var,define,module該標記用于指明關鍵字的存取權限:private、public或proteced@author指明作者@copyright使用范圍:class,function,var,define,module,use指明版權信息@deprecated使用范圍:class,function,var,define,module,constent,global,include指明不用或者廢棄的關鍵字@example該標記用于解析一段文件內容,并將他們高亮顯示。Phpdoc會試圖從該標記給的文件路徑中讀取文件內容@const使用范圍:define用來指明php中define的常量@final使用范圍:class,function,var指明關鍵字是一個最終的類、方法、屬性,禁止派生、修改。@filesource和example類似,只不過該標記將直接讀取當前解析的php文件的內容并顯示。@global指明在此函數中引用的全局變量@ingore用于在文檔中忽略指定的關鍵字@license相當于html標簽中的<a>,首先是URL,接著是要顯示的內容例如<a href=”http://www.baidu.com”>百度</a>可以寫作 @license http://www.baidu.com 百度@link類似于license但還可以通過link指到文檔中的任何一個關鍵字@name為關鍵字指定一個別名。@package使用范圍:頁面級別的-> define,function,include類級別的->class,var,methods用于邏輯上將一個或幾個關鍵字分到一組。@abstrcut說明當前類是一個抽象類@param指明一個函數的參數@return指明一個方法或函數的返回指@static指明關建字是靜態的。@var指明變量類型@version指明版本信息@todo指明應該改進或沒有實現的地方@throws指明此函數可能拋出的錯誤異常,極其發生的情況上面提到過,普通的文檔標記標記必須在每行的開頭以@標記,除此之外,還有一種標記叫做inline tag,用{@}表示,具體包括以下幾種:{@link}用法同@link{@source}顯示一段函數或方法的內容6.一些注釋規范a.注釋必須是/*** XXXXXXX*/的形式b.對于引用了全局變量的函數,必須使用glboal標記。c.對于變量,必須用var標記其類型(int,string,bool...)d.函數必須通過param和return標記指明其參數和返回值e.對于出現兩次或兩次以上的關鍵字,要通過ingore忽略掉多余的,只保留一個即可f.調用了其他函數或類的地方,要使用link或其他標記鏈接到相應的部分,便于文檔的閱讀。g.必要的地方使用非文檔性注釋,提高代碼易讀性。h.描述性內容盡量簡明扼要,盡可能使用短語而非句子。i.全局變量,靜態變量和常量必須用相應標記說明7. 總結phpDocumentor是一個非常強大的文檔自動生成工具,利用它可以幫助我們編寫規范的注釋,生成易于理解,結構清晰的文檔,對我們的代碼升級,維護,移交等都有非常大的幫助。關于phpDocumentor更為詳細的說明,可以到它的官方網站http://manual.phpdoc.org/查閱8.附錄附錄1:能夠被phpdoc識別的關鍵字:IncludeRequireinclude_oncerequire_oncedefinefunctionglobalclass附錄2文檔中可以使用的標簽<b><code><br><kdb><li><pre><ul><samp><var>附錄三:一段含有規范注釋的php代碼 :
<?php/*** Sample File 2, phpDocumentor Quickstart** This file demonstrates the rich information that can be included in* in-code documentation through DocBlocks and tags.* @author Greg Beaver <[email protected]>* @version 1.0* @package sample*/// sample file #1/*** Dummy include value, to demonstrate the parsing power of phpDocumentor*/include_once 'sample3.php';/*** Special global variable declaration DocBlock* @global integer $GLOBALS['_myvar']* @name $_myvar*/$GLOBALS['_myvar'] = 6;/*** Constants*//*** first constant*/define('testing', 6);/*** second constant*/define('anotherconstant', strlen('hello'));/*** A sample function docblock* @global string document the fact that this function uses $_myvar* @staticvar integer $staticvar this is actually what is returned* @param string $param1 name to declare* @param string $param2 value of the name* @return integer*/function firstFunc($param1, $param2 = 'optional') {static $staticvar = 7;global $_myvar;return $staticvar;}/*** The first example class, this is in the same package as the* procedural stuff in the start of the file* @package sample* @subpackage classes*/class myclass {/*** A sample private variable, this can be hidden with the --parseprivate* option* @accessprivate* @var integer|string*/var $firstvar = 6;/*** @link http://www.example.com Example link* @see myclass()* @uses testing, anotherconstant* @var array*/var $secondvar =array( 'stuff' => array( 6, 17, 'armadillo' ), testing => anotherconstant);/*** Constructor sets up {@link $firstvar}*/function myclass() {$this->firstvar = 7;}/*** Return a thingie based on $paramie* @param boolean $paramie* @return integer|babyclass*/function parentfunc($paramie) {if ($paramie) {return 6;} else {return new babyclass;}}}/*** @package sample1*/class babyclass extends myclass {/*** The answer to Life, the Universe and Everything* @var integer*/var $secondvar = 42;/*** Configuration values* @var array*/var $thirdvar;/*** Calls parent constructor, then increments {@link $firstvar}*/function babyclass() {parent::myclass();$this->firstvar++;}/*** This always returns a myclass* @param ignored $paramie* @return myclass*/function parentfunc($paramie) {return new myclass;}}?>