blob: 6fbca116a5e5a2962bebf990abc1f8a44e9f6875 [file] [log] [blame] [view]
# How to write WebRTC documentation
<?% config.freshness.owner = 'titovartem' %?>
<?% config.freshness.reviewed = '2021-03-01' %?>
## 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 entites, 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;
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
<?\% config.freshness.owner = '<user name>' %?>
<?\% config.freshness.reviewed = '<last review date in format yyyy-mm-dd>' %?>
```
If you want to configure the owner for all pages under a directory, create a
`g3doc.lua` file in that directory with the content:
```lua
config = super()
config.freshness.owner = '<user name>'
return config
```
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/+/master/styleguide/c++/c++.md)
for pointers on how to write API documentatin in .h files.