惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Google Online Security Blog
Google Online Security Blog
博客园_首页
酷 壳 – CoolShell
酷 壳 – CoolShell
Jina AI
Jina AI
博客园 - Franky
大猫的无限游戏
大猫的无限游戏
Hugging Face - Blog
Hugging Face - Blog
博客园 - 司徒正美
V
V2EX
雷峰网
雷峰网
云风的 BLOG
云风的 BLOG
V
Visual Studio Blog
F
Full Disclosure
Y
Y Combinator Blog
V
V2EX - 技术
Attack and Defense Labs
Attack and Defense Labs
S
Security @ Cisco Blogs
Schneier on Security
Schneier on Security
Microsoft Azure Blog
Microsoft Azure Blog
SecWiki News
SecWiki News
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
The GitHub Blog
The GitHub Blog
量子位
PCI Perspectives
PCI Perspectives
S
Secure Thoughts
D
Darknet – Hacking Tools, Hacker News & Cyber Security
AWS News Blog
AWS News Blog
Blog — PlanetScale
Blog — PlanetScale
爱范儿
爱范儿
K
Kaspersky official blog
B
Blog
A
Arctic Wolf
Hacker News: Ask HN
Hacker News: Ask HN
L
LangChain Blog
T
Tor Project blog
P
Privacy & Cybersecurity Law Blog
Recent Announcements
Recent Announcements
宝玉的分享
宝玉的分享
The Register - Security
The Register - Security
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
L
Lohrmann on Cybersecurity
D
Docker
A
About on SuperTechFans
H
Hackread – Cybersecurity News, Data Breaches, AI and More
Google DeepMind News
Google DeepMind News
The Last Watchdog
The Last Watchdog
S
Security Affairs
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
P
Privacy International News Feed
Simon Willison's Weblog
Simon Willison's Weblog

博客园 - Titan

在Android模拟器上安装和卸载APK包 [ZZ]产品经理的核心价值 【ZZ】产品经理如何推进团队执行力 [转载]我在QQ邮箱的这四年 关于草根小团队创业的一些看法【转】 狗日的腾讯对蛋疼的360 [转载]Visual Studio统计有效代码行数 把东西写下来是一种神奇的力量 [转载]论我国的期股、期权激励制度 [转载]组态软件的发展和趋势 [转载]现阶段HMI市场发展趋势分析 自动化组态软件市场的趋势与挑战 [转载]风力发电自动化市场容量和增长预测 转载《2009年度组态软件市场研究报告》读后感 [ZZ]解析Windows 7超级任务栏 IE8 RC1使用体验 Windows 7 Beta hotkey cheat sheet [ZZ]Redirecting Output to a File in Windows Batch Scripts 欧洲通行证
使用Doxygen来自动化生成项目代码文档
Titan · 2010-10-26 · via 博客园 - Titan

 又到了项目结尾的时候,文档的需求又成了人民的最大矛盾了。

看了Doxygen 才发现原来之前看到很多以网页方式展现的开源项目代码都是通过该工具生成的,赞之!

关于 Doxygen 的安装文件,帮助,源代码都可以直接访问sourceforge获得:http://sourceforge.net/projects/doxygen/ 

初次接触还是需要了解很多关于Doxygen 的注释公约,简单搜了一下常用的贴在下面,后面使用到了再不断补充成自己需要的: 

Doxygen语法

1. 模块定义(单独显示一页)

/*
* @defgroup 模块名 模块的说明文字
* @{
*/
… 定义的内容 …
/** @} */ // 
模块结尾

2. 分组定义(在一页内分组显示)

/*
* @name 
分组说明文字
* @{
*/
… 定义的内容 …
/** @} */

3. 变量、宏定义、类型定义简要说明

/** 简要说明文字 */
#define FLOAT float

/** @brief 简要说明文字(在前面加 @brief 是标准格式) */
#define MIN_UINT 0

/*
分行的简要说明 \n
这是第二行的简要说明
*/
int b;

4. 函数说明

/*
简要的函数说明文字 
* @param [in] param1 
参数1说明
* @param [out] param2 
参数2说明
* @return 
返回值说明
*/

int func(int param1, int param2);

/*
打开文件 \n
文件打开成功后,必须使用 ::CloseFile 函数关闭。
* @param[in] file_name 
文件名字符串
* @param[in] file_mode 
文件打开模式字符串,可以由以下几个模块组合而成:
* - r 
读取
* - w 
可写
* - a 
添加
* - t 
文本模式(不能与 b 联用)
* - b 
二进制模式(不能与 t 联用)
* @return 
返回文件编号
* - -1 
表示打开文件失败
* @note 
文件打开成功后,必须使用 ::CloseFile 函数关闭
* @par 
示例:
* @code
// 
用文本只读方式打开文件
int f = OpenFile(”d:\\test.txt”, “rt”);
* @endcode
* @see ::ReadFile ::WriteFile ::CloseFile
* @deprecated 
由于特殊的原因,这个函数可能会在将来的版本中取消。
*/
int OpenFile(const char* file_name, const char* file_mode);

5. 枚举类型定义

/** 枚举常量 */
typedef enum TDayOfWeek
{
SUN = 0, /**< 星期天(注意,要以 “<” 小于号开头) */
MON = 1, /**< 星期一 */ 
TUE = 2, /**< 星期二 */ 
WED = 3, /**< 星期三 */ 
THU = 4, /**< 星期四 */ 
FRI = 5, /**< 星期五 */ 
SAT = 6 /**< 星期六 */ 
}

/** 定义类型 TEnumDayOfWeek */
TEnumDayOfWeek;

6. 项目符号标记

/*
* A list of events:
* - mouse events
* -# mouse move event
* -# mouse click event\n
* More info about the click event.
* -# mouse double click event
* - keyboard events
* -# key down event
* -# key up event
*
* More text here.
*/

结果为:

A list of events:

  • mouse events
    1. mouse move event
    2. mouse click event
      More info about the click event.
    3. mouse double click event
  • keyboard events
    1. key down event
    2. key up event

More text here.

代码示范:

/*
* @defgroup EXAMPLES 自动注释文档范例
* @author minidxer
* @version 1.0
* @date 2007-2008
* @{
*/

/*
* @name 文件名常量
* @{
*/

/** 日志文件名 */
#define LOG_FILENAME “c:\\log\\debug.log”
/** 
数据文件名 */
#define DATA_FILENAME “c:\\data\\detail.dat”
/** 
存档文件名 */
#define BAK_FILENAME “c:\\data\\backup.dat”

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

/*
* @name 系统状态常量
* @{
*/

/** 正常状态 */
#define SYS_NORMAL 0
/** 
故障状态 */
#define SYS_FAULT 1
/** 
警告状态 */
#define SYS_WARNNING 2

/** @}*/ // 系统状态常量

/** 枚举常量 */
typedef enum TDayOfWeek
{
SUN = 0, /**< 星期天 */
MON = 1, /**< 星期一 */
TUE = 2, /**< 星期二 */
WED = 3, /**< 星期三 */
THU = 4, /**< 星期四 */
FRI = 5, /**< 星期五 */
SAT = 6 /**< 星期六 */
}
/** 
定义类型 TEnumDayOfWeek */
TEnumDayOfWeek;
/** 
定义类型 PEnumDayOfWeek */
typedef TEnumDayOfWeek* PEnumDayOfWeek;

/** 定义枚举变量 enum1 */
TEnumDayOfWeek enum1;
/** 
定义枚举指针变量 enum2 */
PEnumDayOfWeek p_enum2;

/*
* @defgroup FileUtils 文件操作函数
* @{
*/

/*
打开文件 \n
文件打开成功后,必须使用 ::CloseFile 函数关闭。
* @param[in] file_name 
文件名字符串
* @param[in] file_mode 
文件打开模式字符串,可以由以下几个模块组合而成:
* - r 
读取
* - w 
可写
* - a 
添加
* - t 
文本模式(不能与 b 联用)
* - b 
二进制模式(不能与 t 联用)
* @return 
返回文件编号
* - -1 
表示打开文件失败

* @note 文件打开成功后,必须使用 ::CloseFile 函数关闭
* @par 
示例:
* @code
// 
用文本只读方式打开文件
int f = OpenFile(”c:\\test.txt”, “rt”);
* @endcode

* @see ::ReadFile ::WriteFile ::CloseFile
* @deprecated 由于特殊的原因,这个函数可能会在将来的版本中取消。
*/
int OpenFile(const char* file_name, const char* file_mode);

/*
读取文件
* @param[in] file 
文件编号,参见:::OpenFile
* @param[out] buffer 
用于存放读取的文件内容
* @param[in] len 
需要读取的文件长度
* @return 
返回读取文件的长度
* - -1 
表示读取文件失败

* @pre \e file 变量必须使用 ::OpenFile 返回值
* @pre \e buffer 
不能为 NULL
* @see ::OpenFile ::WriteFile ::CloseFile
*/
int ReadFile(int file, char* buffer, int len);

/*
写入文件
* @param[in] file 
文件编号,参见:::OpenFile
* @param[in] buffer 
用于存放将要写入的文件内容
* @param[in] len 
需要写入的文件长度
* @return 
返回写入的长度
* - -1 
表示写入文件失败

* @pre \e file 变量必须使用 ::OpenFile 返回值
* @see ::OpenFile ::ReadFile ::CloseFile
*/
int WriteFile(int file, const char* buffer, int len);

/*
关闭文件
* @param file 
文件编号,参见:::OpenFile
* @retval 0 
为成功
* @retval -1 
表示失败

* @see ::OpenFile ::WriteFile ::ReadFile
* @deprecated 由于特殊的原因,这个函数可能会在将来的版本中取消。
*/
int CloseFile(int file);

/** @}*/ // 文件操作函数

/** @}*/ // 自动注释文档范例