TongchengOpenSource/smart-doc-maven-plugin
Fork: 49 Star: 59 (更新于 1970-01-01 00:00:00)
license: Apache-2.0
Language: Java .
maven plugin for smart-doc api documentation generation tool
最后发布版本: 3.0.0 ( 2023-10-19 10:03:57)
Smart-Doc Maven Plugin
Introduce
smart-doc-maven-plugin is a maven
plugin developed by the smart-doc official team.
This plugin is available from smart-doc 1.7.9.
Using smart-doc-maven-plugin makes it easier to integrate smart-doc into your project, and integration is more
lightweight.
You no longer need to write unit tests in your project to
Start smart-doc to scan source code analysis and generate API documents.
You can run the maven
command directly or click on the preset goal
of the smart-doc-maven-plugin in the IDE to
generate API documentation.
smart-doc-maven-plugin will also make smart-doc's ability to generate API documentation more powerful.
About smart-doc
Best Practice
smart-doc + Torna form an industry-leading document generation and management solution, using smart-doc to complete Java source code analysis and extract annotations to generate API documents without intrusion, and automatically push the documents to the Torna enterprise-level interface document management platform.
Getting started
Add plugin
<plugin>
<groupId>com.ly.smart-doc</groupId>
<artifactId>smart-doc-maven-plugin</artifactId>
<version>[latest version]</version>
<configuration>
<!--skip option is used to disable plugin in child module-->
<!--<skip>true</skip>-->
<!--Specify the configuration file used to generate the document-->
<configFile>./src/main/resources/smart-doc.json</configFile>
<!--smart-doc implements automatic analysis of the dependency tree to load the source code of third-party dependencies. If some framework dependency libraries are not loaded, an error is reported, then use excludes to exclude-->
<excludes>
<!--The format is: groupId: artifactId; refer to the following-->
<!--since 1.0.7 version you can also use regular matching to exclude, such as: poi. *-->
<exclude>com.google.guava:guava</exclude>
</excludes>
<!--Since version 1.0.8, the plugin provides includes support-->
<!--smart-doc can automatically analyze the dependency tree to load all dependent source code. In principle, it will affect the efficiency of document construction, so you can use includes to let the plugin load the components you configure.-->
<includes>
<!--The format is: groupId: artifactId; refer to the following-->
<include>com.alibaba:fastjson</include>
</includes>
</configuration>
<executions>
<execution>
<!--Comment out phase if you don't need to start smart-doc when compiling-->
<phase>compile</phase>
<goals>
<!--smart-doc provides html, openapi, markdown, adoc and other goals-->
<goal>html</goal>
</goals>
</execution>
</executions>
</plugin>
Create a json config
Create a json configuration file in your project. The smart-doc-maven-plugin plugin will use this configuration
information.
For example, create /src/main/resources/smart-doc.json
in the project.
The configuration contents are as follows.
Minimize configuration:
{
"allInOne": true, // whether to merge documents into one file, generally recommended as true
"isStrict": false,//If the strict mode is set to true, Smart-doc forces that the public method in each interface in the code has a comment.
"outPath": "/src/main/resources" //Set the api document output path.
}
Only three configurations items are needed to generate API documentation using smart-doc-maven-plugin. In fact, only outPath must be configured.
Detailed configuration content:
smart-doc provides a lot of configuration options. For more configuration options, please refer to the official documentation
Generated document
Run plugin with maven command
// Generate html
mvn -Dfile.encoding=UTF-8 smart-doc:html
// Generate markdown
mvn -Dfile.encoding=UTF-8 smart-doc:markdown
// Generate adoc
mvn -Dfile.encoding=UTF-8 smart-doc:adoc
// Generate postman collection
mvn -Dfile.encoding=UTF-8 smart-doc:postman
// Generate Open Api 3.0+,Since 1.1.5
mvn -Dfile.encoding=UTF-8 smart-doc:openapi
// Generate document and send to Torna
mvn -Dfile.encoding=UTF-8 smart-doc:torna-rest
// For Apache Dubbo Rpc
// Generate html
mvn -Dfile.encoding=UTF-8 smart-doc:rpc-html
// Generate markdown
mvn -Dfile.encoding=UTF-8 smart-doc:rpc-markdown
// Generate adoc
mvn -Dfile.encoding=UTF-8 smart-doc:rpc-adoc
Note: Under the window system, if you use the maven command line to perform document generation,
non-English characters may be garbled, so you need to specify -Dfile.encoding = UTF-8
during execution.
View maven's coding
# mvn -version
Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T19:57:37+08:00)
Maven home: D:\ProgramFiles\maven\bin\..
Java version: 1.8.0_191, vendor: Oracle Corporation
Java home: D:\ProgramFiles\Java\jdk1.8.0_191\jre
Default locale: zh_CN, platform encoding: GBK
OS name: "windows 10", version: "10.0", arch: "amd64", family: "dos"
Run plugin in IDEA
On Use IntelliJ IDE, if you have added smart-doc-maven-plugin to the project, you can directly find the plugin smart-doc plugin and click to generate API documentation.
Generated document example
Interface header rendering
Request parameter example rendering
Response parameter example renderings
Building
you can build with the following commands. (Java 1.8 is required to build the master branch)
mvn clean install -Dmaven.test.skip=true
Who is using
These are only part of the companies using smart-doc, for reference only. If you are using smart-doc, please add your company here to tell us your scenario to make smart-doc better.
License
smart-doc-maven-plugin is under the Apache 2.0 license. See the LICENSE file for details.
Contact
Email: opensource@ly.com
最近版本更新:(数据更新于 1970-01-01 00:00:00)
2023-10-19 10:03:57 3.0.0
2023-09-11 09:57:11 2.7.7
2023-09-03 00:26:07 2.7.6
2023-08-21 23:13:54 2.7.5
2023-07-29 12:35:33 2.7.4
2023-07-20 22:52:15 2.7.3
2023-07-08 11:44:34 2.7.2
2023-06-23 23:14:11 2.7.1
2023-06-11 14:38:40 2.7.0
2023-05-14 23:48:40 2.6.9
TongchengOpenSource/smart-doc-maven-plugin同语言 Java最近更新仓库
2025-01-17 17:46:39 apache/incubator-seata
2025-01-17 07:01:22 Stirling-Tools/Stirling-PDF
2025-01-16 16:51:02 spring-projects/spring-framework
2025-01-15 10:07:02 iBotPeaches/Apktool
2025-01-14 00:10:36 PBH-BTN/PeerBanHelper
2025-01-13 23:06:50 baomidou/mybatis-plus