mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-15 14:50:39 +01:00

Bug: b/362492031, b/362492070, b/362492356, b/364207037, b/364831690 Change-Id: Ic889c731b98f8876c0ee31c0bda91a5a18b3add1 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/362100 Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Commit-Queue: Artem Titov <titovartem@webrtc.org> Cr-Commit-Position: refs/heads/main@{#42981}
68 lines
2.6 KiB
Markdown
68 lines
2.6 KiB
Markdown
<!-- go/cmark -->
|
|
<!--* freshness: {owner: 'titovartem' reviewed: '2024-09-09'} *-->
|
|
|
|
# How to write WebRTC documentation
|
|
|
|
## Audience
|
|
|
|
Engineers and tech writers who wants to contribute to WebRTC documentation
|
|
|
|
## Conceptual documentation
|
|
|
|
Conceptual documentation provides overview of APIs or systems. Examples can
|
|
be threading model of a particular module or data life cycle. Conceptual
|
|
documentation can skip some edge cases in favor of clarity. The main point
|
|
is to impart understanding.
|
|
|
|
Conceptual documentation often cannot be embedded directly within the source
|
|
code because it usually describes multiple APIs and entities, so the only
|
|
logical place to document such complex behavior is through a separate
|
|
conceptual document.
|
|
|
|
A concept document needs to be useful to both experts and novices. Moreover,
|
|
it needs to emphasize clarity, so it often needs to sacrifice completeness
|
|
and sometimes strict accuracy. That's not to say a conceptual document should
|
|
intentionally be inaccurate. It just means that is should focus more on common
|
|
usage and leave rare ones or side effects for class/function level comments.
|
|
|
|
In the WebRTC repo, conceptual documentation is located in `g3doc` subfolders
|
|
of related components. To add a new document for the component `Foo` find a
|
|
`g3doc` subfolder for this component and create a `.md` file there with
|
|
desired documentation. If there is no `g3doc` subfolder, create a new one.
|
|
|
|
Please put the following file header into any created documentation file as the
|
|
first line:
|
|
|
|
```markdown
|
|
<!-- go/cmark -->
|
|
```
|
|
|
|
When you want to specify a link from one page to another - use the absolute
|
|
path:
|
|
|
|
```
|
|
[My document](/module/g3doc/my_document.md)
|
|
```
|
|
|
|
If you are a Googler also please specify an owner, who will be responsible for
|
|
keeping this documentation updated, by adding the next lines at the beginning
|
|
of your `.md` file immediately after page title:
|
|
|
|
```markdown
|
|
<!--* freshness: {owner: '<user name>' reviewed: '<last review date in format yyyy-mm-dd>' *-->
|
|
```
|
|
|
|
After the document is ready you should add it into `/g3doc/sitemap.md`, so it
|
|
will be discoverable by others.
|
|
|
|
### Documentation format
|
|
|
|
The documentation is written in GitHub Markdown
|
|
([spec](https://github.github.com/gfm/#:~:text=GitHub%20Flavored%20Markdown%2C%20often%20shortened,a%20strict%20superset%20of%20CommonMark.)).
|
|
|
|
## Class/function level comments
|
|
|
|
Documentation of specific classes and function APIs and their usage, including
|
|
their purpose, is embedded in the .h files defining that API. See
|
|
[C++ style guide](https://chromium.googlesource.com/chromium/src/+/main/styleguide/c++/c++.md)
|
|
for pointers on how to write API documentatin in .h files.
|