title | author | categories | tags | image | |
---|---|---|---|---|---|
Using Jsdoc to sync the doc with the latest code |
lijiarui |
announcement |
|
/assets/2017/add-wechaty-jsdoc-automate-all-the-things.webp |
In order to sync the doc with the latest code, it's best to use jsdoc to describe the API and use jsdoc-to-markdown to generate markdown format documents to the docs directory.
Yes, we planned to do this for nearly a year...
Thanks to @Huan, @ax4,@hczhcz, @William, by the end of August, we finally convert all the doc to jsdoc. And I'd like to share some jsdoc experience here.
We need to document them better, not only the public but also the internal modules and methods.
Finally we decided to use the classic jsdoc to embed document in TypeScript, then generate document to docs/ by jsdoc2md.
-- @Huan said in issue 73 in Nov 2016.
At first, we write the doc in wiki, and it lasts for nearly a year.....
A lot of developers use wiki to learn wechaty, but the wiki's performance is not good, it cannot update automatically and doesn't base on user's most demand.
- some minor fix (such as the different naming Message Class & Class Room)
- improvement on the formatting, e.g. the level setting of each title
- maybe, add an index for better guiding
-- In Feb 2017, @ax4 creat an issue and expressed his willingness to contribute the document.
I like @ax4's idea about the document guide:
- First: Learn the awesome features of Wechaty
- Second: See more advanced functions
- Third: Reach the boundary? Help us develop Wechaty
Thanks for @ax4's suggestion and we decide to do the doc as soon as possible.
JsDoc is an API documentation generator for Javascript jsdoc-to-markdown is a tool to help developers create markdown API document from jsdoc-commented
JSDoc's purpose is to document the API of your JavaScript application or library. It is assumed that you will want to document things like modules, namespaces, classes, methods, method parameters, and so on.
JSDoc comments should generally be placed immediately before the code being documented. Each comment must start with a /**
sequence in order to be recognized by the JSDoc parser. Comments beginning with /*
, /***
, or more than 3 stars will be ignored. This is a feature to allow you to suppress parsing of comment blocks.
The simplest documentation is just a description
/** This is a description of the foo function. */
function foo() {
}
- *jsdoc Introduction
- *jsdoc English document
- *jsdoc Chinese document
- *Document This I use vscode as my editor, and use Document This "Document This" is a Visual Studio Code extension that automatically generates detailed JSDoc comments for both TypeScript and JavaScript files. You can use Ctrl+Alt+D and again Ctrl+Alt+D to generates documentation for whatever the caret is on or inside of.
Generates markdown API documentation from jsdoc annotated source code. Useful for injecting API docs into project README files.
When you document your code using valid jscode comments and run jsdoc command (e.g. jsdoc2md example.js
), then you can get a markdown output easily.
At first, I just write all of jsdoc in the code and link wechaty/docs/index.md to the users, but I cannot sync README.md
file with the code and make readme as simple as it can, so I have to do some else.
First, I should know how jsdoc2md works.
This is the main use case (render documentation) sequence:
- User runs
jsdoc2md example.js
. - jsdoc-api is used to obtain the raw jsdoc data for the input source code provided. (a kind of JSON output)
- this data is transformed into something suitable for passing into a template by jsdoc-parse (which also adds support for the jsdoc2md-specific tags like
@typicalname
,@done
,@category
etc). - the resulting template data is passed into dmd. This output is returned to the user.
In order to pick function name from the full api doc, I learnt about dmd, it is the default output templates for jsdoc-to-markdown. It contains handlebars partials and helpers intended to transform jsdoc-parse output into markdown API document.
For the wechaty document, I change two following dmd partials:
- link.hbs
- sig-link-parent.hbs
@Huan, @ax4,@hczhcz, @William and I talked a lot about wechaty document on the following issues:
- issue73: [doc] To Embed Document in Wechaty Code for Generating Automaticly
- issue252: [doc] Contribute to the doc editing[ jsdoc / jsdoc2md / typedoc ]
Also, @hczhcz and @ax4 and I contribute a lot on the document:
- PR378: jsdoc2md may flush some pieces of the embedded doc
- PR380: fix jsdoc flush issue #378 and minor fix on the doc examples
- PR640: add documentation TODO entries
- PR725: add wechaty document
- PR321: Add JsDoc for Class Contact
For the convenience of developers, our doc guideline as follows:
- Simple and clear
- Generate markdown for better readable version control and GitHub page hosting.
- Develop in TypeScript
- Embedded doc insert in TypeScript
- Compile TypeScript into JavaScript, using
npm run dist
- Run jsdoc / jsdoc2md, using
npm run doc
- Get the final doc, in index.md, config it to wechaty.github.io/wechaty
We embed doc into the following file:
Using the following command can generate document easily.
jsdoc2md dist/src/{wechaty,room,contact,friend-request,message}.js dist/src/puppet-web/friend-request.js>> docs/index.md
Actually, the first step is enough, but I think we need insert and sync all of the API docs into README, so I use a template by the following command:
jsdoc2md --template docs/partials/README.hbs dist/src/{wechaty,room,contact,friend-request,message}.js dist/src/puppet-web/friend-request.js>> README.md
Then add the partials {{>member-index-list~}} to show the API directory, because the full doc is too big to put in README, and it is not necessary.
After the second step, I found the link jsdoc2md generate is an anchor link(#
), it means I cannot link it to other pages(https://wechaty.github.io/wechaty), this is very inconvenient for readers.
Inspired by [jsdoc2md-issue-123], @KevinAst using jsdoc-to-markdown wrote a beatutiful doc: astx-redux-util.
I found maybe I can created a custom partial too.
Then I override the following templates in docs/partials/overrides
, adding https://wechaty.github.io/wechaty in the link:
- link.hbs
- sig-link-parent.hbs
This is the reason why I add the following script in package.json
:
jsdoc2md --partial docs/partials/overrides/*.hbs --template docs/partials/README.hbs dist/src/{wechaty,room,contact,friend-request,message}.js dist/src/puppet-web/friend-request.js>> README.md
--partial
command override link.hbs
and sig-link-parent.hbs
Then, all done!
For other developers, I tried my best to make it easier to add doc, just the following 2 steps:
/** This is a description of the foo function. */
function foo() {
}
npm run doc
Then you can find the generated jsdoc here: wechaty/docs/index.md
Cheers!