mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-04 22:00:34 +08:00
255 lines
13 KiB
Markdown
255 lines
13 KiB
Markdown
|
[#]: subject: "Document your source code with Doxygen on Linux"
|
|||
|
[#]: via: "https://opensource.com/article/22/5/document-source-code-doxygen-linux"
|
|||
|
[#]: author: "Stephan Avenwedde https://opensource.com/users/hansic99"
|
|||
|
[#]: collector: "lkxed"
|
|||
|
[#]: translator: " "
|
|||
|
[#]: reviewer: " "
|
|||
|
[#]: publisher: " "
|
|||
|
[#]: url: " "
|
|||
|
|
|||
|
Document your source code with Doxygen on Linux
|
|||
|
======
|
|||
|
This widely used open source tool can generate documentation from your comments.
|
|||
|
|
|||
|
![5 trends in open source documentation][1]
|
|||
|
|
|||
|
Image by: Internet Archive Book Images. Modified by Opensource.com. CC BY-SA 4.0
|
|||
|
|
|||
|
When trying to familiarize yourself with someone else's project, you usually appreciate the comments left behind that help you understand the meaning of their code. In the same way, whenever you are programming, whether for yourself or for others, it is good practice to comment your own code. All programming languages offer a special syntax to mark a word, a line, or a whole section as a comment. Those areas are then ignored by the compiler or interpreter when the source code is processed.
|
|||
|
|
|||
|
Comments don't take the place of documentation, but there is a way to use your comments to produce documentation easily. Meet [Doxygen][2], an open source tool for generating HTML or LaTeX documentation based on comments in the code. Doxygen enables you to provide a comprehensive overview of the structure of your code without additional effort. While Doxygen is mainly used to document C++, you can use it for many other languages, like C, Objective-C, C#, PHP, Java, Python, and more.
|
|||
|
|
|||
|
To use Doxygen, you simply comment your source code in a syntax that Doxygen can read. Doxygen then walks through your source files and creates HTML or LaTeX documentation based on those special comments. The C++ example project below will illustrate how the source code is commented and how the documentation is generated from it. The example is available on [GitHub][3], and I will also include references to different sections of the [Doxygen manual and documentation][4].
|
|||
|
|
|||
|
### Install Doxygen on Linux
|
|||
|
|
|||
|
On Fedora, Doxygen is available as a package. Open a terminal and run:
|
|||
|
|
|||
|
```
|
|||
|
sudo dnf install doxygen
|
|||
|
```
|
|||
|
|
|||
|
On Debian-based systems, you can install it by running:
|
|||
|
|
|||
|
```
|
|||
|
sudo apt-get install doxygen
|
|||
|
```
|
|||
|
|
|||
|
### Usage
|
|||
|
|
|||
|
Once installed, all you need is a project with Doxygen-compatible comments and a Doxyfile, a configuration file that controls the behavior of Doxygen.
|
|||
|
|
|||
|
Note: If you stick to the related example project on GitHub, you can omit the next step.
|
|||
|
|
|||
|
If there is no `Doxyfile` yet, you can simply let Doxygen generate a standard template. To do so, navigate to the root of your project and run:
|
|||
|
|
|||
|
```
|
|||
|
doxygen -g
|
|||
|
```
|
|||
|
|
|||
|
The `-g` stands for generate. You should now notice a newly created file called `Doxyfile`. You can invoke Doxygen by simply running:
|
|||
|
|
|||
|
```
|
|||
|
doxygen
|
|||
|
```
|
|||
|
|
|||
|
You should now notice two newly created folders:
|
|||
|
|
|||
|
* html/
|
|||
|
* latex/
|
|||
|
|
|||
|
By default, Doxygen outputs LaTeX-formatted documentation as well as HTML-based documentation. In this article, I will focus only on HTML-based documentation. You can find out more about LaTeX output in the official Doxygen documentation, in the *Getting started* section.
|
|||
|
|
|||
|
Double click on `html/index.html` to open the actual HTML documentation. With a blank configuration, it probably looks like the screenshot below:
|
|||
|
|
|||
|
![A screenshot of a doxygen generated main page on Firefox. The content field under My Project Documentation is blank.][6]
|
|||
|
|
|||
|
Now it's time to modify the `Doxyfile` and add some special comments to the source code.
|
|||
|
|
|||
|
### Doxyfile
|
|||
|
|
|||
|
The `Doxyfile` allows you to define tons of adjustment possibilities, so I will describe only a very small subset. The settings correspond to the `Doxyfile` of the example project.
|
|||
|
|
|||
|
#### Line 35: Project name
|
|||
|
|
|||
|
Here you can specify the project name, which will be visible in the header line and the browser tab.
|
|||
|
|
|||
|
```
|
|||
|
# The PROJECT_NAME tag is a single word (or a sequence of words surrounded by
|
|||
|
# double-quotes, unless you are using Doxywizard) that should identify the
|
|||
|
# project for which the documentation is generated. This name is used in the
|
|||
|
# title of most generated pages and in a few other places.
|
|||
|
# The default value is: My Project.
|
|||
|
|
|||
|
PROJECT_NAME = "My Project"
|
|||
|
```
|
|||
|
|
|||
|
#### Line 47: Project brief description
|
|||
|
|
|||
|
The brief description will also be shown in the header but in a smaller font.
|
|||
|
|
|||
|
```
|
|||
|
# Using the PROJECT_BRIEF tag one can provide an optional one line description
|
|||
|
# for a project that appears at the top of each page and should give viewer a
|
|||
|
# quick idea about the purpose of the project. Keep the description short.
|
|||
|
|
|||
|
PROJECT_BRIEF = "An example of using Doxygen in C++"
|
|||
|
```
|
|||
|
|
|||
|
#### Line 926: Inclusion of subdirectories
|
|||
|
|
|||
|
Allow Doxygen to walk recursively through subdirectories to find source and documentation files.
|
|||
|
|
|||
|
```
|
|||
|
# The RECURSIVE tag can be used to specify whether or not subdirectories should
|
|||
|
# be searched for input files as well.
|
|||
|
# The default value is: NO.
|
|||
|
|
|||
|
RECURSIVE = YES
|
|||
|
```
|
|||
|
|
|||
|
#### Line 1769: Disable LaTeX output
|
|||
|
|
|||
|
If you are just interested in the HTML output, you can disable the LaTeX code generation using this switch.
|
|||
|
|
|||
|
```
|
|||
|
# If the GENERATE_LATEX tag is set to YES, doxygen will generate LaTeX output.
|
|||
|
|
|||
|
# The default value is: YES.
|
|||
|
|
|||
|
GENERATE_LATEX = NO
|
|||
|
```
|
|||
|
|
|||
|
After every change, you can run Doxygen again to check whether your changes have had the desired effect. If you just want to check which modification an existing `Doxyfile` has, invoke Doxygen with the `-x` switch:
|
|||
|
|
|||
|
![A screenshot of the terminal showing the differences, Project Name, Project Brief, Recursive, and status of Generate Latex][7]
|
|||
|
|
|||
|
As with the command `diff`, Doxygen displays only the differences between the actual Doxyfile and the template.
|
|||
|
|
|||
|
### Special comments
|
|||
|
|
|||
|
Doxygen reads the sources and checks each file for special comments. Based on those comments and keywords, it builds up the HTML documentation. The anatomy of the special comments can be well explained using the header file of the class ByteStream, as shown in the GitHub example linked above.
|
|||
|
|
|||
|
I will look at the constructor and destructor as an example:
|
|||
|
|
|||
|
```
|
|||
|
/*! @brief Constructor which takes an external buffer to operate on
|
|||
|
*
|
|||
|
* The specified buffer already exist.
|
|||
|
* Memory and size can be accessed by buffer() and size().
|
|||
|
*
|
|||
|
* @param[in] pBuf Pointer to existing buffer
|
|||
|
* @param[in] size Size of the existing buffer
|
|||
|
*/
|
|||
|
|
|||
|
ByteStream(char* pBuf, size_t size) noexcept;
|
|||
|
```
|
|||
|
|
|||
|
There are different flavors of formatting a special comment block. I prefer to start the comment in the Qt-style (`/*!` ) and add an asterisk (`*` ) before each line. The block then ends with an asterisk followed by a forward slash (`*/` ). To get an overview of the different style options, refer to the Doxygen manual, in the section *Documenting the code*.
|
|||
|
|
|||
|
Comments in Doxygen are divided into two sections, a brief description and a detailed description. Both sections are optional. In the code sample above, the comment block refers to the following line of code, the declaration of a constructor. The sentence behind the `@brief` will be shown in the compact class overview:
|
|||
|
|
|||
|
![A screenshot of the C++ example of using Doxygen showing the Byte Stream Class Reference. The categories in the list are public member functions, writing (operators for writing to the stream), and reading (operators for reading from the stream)][8]
|
|||
|
|
|||
|
After a blank line (blank lines are treated as paragraph separators), the actual documentation for the constructor begins. With the `@param[in/out]` keyword, you can mark the arguments passed to the constructor, and Doxygen will make a clear argument list from it:
|
|||
|
|
|||
|
![Screenshot of the Doxygen example showing the parameters under ByteStream][9]
|
|||
|
|
|||
|
Note that Doxygen automatically creates a link to the mentioned `buffer()` and `size()` method in the comment. In contrast, the comment before the destructor declaration won't have any effect on Doxygen as it is not recognized as a special comment:
|
|||
|
|
|||
|
```
|
|||
|
// Destructor
|
|||
|
~ByteStream();
|
|||
|
```
|
|||
|
|
|||
|
Now you have seen 90% of the magic. By using a slightly modified syntax for your comments, you can convert them into special comments that Doxygen can read. Furthermore, by using a few keywords, you can advance the formatting. In addition, Doxygen has some special features, which I will highlight in the following section.
|
|||
|
|
|||
|
### Features
|
|||
|
|
|||
|
Most of the work is already done via your regular commenting on the source code. But with a few tweaks, you can easily enhance the output of Doxygen.
|
|||
|
|
|||
|
#### Markdown
|
|||
|
|
|||
|
For advanced formatting, Doxygen supports Markdown syntax and HTML commands. There is a Markdown cheat sheet available in the [download section][10] of opensource.com.
|
|||
|
|
|||
|
#### Mainpage
|
|||
|
|
|||
|
Aside from your customized header, you will get a mostly empty page when you open `html/index.html`. You can add some meaningful content to this empty space by using specific keywords. Because the main page is usually not dedicated to a particular source code file, you can add an ordinary text file containing the content for the main page into the root of your project. You can see this in the example on GitHub. The comments in there produce the following output:
|
|||
|
|
|||
|
![The Doxygen Example Documentation field now contains headings and documentation: Introduction, Running the example, System requirements, and Building the code, with step by step examples and code snippets (all can be found in the example on GitHub)][11]
|
|||
|
|
|||
|
#### Automatic link generation
|
|||
|
|
|||
|
As noted above, Doxygen automatically figures out when you are referring to an existing part of the code and creates a link to the related documentation. Be aware that automatic link creation only works if the part you refer to is documented as well.
|
|||
|
|
|||
|
More information can be found in the official documentation, under *Automatic link generation*.
|
|||
|
|
|||
|
#### Groups
|
|||
|
|
|||
|
The ByteStream class has overloaded stream operators for writing (`<<` ) and reading (`>>` ). In the class overview in the **Special comments** section above, you can see that the operator declarations are grouped as Writing and Reading. These groups are defined and named in the ByteStream header file.
|
|||
|
|
|||
|
Grouping is done using a special syntax: You start a group with `@{` and end it with `}@`. All members inside those marks belong to this group. In the header `ByteStream.h` it is implemented as follows:
|
|||
|
|
|||
|
```
|
|||
|
/** @name Writing
|
|||
|
* Operators for writing to the stream
|
|||
|
* @{
|
|||
|
*/
|
|||
|
|
|||
|
(...)
|
|||
|
|
|||
|
/** @}
|
|||
|
* @name Reading
|
|||
|
* Operators for reading from the stream
|
|||
|
* @{
|
|||
|
*/
|
|||
|
|
|||
|
(...)
|
|||
|
|
|||
|
/** @} */
|
|||
|
```
|
|||
|
|
|||
|
You can find more information about grouping in the Doxygen documentation, under *Grouping*.
|
|||
|
|
|||
|
#### LLVM Support
|
|||
|
|
|||
|
If you are building with [Clang][12], you can apply the flag `-Wdocumentation` to the build process to let Clang check your special comments. You can find more information about this feature in the LLVM Users Manual or in Dmitri Gribenko's presentation, both on the Clang website.
|
|||
|
|
|||
|
### Where Doxygen is used
|
|||
|
|
|||
|
Doxygen was first released in 1997, so it has been already around for some years. Despite its age, many projects use Doxygen to create their documentation. Some examples are NASA's [F Prime][13] flight software framework, the image processing library [OpenCV][14], and the package manager [RPM][15]. You can also find the Doxygen syntax in other areas, like in the documentation standards of the content management platform [Drupal][16].
|
|||
|
|
|||
|
A caveat: One drawback of using Doxygen is that it outputs HTML documentation with the look and feel of web pages from the nineties. It is also hard to depict the architecture of meta and template programming using Doxygen. For those cases, you would probably choose [Sphinx][17] over Doxygen.
|
|||
|
|
|||
|
--------------------------------------------------------------------------------
|
|||
|
|
|||
|
via: https://opensource.com/article/22/5/document-source-code-doxygen-linux
|
|||
|
|
|||
|
作者:[Stephan Avenwedde][a]
|
|||
|
选题:[lkxed][b]
|
|||
|
译者:[译者ID](https://github.com/译者ID)
|
|||
|
校对:[校对者ID](https://github.com/校对者ID)
|
|||
|
|
|||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|||
|
|
|||
|
[a]: https://opensource.com/users/hansic99
|
|||
|
[b]: https://github.com/lkxed
|
|||
|
[1]: https://opensource.com/sites/default/files/lead-images/documentation-type-keys-yearbook.png
|
|||
|
[2]: https://www.doxygen.n/
|
|||
|
[3]: https://github.com/hANSIc99/DoxygenSample
|
|||
|
[4]: https://www.doxygen.nl/manual/
|
|||
|
[5]: https://opensource.com/downloads/doxygen-cheat-sheet
|
|||
|
[6]: https://opensource.com/sites/default/files/2022-05/main%20page%20doxy.png
|
|||
|
[7]: https://opensource.com/sites/default/files/2022-05/doxygen%20class%20overview.png
|
|||
|
[8]: https://opensource.com/sites/default/files/2022-05/actual%20doxy%20byte%20stream%20class.png
|
|||
|
[9]: https://opensource.com/sites/default/files/2022-05/argument%20list%20from%20Doxygen.png
|
|||
|
[10]: https://opensource.com/downloads/cheat-sheet-markdown
|
|||
|
[11]: https://opensource.com/sites/default/files/2022-05/main%20page%20doxygen.png
|
|||
|
[12]: https://clang.llvm.org/
|
|||
|
[13]: https://github.com/nasa/fprime
|
|||
|
[14]: https://docs.opencv.org/4.5.5/index.html
|
|||
|
[15]: https://github.com/rpm-software-management/rpm
|
|||
|
[16]: https://www.drupal.org/docs/develop/standards/api-documentation-and-comment-standards
|
|||
|
[17]: https://opensource.com/article/18/11/building-custom-workflows-sphinx
|
|||
|
[18]: https://opensource.com/downloads/doxygen-cheat-sheet
|