documenting-code.rst 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. Documenting Code
  2. ================
  3. The purpose of this description is to provide quick summary on documentation style used in `espressif/esp-idf`_ repository and how to add new documentation.
  4. Introduction
  5. ------------
  6. When documenting code for this repository, please follow `Doxygen style <http://www.stack.nl/~dimitri/doxygen/manual/docblocks.html#specialblock>`_. You are doing it by inserting special commands, for instance ``@param``, into standard comments blocks, for example:
  7. ::
  8. /**
  9. * @param ratio this is oxygen to air ratio
  10. */
  11. Doxygen is phrasing the code, extracting the commands together with subsequent text, and building documentation out of it.
  12. Typical comment block, that contains documentation of a function, looks like below.
  13. .. image:: _static/doc-code-documentation-inline.png
  14. :align: center
  15. :alt: Sample inline code documentation
  16. Doxygen supports couple of formatting styles. It also gives you great flexibility on level of details to include in documentation. To get familiar with available features, please check data reach and very well organized `Doxygen Manual <http://www.stack.nl/~dimitri/doxygen/manual/index.html>`_.
  17. Why we need it?
  18. ---------------
  19. The ultimate goal is to ensure that all the code is consistently documented, so we can use tools like `Sphinx <http://www.sphinx-doc.org/>`_ and `Breathe <https://breathe.readthedocs.io/>`_ to aid preparation and automatic updates of API documentation when the code changes.
  20. With these tools the above piece of code renders like below:
  21. .. image:: _static/doc-code-documentation-rendered.png
  22. :align: center
  23. :alt: Sample inline code after rendering
  24. Go for it!
  25. ----------
  26. When writing code for this repository, please follow guidelines below.
  27. 1. Document all building blocks of code: functions, structs, typedefs, enums, macros, etc. Provide enough information on purpose, functionality and limitations of documented items, as you would like to see them documented when reading the code by others.
  28. 2. Documentation of function should describe what this function does. If it accepts input parameters and returns some value, all of them should be explained.
  29. 3. Do not add a data type before parameter or any other characters besides spaces. All spaces and line breaks are compressed into a single space. If you like to break a line, then break it twice.
  30. .. image:: _static/doc-code-function.png
  31. :align: center
  32. :alt: Sample function documented inline and after rendering
  33. 4. If function has void input or does not return any value, then skip ``@param`` or ``@return``
  34. .. image:: _static/doc-code-void-function.png
  35. :align: center
  36. :alt: Sample void function documented inline and after rendering
  37. 5. When documenting a ``define`` as well as members of a ``struct`` or ``enum``, place specific comment like below after each member.
  38. .. image:: _static/doc-code-member.png
  39. :align: center
  40. :alt: Sample of member documentation inline and after rendering
  41. 6. To provide well formatted lists, break the line after command (like ``@return`` in example below).
  42. ::
  43. *
  44. * @return
  45. * - ESP_OK if erase operation was successful
  46. * - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
  47. * - ESP_ERR_NVS_READ_ONLY if handle was opened as read only
  48. * - ESP_ERR_NVS_NOT_FOUND if the requested key doesn't exist
  49. * - other error codes from the underlying storage driver
  50. *
  51. 7. Overview of functionality of documented header file, or group of files that make a library, should be placed in the same directory in a separate ``README.rst`` file. If directory contains header files for different APIs, then the file name should be ``apiname-readme.rst``.
  52. Go one extra mile
  53. -----------------
  54. There is couple of tips, how you can make your documentation even better and more useful to the reader.
  55. 1. Add code snippets to illustrate implementation. To do so, enclose snippet using ``@code{c}`` and ``@endcode`` commands.
  56. ::
  57. *
  58. * @code{c}
  59. * // Example of using nvs_get_i32:
  60. * int32_t max_buffer_size = 4096; // default value
  61. * esp_err_t err = nvs_get_i32(my_handle, "max_buffer_size", &max_buffer_size);
  62. * assert(err == ESP_OK || err == ESP_ERR_NVS_NOT_FOUND);
  63. * // if ESP_ERR_NVS_NOT_FOUND was returned, max_buffer_size will still
  64. * // have its default value.
  65. * @endcode
  66. *
  67. The code snippet should be enclosed in a comment block of the function that it illustrates.
  68. 2. To highlight some important information use command ``@attention`` or ``@note``.
  69. ::
  70. *
  71. * @attention
  72. * 1. This API only impact WIFI_MODE_STA or WIFI_MODE_APSTA mode
  73. * 2. If the ESP32 is connected to an AP, call esp_wifi_disconnect to disconnect.
  74. *
  75. Above example also shows how to use a numbered list.
  76. 3. Use markdown to make your documentation even more readable. You will add headers, links, tables and more.
  77. ::
  78. *
  79. * [ESP32 Technical Reference](http://espressif.com/sites/default/files/documentation/esp32_technical_reference_manual_en.pdf)
  80. *
  81. .. note::
  82. Code snippets, notes, links, etc. will not make it to the documentation, if not enclosed in a comment block associated with one of documented objects.
  83. 5. Prepare one or more complete code examples together with description. Place them in a separate file ``example.rst`` in the same directory as the API header files. If directory contains header files for different APIs, then the file name should be ``apiname-example.rst``.
  84. Put it all together
  85. -------------------
  86. Once all the above steps are complete, follow instruction in :doc:`api/template` and create a single file, that will merge all individual pieces of prepared documentation. Finally add a link to this file to respective ``.. toctree::`` in ``index.rst`` file located in ``/docs`` folder.
  87. OK, but I am new to Sphinx!
  88. ---------------------------
  89. 1. No worries. All the software you need is well documented. It is also open source and free. Start by checking `Sphinx <http://www.sphinx-doc.org/>`_ documentation. If you are not clear how to write using rst markup language, see `reStructuredText Primer <http://www.sphinx-doc.org/en/stable/rest.html>`_.
  90. 2. Check the source files of this documentation to understand what is behind of what you see now on the screen. Sources are maintained on GitHub in `espressif/esp-idf`_ repository in :idf:`docs` folder. You can go directly to the source file of this page by scrolling up and clicking the link in the top right corner. When on GitHub, see what's really inside, open source files by clicking ``Raw`` button.
  91. 3. You will likely want to see how documentation builds and looks like before posting it on the GitHub. There are two options to do so:
  92. * Install `Sphinx <http://www.sphinx-doc.org/>`_, `Breathe <https://breathe.readthedocs.io/>`_ and `Doxygen <http://www.stack.nl/~dimitri/doxygen/>`_ to build it locally. You would need a Linux machine for that.
  93. * Set up an account on `Read the Docs <https://readthedocs.org/>`_ and build documentation in the cloud. Read the Docs provides document building and hosting for free and their service works really quick and great.
  94. Wrap up
  95. -------
  96. We love good code that is doing cool things.
  97. We love it even better, if it is well documented, so we can quickly make it run and also do the cool things.
  98. Go ahead, contribute your code and documentation!
  99. .. _espressif/esp-idf: https://github.com/espressif/esp-idf/