青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

如何使用Doxygen

Posted on 2009-12-24 16:39 Prayer 閱讀(3544) 評論(0)  編輯 收藏 引用 所屬分類: 面向對象

Doxygen是什么?

    Doxygen是一種開源跨平臺的,以類似JavaDoc風格描述的文檔系統,完全支持C、C++、Java、Objective-C和IDL語言,部分支持PHP、C#。注釋的語法與Qt-Doc、KDoc和JavaDoc兼容。Doxgen可以從一套歸檔源文件開始,生成HTML格式的在線類瀏覽器,或離線的LATEX、RTF參考手冊。對于未歸檔的源文件,也可以通過配置Doxygen來提取代碼結構。或者借助自動生成的包含依賴圖(include dependency graphs)、繼承圖(inheritance diagram)以及協作圖(collaboration diagram)來可視化文檔之間的關系。Doxygen生成的幫助文檔的格式可以是CHM、RTF、PostScript、PDF、HTML和Unix man page等。

   Doxygen在Linux上開發,但也可以在其它的Unix平臺下運行。而且,Windows 9x/NT平臺下也有對應的可執行版本。

安裝Doxygen

    首先,去Doxygen網站上找到最新版本的Doxygen。有二進制或源碼兩種版本,如果不想重頭編譯,下載二進制版本安裝即可。在Linux下,源碼編譯需要perl和Gnu工具flex、bison、make的支持。在Windows下,二進制版本勿需安裝,而源碼編譯所需支持工具較多。我們僅講述Linux下的Doxygen的源碼編譯以及二進制版本安裝過程。

編譯源碼

gunzip doxygen-$VERSION.src.tar.gztar xf doxygen-$VERSION.src.tarsh ./configure,或者configure --platform platform-type(略去直接使用configure需要平臺檢測的過程,平臺類型在PLATFORMS文件中列出),configure --with-doxywizard(GUI前端選項)make,或者make docs(創建HTML格式的手冊),make pdf(創建PDF格式的手冊)

安裝二進制版本

./configuremake install

    二進制文件安裝目錄是<prefix>/bin,其中<prefix>缺省為/usr,可以通過configure的參數--prefix修改其值。使用make install_docs可以把文檔和例子安裝在目錄<docdir>/doxygen,其中<docdir>缺省為<prefix>/share/doc/packages,可以通過configure的參數--docdir修改其值。doxygen是bin目錄下的一個命令行程序,它是Doxygen的核心工具,完成文檔的轉換和生成工作。

Doxygen的處理流程

圖1是Doxygen網站上給出的Doxygen處理工具以及它們之間的信息流。

    從圖中可以看出,Doxygen可執行程序位于正中,所有的流程都圍繞著它進行。左側圖標表示Doxygen的輸入可以是源文件,或者是定制的頭文件、圖像、注解等。Doxygen圖標上部是配置文件,由Doxywizard處理,下部是Tag文件,由Doxytag處理。后面是Doxygen輸出文件的類型,依次是XML、Latex、Man pages、RTF和HTML,可處理類型圖標之后是進行進一步轉換所需的工具。

圖1   Doxygen網站上給出的Doxygen信息流圖

配置文件

    每一個Doxygen工程都有一個后綴為.cfg的配置文件,用來保存所有的設置。配置文件的格式與autoexec.bat、config.sys等文件相似,是由名稱/值對組成的ASCII碼,會由doxygen命令來解析。為了簡化創建和修改配置文件,Doxygen可以在命令行方式下加上參數-g自動創建模板文件。

doxygen -g <config-file>

     忽略<config-file>將會生成一個名為Doxyfile的缺省文件,如果<config-file>已經存在,會被Doxygen改名為<config-file>.bak。

   實際上,我們根本就不需要用一般的編輯器來編輯配置文件,Doxygen提供了一個輔助工具Doxywizard。Doxywizard是Doxygen的GUI前臺,用戶可以能過它來讀寫配置文件,省卻了手工配置的麻煩?;旧希贒oxywizard中可以完成Doxygen的絕大多數工作,而且Doxygen也可以在由Doxywizard啟動,這樣就使得整個過程比較連貫。

    雖然如此,我們還是要理解常見的各個Tag的含義。在Doxywizard中,可以看到這些Tag以自明的方式命名,我們大致可以從名稱中看出其作用。這些Tag被Doxywizard大致分為幾類,其中HTML到PerlMod是輸出文件種類設置,Project是Doxygen工程設置,Build是編譯類選項,Messages為出錯或異常選項,Input為輸入源選項,等等。

圖2   Doxywizard

注釋

    Doxygen規定了進行注釋的一些格式,正確的注釋才能使Doxygen生成文檔。第一個代碼條目,都有兩種描述:簡要描述和詳細描述,兩者都是可選的。簡要描述只有一行,而詳細描述則提供更長、更仔細的描述,Doxygen只允許有一個簡要描述和詳細描述。

     在Doxygen中,一般只會處理與程序結構相關的注釋,函數內部的注釋通常不做處理。對于詳細描述來說,有下面幾種表示方式。

JavaDoc風格,中間的"*"號可選。/*** 注釋*/Qt風格,中間的"*"號可選。/*!* 注釋*/C++風格的變體,或者最后一個"/"改為"!"也可以。/// 單行注釋/// 注釋///更加顯著的表示。////////////////////////////////////////////// 注釋///////////////////////////////////////////簡要描述亦有多種表示方式。在上述注釋塊中使用\brief命令,詳細注釋在空行之后開始。/*! \brief 簡要描述*   繼續** 詳細注釋*/JAVADOC_AUTOBRIEF設置為YES后,在JavaDoc風格的注釋中,第一個點號之前的內容被自動設置為簡要描述。對于多行C++變體,這個選項亦會起到相同的作用。/** 簡要描述.詳細描述* 注釋*/C++變體風格。/// 簡要描述/* 詳細描述 */
            

命令

    Doxygen支持的指令非常多,主要作用是控制輸出文檔的排版格式。命令以"\"或"@"號開始。

一些命令可以有多個參數,一些命令只有一個參數。參數周圍的括號使用是有含義的:

  • <>號表示參數是單個詞。
  • ()號表示參數一直會到行尾。
  • {}號表示參數會擴展到下一段落。
  • []號表示參數是可選的。

下面章節中也涉及到一些命令的使用,其它的命令可以查閱Doxygen用戶手冊。

列表

Doxygen有許多方法可以創建項目列表。

使用"-"在每行開始之前打頭,使用"."可以結束一個列表,開始新的段落。使用這種方法要嚴格對齊。/***  - 表項一*    - 子項一*    - 子項二*    .*  .*/在文檔塊中使用HTML命令。這種方法不需要嚴格對齊。/*!*  <ul>*  <li> 表項一*  <ol>*     <li> 子項一*     <li> 子項二*     </ol>*  <li> 表項二*  </ul>*/

分組

    Doxygen有兩種分組機制。第一種是全局地為每一個組創建一個網頁,此時分組被稱為"module";第二種是用于復合實體中的成員列表,此時分組被稱為"member group"。Module是一種把內容在單個網頁上分組的方法。分組可以包括files,namespace,classes,functions,variables,enums,typedefs和defines,也可以包含其它分組。復合實體(compound entities)如類、文件、命名空間等可以分布在多個分組中,而成員實體(member)如變量、函數、typedef等只能歸屬于一個分組。

定義分組的方法是在特殊注釋塊中使用命令\defgroup和\addtogroup。 defgroup的格式如下:

\defgroup <唯一標識名> (中間可以有空格的標題)

    兩次使用同一標識名,在doxygen解析的時候會出現錯誤。命令addtogroup與defgroup不同的地方在于,如果使用了同一標識,則會在改組中加入新的項,如果標識不重復,則會創建分組。addtogroup中的標題是可選的。

    聲明分組之后,如果要使某個實體歸屬某一分組,需要使用ingroup命令。避免在每個成員之前都使用ingroup命令,可以將member用@{和@}封裝起來。

/** * \ingroup A */extern int VarInA;/** * \defgroup IntVariables Global integer variables *//*@{*//** an integer variable */extern int IntegerVariable;/*@}*/..../** * \defgroup Variables Global variables *//*@{*//** a variable in group A */int VarInA;int IntegerVariable;/*@}*/

    上面這些命令都是有優先級的,doxygen會根據優先級將實體放入具有最高優先級的分組之中。它們的優先級順序是:ingroup,defgroup,addtogroup,weakgroup。weakgroup類似一個低優先級的addtogroup。在.h文件中可以使用高優先級的命令定義層次結構,在.c文件中\weakgroup就不需要準確遵循.h文件中定義的層次結構。

如果要把不同的類型歸入同一分組內,就要使用Member group,它的定義方法如下:

//@{   ...//@}或者/*@{*/   ... /*@}*/

Member group不可以嵌套。

圖表

    Doxygen里有內置生成C++類層次圖的功能。它使用貝爾實驗室開發的graphviz 1.5中的工具"dot"來生成更高級的圖表。使用這個工具時,要將配置選項HAVE_DOT設為YES。

  • 當GRAPHICAL_HIERARCHY設置為YES時,將會繪制一個圖形表示的類圖結構。
  • 當CLASS_GRAPH設置為YES時,會為每個歸檔的類創建一張圖表示其直接或間接的繼承關系。
  • 當INCLUDE_GRAPH設置為YES時,會為每個歸檔文件創建一幅包含依賴圖,此功能目前僅有HTML和RTF格式支持。
  • 當COLLABORATION_GRAPH設置為YES時,會為每個歸檔類或結構繪制基類繼承關系圖和使用關系圖。
  • 當CALL_GRAPH設置為YES時,會為每個函數顯示一幅直接或間接調用關系圖。

更具體的信息可以參考Doxygen的手冊。

公式

    Doxygen可以把LaTeX格式的公式輸出出來。要在HTML文檔里包含公式,需要安裝下面的工具:latex(LaTeX編譯器)、dvips(將DVI文件轉換為PS文件)、gs(將PS文件轉換為位圖)。

包含公式的方法有兩種:

使用\f$命令對表示文本中間的公式,遵循LaTeX格式。\f$(x_1, y_1)\f$  (x1,y1)位于獨立一行上未編號的公式,應放在命令\f[和\f]之間。\f[    |I_2|=\left| \psi(t)           \right|\f]對應的輸出是|I2|=|ψ(t)|。

中文文檔

    Doxygen支持多種語言,輸出中文文檔的時候,只需要將配置文件中的OUTPUT_LANGUAGE標簽設置為Chinese即可(用Doxywizard修改更方便)。

    有一個需要注意的問題是,在Windows下的瀏覽器瀏覽中文HTML文檔時,英文字母會變得很難看,解決的辦法是將doxygen_cn.css下載到本地硬盤,并將配置文件中的HTML_STYLESHEET修改為這個文件的位置。

HTML_STYLESHEET=c:\doxygen\doxygen.css

運行doxygen

在命令行下運行doxygen是很簡單的,只需要指定配置文件即可。

doxygen project.cfg

或者,也可以使用Doxywizard在配置完后直接運行doxygen。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产精品久久精品怡红院| 国产精品毛片| 久久成人久久爱| 国产精品嫩草影院一区二区| 在线精品视频一区二区| 欧美在线观看一二区| 99re6这里只有精品视频在线观看| 久久影音先锋| 亚洲国产日韩在线| 欧美激情亚洲国产| 欧美日韩一区二区欧美激情| 亚洲免费成人av电影| 亚洲第一色中文字幕| 久久久久久高潮国产精品视| 精品动漫一区| 亚洲第一狼人社区| 欧美日韩国产bt| 香蕉免费一区二区三区在线观看| 亚洲精品一线二线三线无人区| 欧美日本免费| 亚洲一区二区视频在线| 国产精品国产三级国产专区53 | 欧美亚洲免费高清在线观看| 一本一本久久| 亚洲午夜激情免费视频| 麻豆freexxxx性91精品| 亚洲国产成人久久综合一区| 亚洲第一视频| 国产伦精品一区二区三区照片91| 欧美一区免费| 欧美二区在线观看| 久久久综合网| 国产精品狼人久久影院观看方式| 农夫在线精品视频免费观看| 国产精品爱啪在线线免费观看| 欧美国产激情| 国产精品免费网站在线观看| 欧美国产一区在线| 亚洲丶国产丶欧美一区二区三区 | 免费在线观看一区二区| 欧美韩日一区二区| 你懂的成人av| 亚洲欧洲另类| 欧美插天视频在线播放| 久久一二三区| 亚洲图片在线观看| 国产亚洲人成网站在线观看| 免费h精品视频在线播放| 亚洲美女黄色片| 久热国产精品视频| 亚洲天堂av在线免费| 黄色成人免费观看| 欧美日韩免费观看中文| 久久精品国产99精品国产亚洲性色| 欧美刺激性大交免费视频| 亚洲欧美中日韩| 亚洲国产精品高清久久久| 一本久久综合亚洲鲁鲁五月天| 亚洲伦伦在线| 国产精品一卡二卡| 99精品热6080yy久久 | 亚洲一区二区成人在线观看| 亚洲一区二区三区精品在线观看 | 欧美一区二区三区播放老司机| 久久精品亚洲一区二区| 最近中文字幕日韩精品| 欧美日韩精品免费看| 欧美在线视频a| 亚洲美女免费精品视频在线观看| 午夜视频在线观看一区| 亚洲缚视频在线观看| 国产精品成人观看视频免费 | 亚洲一区二区三区四区中文 | 欧美成人免费网| 午夜精品影院| 亚洲性感激情| 亚洲伦理在线免费看| 激情亚洲网站| 国产日韩1区| 国产精品分类| 欧美日韩综合在线免费观看| 麻豆精品精华液| 久久精品一区二区三区不卡牛牛| 99精品国产在热久久下载| 亚洲激情婷婷| 亚洲成人自拍视频| 亚洲电影av在线| 亚洲成色www8888| 亚洲高清网站| 亚洲人成免费| 一级日韩一区在线观看| 一本色道88久久加勒比精品| 亚洲人成网站在线播| 国产一区二区三区免费在线观看| 乱人伦精品视频在线观看| 麻豆成人小视频| 美女91精品| 欧美日精品一区视频| 欧美三级电影一区| 国产精品高潮粉嫩av| 国产日韩精品一区二区浪潮av| 一区二区三区中文在线观看 | 一区二区三区日韩精品| 亚洲尤物精选| 久久婷婷色综合| 91久久黄色| 久久av一区二区三区| 欧美精品乱码久久久久久按摩| 国产精品r级在线| 精品电影在线观看| 国产精品99久久久久久久女警 | 久久综合中文色婷婷| 欧美承认网站| 亚洲在线观看| 欧美日韩国产成人| 国产一区二区三区的电影| 一区国产精品| 91久久夜色精品国产网站| 欧美日本不卡视频| 久久久久久久综合日本| 欧美第一黄色网| 午夜影院日韩| 欧美激情视频一区二区三区在线播放| 亚洲在线视频免费观看| 欧美在线视频免费播放| 国语自产偷拍精品视频偷| 亚洲东热激情| 国内成+人亚洲+欧美+综合在线| 久久综合图片| 国产精品成人一区二区网站软件| 精品91久久久久| 久久亚洲不卡| 国产精品www色诱视频| 亚洲视频1区2区| 免费在线亚洲欧美| 久久男人av资源网站| 亚洲福利视频免费观看| 亚洲电影自拍| 激情欧美一区二区三区| 麻豆精品网站| 欧美xxx成人| 久久精品国产99| 国产精品毛片在线看| 亚洲伦理一区| 极品少妇一区二区三区精品视频| 欧美国产亚洲精品久久久8v| 欧美久久久久免费| 久久综合色天天久久综合图片| 欧美三区不卡| 一本色道久久99精品综合| 在线观看亚洲精品视频| 亚洲视频碰碰| 亚洲在线播放| 国产精品免费aⅴ片在线观看| 亚洲韩日在线| 91久久久久久久久| 久久亚洲一区二区| 免费一级欧美片在线播放| 国产精品午夜在线观看| 亚洲午夜激情网站| 亚洲综合另类| 国产欧美精品久久| 亚洲欧美一区二区原创| 亚洲欧美高清| 国产日韩亚洲欧美综合| 亚洲女同同性videoxma| 午夜精品久久久久久久白皮肤 | 国产伦精品一区二区三区免费 | 一区二区亚洲精品| 久久久美女艺术照精彩视频福利播放 | 亚洲国产成人一区| 久久久久88色偷偷免费| 免费成人在线观看视频| 亚洲欧洲一区二区在线观看| 欧美二区在线| 亚洲一区二区三区影院| 久久亚洲一区二区三区四区| 亚洲欧洲日产国产网站| 欧美性久久久| 久久高清国产| 99re6热只有精品免费观看| 亚洲综合精品| 久久精品一区四区| 亚洲欧美精品伊人久久| 欧美理论电影网| 一区二区三区日韩| 亚洲一区二区三区视频播放| 欧美主播一区二区三区美女 久久精品人| 欧美一级大片在线免费观看| 亚洲激情成人网| 国产一区二区久久精品| 国产精品海角社区在线观看| 毛片av中文字幕一区二区| 欧美一区国产一区| 宅男精品视频| 亚洲小说区图片区| 99亚洲一区二区| 在线亚洲一区二区| 在线综合视频| 午夜精品久久久久久久99黑人|