• <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>

            Benjamin

            靜以修身,儉以養(yǎng)德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            編寫C++幫助文檔的工具-----doxys使用方法

            doxys是開源軟件,  文章最后給的鏈接里的doxys.exe是debug版本,還有個配置文件,感興趣的朋友可以打開鏈接下載,按照下面的方法使用即可。
            一、更改配置
            :打開DoxySfile,設(shè)置INPUT(源碼路徑)、OUTPUT_DIRECTORY(輸出路徑)、OUTPUT_LANGUAGE(語言選擇----界面語言)

            如果是中文界面,只要改變INPUTOUT_DIRECTORY的路徑就可以。

             

            二、生成文檔:進入MS-DOS,切換到doxys.exe所在的路徑,執(zhí)行doxys DoxySfile -m就可產(chǎn)生幫助文檔,不過都是html。

             

            三、制作CHM文檔:進入到配置文件中的OUTPUT_DIRECTORY(輸出路徑)下,在common目錄,打開js.js,搜索一下“http://www.doxys.dk,

            將有這已經(jīng)的代碼行注釋掉(這行在頁面上產(chǎn)生“產(chǎn)生 DoxyS”鏈接,它的直接結(jié)果就是產(chǎn)生doxys的英文幫助)。

            最后單擊.hhc.hhk.hhp文件,File菜單下點擊“compile”,就可以產(chǎn)生.chm文件。

             

            四、其他:必須的安裝文件還有htmhtlp.exe.

             

             

            附錄:編寫注釋規(guī)范

            一、函數(shù)注釋:

            /**

            \brief

            簡短注釋

            \n

            * @param[in] 輸入?yún)?shù)

            * @param[out] 輸出參數(shù)

            * @return 返回值

            * @note 注解

            * @par 示例

            * @code 代碼

            * @endcode

            * @see 參見

            * @deprecated 相關(guān)信息

            也可以在@param后面直接跟參數(shù)

             

            示例:函數(shù)OpenFile的注釋

                /**

                \brief file_文件

                打開文件 \n

                文件打開成功后,必須使用 ::CloseFile 函數(shù)關(guān)閉。

                * @param[in] file_name 文件名字符串

                * @param[in] file_mode 文件打開模式字符串,可以由以下幾個模塊組合而成:

                * - r 讀取

                * - w 可寫

                * - a 添加

                * - t 文本模式(不能與 b 聯(lián)用)

                * - b 二進制模式(不能與 t 聯(lián)用)

                * @return 返回文件編號

                * - -1 表示打開文件失敗

               

                 * @note 文件打開成功后,必須使用 ::CloseFile 函數(shù)關(guān)閉

                 * @par 示例:

                 * @code

                 // 用文本只讀方式打開文件

                 int f = OpenFile("d:\\test.txt", "rt");

                 * @endcode

                 

                    * @see ::ReadFile ::WriteFile ::CloseFile

                    * @deprecated 由于特殊的原因,這個函數(shù)可能會在將來的版本中取消。

                */

            int OpenFile(const char* file_name, const char* file_mode);

            二、變量注釋:

            /** 成員變量描述 */

             int m_Var;

            三、宏定義注釋:

            /** 定義說明 */

            #define LOG_FILENAME "d:\\log\\debug.log"

             

            在宏定義中我們也可以分組展示:就是在一組的宏定義前面和后面分別加注釋

            前面加:

            /** @name 文件名常量

             * @{

             */

            后面加:

            /** @}*/ // 文件名常量

            如下所示:

            /** @name 文件名常量

             * @{

             */

             

            /** 日志文件名 */

            #define LOG_FILENAME "d:\\log\\debug.log"

            /** 數(shù)據(jù)文件名 */

            #define DATA_FILENAME "d:\\data\\detail.dat"

            /** 存檔文件名 */

            #define BAK_FILENAME "d:\\data\\backup.dat"

             

            /** @}*/ // 文件名常量

             

            四、枚舉注釋:

            /** 枚舉常量 */

            typedef enum TDayOfWeek

            {

                SUN = 0, /**< 星期天 */

                MON = 1, /**< 星期一 */

                TUE = 2, /**< 星期二 */

                WED = 3, /**< 星期三 */

                THU = 4, /**< 星期四 */

                FRI = 5, /**< 星期五 */

                SAT = 6 /**< 星期六 */

            }

            五、類注釋:

            1、類的簡短說明:放到類聲明(Yourclass.h)最前面

            /*!\file

            \brief Yourclass類封裝了對象的屬性及對屬性的操作

            */

            .......

            .......

            class Yourclass{

            .........

            };

            2、類的詳細說明:在類簡短說明下面

             

            /** \file

            \brief 每個CPerson類對象包含問題規(guī)定的對象屬性

             

            * @author 作者

            * @version 版本號

            * @date 日期

             

            在“誰養(yǎng)魚”問題中,每個對象包含屬性:國籍、顏色、寵物、飲料、香煙、房間號。不過CPerson并不關(guān)心屬性的含義。

            屬性對CPerson來說只是序號和值。

            */

            六、結(jié)構(gòu)體/聯(lián)合體:

            /** A test class. 結(jié)構(gòu)體簡要說明. */

            typedef struct TWeek

            {

                int a; //!< 星期天

                int b;//!<星期一

                int c; //!<星期二

            };


            下面的鏈接是doxys.exe、DoxySfile和htmlhelp.exe,doxys.exe是debug版本的比較大,DoxySfile是配置文件,如果搭建懶得寫,改改這個示例的配置文件就行,方法如上所示。
            http://www.vdisk.cn/down/index/4361526A7291

            Doxygen相關(guān)設(shè)置

            首先在“Wizard”標簽的Project項進行如下設(shè)置:

            • 項目名稱:將在最新的文檔首頁中顯示
            • 源碼列表:選擇要生成文檔的源代碼或目錄,可以有多個文件或目錄形成一個列表。建議使用相對路徑,相對于當前目錄(也即當前配置文件所在的目錄)
            • 遞歸掃描:如果需要對整個源碼目錄下的所有子目錄及文件生成文檔,請勾選本項
            • 輸出目錄:設(shè)置最終生成的幫助文檔的存儲路徑,建議使用相對路徑

            下一步,Mode項,根據(jù)需要設(shè)置文檔生成模式。

            下一步,Output項,設(shè)置輸出格式,勾選HTML和“prepare for compressed HTML(.chm)”

            然后切換到“Expert”標簽的“HTML”項,設(shè)置HTML和CHM相關(guān)的選項:

            • GENERATE_HTMLHELP:確保已經(jīng)勾選了
            • CHM_FILE:最終生成的.chm的文件名,如“HkcProjectHelp.chm”。默認為“index.chm”??梢允褂寐窂?,也可以使用相對路徑,相對于上面設(shè)置的輸出目錄的html目錄(建設(shè)使用上一級目錄,如“..\MyDoc.chm”)
            • HHC_LOCATION:chm 編譯器(hhc.exe)的全路徑。請指到 HTML Help Workshop 的安裝目錄的 hhc.exe 程序
            • CHM_INDEX_ENCODING:chm索引文件編碼,下面會講到,這里填“GBK”

            編碼設(shè)置

            編碼設(shè)置很重要,如果設(shè)置不當,生成的文檔會出現(xiàn)亂碼。因為 Doxygen 汲及的東西多,有好幾項編碼設(shè)置,所以需要認真對待,根據(jù)項目的實情情況設(shè)置。

            所有高級設(shè)置(包括編碼設(shè)置)都在“Expert”標簽,重要的設(shè)置項如下:

            • Project/DOXYFILE_ENCODING:當前 Doxygen 配置文件本身的字符編碼,默認為UTF-8,一般不需要修改
            • Project/OUTPUT_LANGUAGE:輸出語言。這里是指Doxygen自己生成的導(dǎo)航、提示、幫助等文本的文字采用的語言。我們希望幫助文檔是全中文的,所以選擇Chinese
            • Input/INPUT_ENCODING:輸入文件的編碼。這里是指我們的源代碼文件本身的編碼。在Windows平臺一般是系統(tǒng)編碼(GBK),而Linux平臺一般是UTF-8。請用文本編輯器查看源文件的編碼。這里如果設(shè)置的不一致,源碼文件的注釋中所有非ASCII字符將在生成的文檔中變成亂碼。
            • HTMP/CHM_INDEX_ENCODING:這里設(shè)置Doxygen生成的CHM索引文件的編碼,以前是不能設(shè)置的,默認為UTF-8,而微軟的編譯器不能識別UTF-8編碼的索引文件,所以最終造成左邊目錄導(dǎo)航欄亂碼。我們設(shè)置它為GBK,這樣Doxygen將為我們生成GBK編碼的索引文件(.hhc、.hhk、.hhp)





            posted on 2010-04-25 22:04 Benjamin 閱讀(1288) 評論(0)  編輯 收藏 引用 所屬分類: 雜談

            性欧美丰满熟妇XXXX性久久久| 无码任你躁久久久久久老妇App| 成人久久精品一区二区三区| 一本一道久久精品综合| 色狠狠久久综合网| 2021久久精品国产99国产精品| 91精品日韩人妻无码久久不卡 | 国产精品久久网| 伊人久久大香线蕉AV一区二区| 99精品国产在热久久无毒不卡| 欧美一级久久久久久久大片| 久久电影网2021| 久久久一本精品99久久精品66 | 久久―日本道色综合久久| 97精品国产97久久久久久免费| 91久久精品电影| 久久精品国产亚洲AV电影| 综合久久国产九一剧情麻豆| 精品99久久aaa一级毛片| 久久久久久久久无码精品亚洲日韩| 久久夜色精品国产亚洲av| 97久久天天综合色天天综合色hd| 久久久久久久久久久| 久久国产综合精品五月天| 久久婷婷国产综合精品 | 久久亚洲2019中文字幕| av无码久久久久久不卡网站| 久久精品中文无码资源站| 日韩欧美亚洲综合久久影院Ds | 久久久久亚洲AV成人网人人网站| 久久久久综合国产欧美一区二区| 91久久精品91久久性色| 午夜不卡久久精品无码免费| 精品久久亚洲中文无码| 亚洲中文久久精品无码| 久久精品国产亚洲av影院| 人妻精品久久无码专区精东影业| 无码人妻久久一区二区三区免费丨| 久久精品一本到99热免费| 午夜不卡久久精品无码免费| 久久精品中文无码资源站|