3 @page Doxygen_On_Addon Doxygen on Kodi's Add-On headers
5 ### This page is for notes on using Doxygen to document the Kodi's Add-On headers source code.
7 [Doxygen](http://www.stack.nl/~dimitri/doxygen/index.html), is a documentation
8 system for C++, C, Java, and some other weird languages. It can generate html
9 docs documenting a projects source code, by either extracting special tags from
10 the source code (put there by people wanting to make use of doxygen), or doxygen
11 attempts to build documentation from existing source.
13 Doxygen seems to be installed on the NMR systems, type:
21 Start doxygen documentation for add-ons always with `///` and on Kodi itself with `/*!`, this makes it more easy to see for which place the documentation is.
23 <b>Here an example on add-on about function coding style:</b>
26 #ifdef DOXYGEN_SHOULD_USE_THIS
28 /// \ingroup python_xbmcgui_window
29 /// @brief Sets the resolution
31 /// That the coordinates of all controls are defined in. Allows Kodi
32 /// to scale control positions and width/heights to whatever resolution
33 /// Kodi is currently using.
35 /// @param[in] res Coordinate resolution to set
36 /// Resolution is one of the following:
37 /// | value | Resolution |
38 /// |:-----:|:--------------------------|
39 /// | 0 | 1080i (1920x1080)
40 /// | 1 | 720p (1280x720)
41 /// | 2 | 480p 4:3 (720x480)
42 /// | 3 | 480p 16:9 (720x480)
43 /// | 4 | NTSC 4:3 (720x480)
44 /// | 5 | NTSC 16:9 (720x480)
45 /// | 6 | PAL 4:3 (720x576)
46 /// | 7 | PAL 16:9 (720x576)
47 /// | 8 | PAL60 4:3 (720x480)
48 /// | 9 | PAL60 16:9 (720x480)
49 /// @return Nothing only added as example here :)
50 /// @param[out] nothingExample Example here, if on value pointer data becomes
52 /// @throws TypeError If supplied argument is not of List type, or a
53 /// control is not of Control type
54 /// @throws ReferenceError If control is already used in another window
55 /// @throws RuntimeError Should not happen :-)
58 ///--------------------------------------------------------------------------
61 /// ~~~~~~~~~~~~~{.py}
63 /// win = xbmcgui.Window(xbmcgui.getCurrentWindowId())
64 /// win.setCoordinateResolution(0)
68 setCoordinateResolution(...);
70 SWIGHIDDENVIRTUAL bool setCoordinateResolution(long res, int ¬hingExample);
73 - \verbatim /// \ingroup\endverbatim - Define the group where the documentation part comes in.
74 - \verbatim /// @brief\endverbatim - Add a small text of part there.
75 - \verbatim /// TEXT_FIELD\endverbatim - Add a bigger text there if needed.
76 - \verbatim /// @param[in] VALUE_NAME VALUE_TEXT\endverbatim - To set input parameter defined by name and add a description. There the example also add a small table which is useful to describe values.
77 - \verbatim /// @param[out] VALUE_NAME VALUE_TEXT\endverbatim - To set output parameter defined by name and add a description.
78 - \verbatim /// @return VALUE_TEXT\endverbatim - To add a description of return value.
79 - \verbatim /// @throws ERROR_TYPE ERROR_TEXT\endverbatim - If also exception becomes handled, can you use this for description.
80 - \verbatim /// TEXT_FIELD\endverbatim - Add a much bigger text there if needed.
81 - \verbatim /// ------------------\endverbatim - Use this to define a field line, e.g. if you add example add this always before, further must you make two empty lines before to prevent add of them on string before!
82 - \verbatim /// ~~~~~~~~~~~~~ \endverbatim - Here can you define a code example which must start and end with the definition string, also can you define the code style with e.g. <b>{.py}</b> for Python or <b>{.cpp}</b> for CPP code on the first line of them.
84 @note Start all `VALUE_TEXT` at same character to hold a clean code on <c>*.cpp</c> or <c>*.h</c> files.\n\n
85 The `#ifdef DOXYGEN_SHOULD_USE_THIS` on example above can be becomes used
86 if for Doxygen another function is needed to describe.
88 If you want to prevent a part from doxygen can you define <b>`#ifndef DOXYGEN_SHOULD_SKIP_THIS`</b>
89 or <b>`#ifdef DOXYGEN_SHOULD_USE_THIS`</b> on the related code.