使用Doxygen构建文档系统 如果您这次还没来得及使用老式的Help Workshop为您的Web应用构建文档系统的话 那么 何不尝试一下Doxygen 需知 The proof of the pudding lies in the eating
Doxygen是什么go语言doxygen?
Doxygen是一种开源跨平台的 以类似JavaDoc风格描述的文档系统 完全支持C CJava 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 x/NT平台下也有对应的可执行版本
安装Doxygen
首先 去Doxygen网站上找到最新版本的Doxygen 有二进制或源码两种版本 如果不想重头编译 下载二进制版本安装即可 在Linux下 源码编译需要perl和Gnu工具flex bison make的支持 在Windows下 二进制版本勿需安装 而源码编译所需支持工具较多 go语言doxygen我们仅讲述Linux下的Doxygen的源码编译以及二进制版本安装过程
编译源码
gunzip doxygen $VERSION src tar gz tar xf doxygen $VERSION src tar sh /configure 或者configure platform platform type (略去直接使用configure需要平台检测的过程 平台类型在PLATFORMS文件中列出) configure with doxywizard(GUI前端选项) make 或者make docs(创建HTML格式的手册) make pdf(创建PDF格式的手册)
安装二进制版本
/configure make install
二进制文件安装目录是prefix/bin 其中prefix缺省为/usr 可以通过configure的参数 prefix修改其值 使用make install_docs可以把文档和例子安装在目录docdir/doxygen 其中docdir缺省为prefix/share/doc/packages 可以通过configure的参数 docdir修改其值 doxygen是bin目录下的一个命令行程序 它是Doxygen的核心工具 完成文档的转换和生成工作
Doxygen的处理流程
图 是Doxygen网站上给出的Doxygen处理工具以及它们之间的信息流
从图中可以看出 Doxygen可执行程序位于正中 所有的流程都围绕着它进行 左侧图标表示Doxygen的输入可以是源文件 或者是定制的头文件 图像 注解等 Doxygen图标上部是配置文件 由Doxywizard处理 下部是Tag文件 由Doxytag处理 后面是Doxygen输出文件的类型 依次是XML Latex Man pages RTF和HTML 可处理类型图标之后是进行进一步转换所需的工具
图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
实际上 go语言doxygen我们根本就不需要用一般的编辑器来编辑配置文件 Doxygen提供了一个辅助工具Doxywizard Doxywizard是Doxygen的GUI前台 用户可以能过它来读写配置文件 省却了手工配置的麻烦 基本上 在Doxywizard中可以完成Doxygen的绝大多数工作 而且Doxygen也可以在由Doxywizard启动 这样就使得整个过程比较连贯
虽然如此 go语言doxygen我们还是要理解常见的各个Tag的含义 在Doxywizard中 可以看到这些Tag以自明的方式命名 我们大致可以从名称中看出其作用 这些Tag被Doxywizard大致分为几类 其中HTML到PerlMod是输出文件种类设置 Project是Doxygen工程设置 Build是编译类选项 Messages为出错或异常选项 Input为输入源选项 等等
图Doxywizard
注释
Doxygen规定了进行注释的一些格式 正确的注释才能使Doxygen生成文档 第一个代码条目 都有两种描述 简要描述和详细描述 两者都是可选的 简要描述只有一行 而详细描述则提供更长 更仔细的描述 Doxygen只允许有一个简要描述和详细描述
在Doxygen中 一般只会处理与程序结构相关的注释 函数内部的注释通常不做处理 对于详细描述来说 有下面几种表示方式
JavaDoc风格 中间的 * 号可选 /** * 注释 */ Qt风格 中间的 * 号可选 /*! * 注释 */ C风格的变体 或者最后一个 / 改为 go语言doxygen! 也可以 /// 单行注释 /// 注释 /// 更加显著的表示 /////////////////////////////////////////// /// 注释 /////////////////////////////////////////// 简要描述亦有多种表示方式 在上述注释块中使用\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 也可以包含其它分组 复合实体(pound 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 中的工具 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_ y_ )\f$ (x y ) 位于独立一行上未编号的公式 应放在命令\f[和\f]之间 \f[ |I_ |=\left| \psi(t) \right| \f] 对应的输出是|I |=|ψ(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
lishixinzhi/Article/program/Java/hx/201311/26448
doxygen支持python吗在我发展一个Python模块为开发者提供KP-ABE和CP-ABE功能 。一个重要方面是文档 。任何像样的项目需要提供用户和开发人员文档 。用户文档是对外,告诉用户如何使用该项目,和开发人员文档是对内,告??开发人员项目是如何构成的 。开发人员文档和参考文档也知道 。有趣的是,用户文档可以进一步分为两组:用户\ u2014for当用户只是一个\ u2018plain-dumb-user ';Dev-User \ u2014when项目产生一些供其他开发者使用即一个图书馆 。经常Dev-User文档只是参考文档 。这篇文章是关于参考文档 。
记录API \ u2019s和库不同的语言有不同的工具:
Java Javadoc,Doxygen
Python epydoc,pydoctor pydoc,狮身人面像,Doxygen
C \ u2026 gtk-doc \ u2026,Doxygen
设计总有plantuml 。
用户文档,通常没有绑定到一个特定的编程语言有不同的格式:
乳胶
斯芬克斯
ASCIIDOC
减价
休息
DocBook
对于开发人员面临的文档,可以使用上述工具的组合 。特别是,当产生UML图 。
开发代码时,我尝试使用doxygen无论我走到哪里,doxygen是跨越语言和提供了一个好的意味着生产:终端用户,Developer用户,开发者在HTML文档、手册页,乳胶,RTF和XML;跨多个语言 。这是给你下降到c .此外,doxygen支持乳胶配方在文档中了 。此外,最新版本的doxygen允许减价的使用,和包容的减价格式化文件 。它本质上是SwissArmy刀的文档 。
然而,当发展中在Python中首选的文档工具是斯芬克斯,剩下依靠马克在Python \ u2018docstrings \ u2019产生参考文档和其他文件,用户文档 。我发现这种方法混乱,尤其是休息 。
Helaas,Doxygen \ u2019t想打好,并喜欢它的文档在特殊的注释块方法定义即之上 。
##
#打印消息发送到STDOUT
# @param味精要打印的消息
#
def print_message(味精):
打印(味精);
而不是在文档字符串 。幸运的是doxypy过滤器,允许有一个告诉doxygen看看文档字符串 。因此,上面的代码片段可以成为:
def print_message(味精):
”““打印消息发送到STDOUT
@param味精要打印的消息 。
"""
打印(味精);
python和doxygen一起很好地工作,除了标准的设置,以下配置设置还建议/要求:
INPUT_FILTER =“python /道路/ / doxypy.py”
FILTER_SOURCE_FILES = YES
HIDE_UNDOC_RELATIONS =没有
OPTIMIZE_OUTPUT_JAVA = YES
JAVADOC_AUTOBRIEF = YES
MULTILINE_CPP_IS_BRIEF = YES
DETAILS_AT_TOP = YES
EXTRACT_ALL = YES
EXTRACT_STATIC = YES
SHOW_DIRECTORIES = YES
SOURCE_BROWSER = YES
ALPHABETICAL_INDEX = YES
COLS_IN_ALPHA_INDEX = 8
TOC_EXPAND = YES
DISABLE_INDEX = YES
GENERATE_TREEVIEW = YES
值得注意的是,使用最新版本的Doxygen可以引用一个减价文件的主页 。
例如python项目使用Doxygen,看到pyPEBEL 。
引用:
自动文档使用Doxygen Python代码
从Python源文件创建文档Doxygen和doxypy
使用doxypy Python代码文档
使用Doxygen中的Readme MD文件作为主页
【go语言doxygen go语言开发为什么难找工作】go语言doxygen的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于go语言开发为什么难找工作、go语言doxygen的信息别忘了在本站进行查找喔 。
推荐阅读
- sap从入门到精通网盘,java从入门到精通pdf百度网盘
- 电脑怎么合成古筝,电脑怎么合成古筝曲子
- 微信电脑版开直播怎么开,微信电脑端如何打开直播
- go语言使用动态库 golang 动态库
- 鸿蒙系统怎么不支持双网络,鸿蒙系统不能所有应用双开
- 如何加强社群营销,如何加强社群营销能力
- oracle数据删除,oracle数据删除后怎么释放表空间
- java代码排列快捷键 java的快速排序算法
- 简洁代码大全java,java代码大全手册