Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 1 | documentation |
| 2 | ============= |
| 3 | |
| 4 | This is the directory that contains the Yocto Project documentation. The Yocto |
Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 5 | Project source repositories at https://git.yoctoproject.org/cgit.cgi have two |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 6 | instances of the "documentation" directory. You should understand each of |
| 7 | these instances. |
| 8 | |
| 9 | poky/documentation - The directory within the poky Git repository containing |
| 10 | the set of Yocto Project manuals. When you clone the |
| 11 | poky Git repository, the documentation directory |
| 12 | contains the manuals. The state of the manuals in this |
| 13 | directory is guaranteed to reflect the latest Yocto |
| 14 | Project release. The manuals at the tip of this |
| 15 | directory will also likely contain most manual |
| 16 | development changes. |
| 17 | |
| 18 | yocto-docs/documentation - The Git repository for the Yocto Project manuals. |
| 19 | This repository is where manual development |
| 20 | occurs. If you plan on contributing back to the |
| 21 | Yocto Project documentation, you should set up |
| 22 | a local Git repository based on this upstream |
| 23 | repository as follows: |
| 24 | |
| 25 | git clone git://git.yoctoproject.org/yocto-docs |
| 26 | |
| 27 | Changes and patches are first pushed to the |
| 28 | yocto-docs Git repository. Later, they make it |
| 29 | into the poky Git repository found at |
| 30 | git://git.yoctoproject.org/poky. |
| 31 | |
| 32 | Manual Organization |
| 33 | =================== |
| 34 | |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 35 | Here the folders corresponding to individual manuals: |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 36 | |
Andrew Geissler | 5199d83 | 2021-09-24 16:47:35 -0500 | [diff] [blame] | 37 | * overview-manual - Yocto Project Overview and Concepts Manual |
| 38 | * sdk-manual - Yocto Project Software Development Kit (SDK) Developer's Guide. |
| 39 | * bsp-guide - Yocto Project Board Support Package (BSP) Developer's Guide |
| 40 | * dev-manual - Yocto Project Development Tasks Manual |
| 41 | * kernel-dev - Yocto Project Linux Kernel Development Manual |
| 42 | * ref-manual - Yocto Project Reference Manual |
| 43 | * brief-yoctoprojectqs - Yocto Project Quick Start |
| 44 | * profile-manual - Yocto Project Profiling and Tracing Manual |
| 45 | * toaster-manual - Toaster User Manual |
| 46 | * test-manual - Yocto Project Test Environment Manual |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 47 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 48 | Each folder is self-contained regarding content and figures. |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 49 | |
| 50 | If you want to find HTML versions of the Yocto Project manuals on the web, |
Andrew Geissler | 5199d83 | 2021-09-24 16:47:35 -0500 | [diff] [blame] | 51 | the current versions reside at https://docs.yoctoproject.org. |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 52 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 53 | poky.yaml |
| 54 | ========= |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 55 | |
| 56 | This file defines variables used for documentation production. The variables |
| 57 | are used to define release pathnames, URLs for the published manuals, etc. |
| 58 | |
| 59 | template |
| 60 | ======== |
| 61 | Contains various templates, fonts, and some old PNG files. |
| 62 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 63 | Sphinx |
| 64 | ====== |
| 65 | |
| 66 | The Yocto Project documentation was migrated from the original DocBook |
| 67 | format to Sphinx based documentation for the Yocto Project 3.2 |
| 68 | release. This section will provide additional information related to |
| 69 | the Sphinx migration, and guidelines for developers willing to |
| 70 | contribute to the Yocto Project documentation. |
| 71 | |
| 72 | Sphinx is a tool that makes it easy to create intelligent and |
| 73 | beautiful documentation, written by Georg Brandl and licensed under |
| 74 | the BSD license. It was originally created for the Python |
| 75 | documentation. |
| 76 | |
| 77 | Extensive documentation is available on the Sphinx website: |
| 78 | https://www.sphinx-doc.org/en/master/. Sphinx is designed to be |
| 79 | extensible thanks to the ability to write our own custom extensions, |
| 80 | as Python modules, which will be executed during the generation of the |
| 81 | documentation. |
| 82 | |
| 83 | Yocto Project documentation website |
| 84 | =================================== |
| 85 | |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 86 | The website hosting the Yocto Project documentation, can be found |
| 87 | at: https://docs.yoctoproject.org/. |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 88 | |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 89 | The entire Yocto Project documentation, as well as the BitBake manual, |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 90 | is published on this website, including all previously released |
| 91 | versions. A version switcher was added, as a drop-down menu on the top |
| 92 | of the page to switch back and forth between the various versions of |
| 93 | the current active Yocto Project releases. |
| 94 | |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 95 | Transition pages have been added (as rst files) to show links to old |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 96 | versions of the Yocto Project documentation with links to each manual |
| 97 | generated with DocBook. |
| 98 | |
| 99 | How to build the Yocto Project documentation |
| 100 | ============================================ |
| 101 | |
| 102 | Sphinx is written in Python. While it might work with Python2, for |
| 103 | obvious reasons, we will only support building the Yocto Project |
| 104 | documentation with Python3. |
| 105 | |
| 106 | Sphinx might be available in your Linux distro packages repositories, |
Andrew Geissler | 3b8a17c | 2021-04-15 15:55:55 -0500 | [diff] [blame] | 107 | however it is not recommended to use distro packages, as they might be |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 108 | old versions, especially if you are using an LTS version of your |
| 109 | distro. The recommended method to install Sphinx and all required |
| 110 | dependencies is to use the Python Package Index (pip). |
| 111 | |
| 112 | To install all required packages run: |
| 113 | |
| 114 | $ pip3 install sphinx sphinx_rtd_theme pyyaml |
| 115 | |
Andrew Geissler | eff2747 | 2021-10-29 15:35:00 -0500 | [diff] [blame] | 116 | Also install the "inkscape" package from your distribution. |
| 117 | Inkscape is need to convert SVG graphics to PNG (for EPUB |
| 118 | export) and to PDF (for PDF export). |
| 119 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 120 | To build the documentation locally, run: |
| 121 | |
| 122 | $ cd documentation |
Andrew Geissler | f034379 | 2020-11-18 10:42:21 -0600 | [diff] [blame] | 123 | $ make html |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 124 | |
| 125 | The resulting HTML index page will be _build/html/index.html, and you |
| 126 | can browse your own copy of the locally generated documentation with |
| 127 | your browser. |
| 128 | |
Andrew Geissler | 6ce62a2 | 2020-11-30 19:58:47 -0600 | [diff] [blame] | 129 | Alternatively, you can use Pipenv to automatically install all required |
| 130 | dependencies in a virtual environment: |
| 131 | |
| 132 | $ cd documentation |
| 133 | $ pipenv install |
| 134 | $ pipenv run make html |
| 135 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 136 | Sphinx theme and CSS customization |
| 137 | ================================== |
| 138 | |
| 139 | The Yocto Project documentation is currently based on the "Read the |
| 140 | Docs" Sphinx theme, with a few changes to make sure the look and feel |
| 141 | of the project documentation is preserved. |
| 142 | |
| 143 | Most of the theme changes can be done using the file |
| 144 | 'sphinx-static/theme_overrides.css'. Most CSS changes in this file |
| 145 | were inherited from the DocBook CSS stylesheets. |
| 146 | |
| 147 | Sphinx design guidelines and principles |
| 148 | ======================================= |
| 149 | |
| 150 | The initial Docbook to Sphinx migration was done with an automated |
| 151 | tool called Pandoc (https://pandoc.org/). The tool produced some clean |
| 152 | output markdown text files. After the initial automated conversion |
| 153 | additional changes were done to fix up headings, images and links. In |
| 154 | addition Sphinx has built in mechanisms (directives) which were used |
| 155 | to replace similar functions implemented in Docbook such as glossary, |
| 156 | variables substitutions, notes and references. |
| 157 | |
| 158 | Headings |
| 159 | ======== |
| 160 | |
| 161 | The layout of the Yocto Project manuals is organized as follows |
| 162 | |
| 163 | Book |
| 164 | Chapter |
| 165 | Section |
| 166 | Section |
| 167 | Section |
| 168 | |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 169 | Here are the heading styles defined in Sphinx: |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 170 | |
| 171 | Book => overline === |
| 172 | Chapter => overline *** |
| 173 | Section => ==== |
| 174 | Section => ---- |
| 175 | Section => ^^^^ |
| 176 | Section => """" or ~~~~ |
| 177 | |
| 178 | With this proposal, we preserve the same TOCs between Sphinx and Docbook. |
| 179 | |
| 180 | Built-in glossary |
| 181 | ================= |
| 182 | |
| 183 | Sphinx has a glossary directive. From |
| 184 | https://www.sphinx-doc.org/en/master/usage/restructuredtext/directives.html#glossary: |
| 185 | |
| 186 | This directive must contain a reST definition list with terms and |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 187 | definitions. It's then possible to refer to each definition through the |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 188 | [https://www.sphinx-doc.org/en/master/usage/restructuredtext/roles.html#role-term |
| 189 | 'term' role]. |
| 190 | |
| 191 | So anywhere in any of the Yocto Project manuals, :term:`VAR` can be |
| 192 | used to refer to an item from the glossary, and a link is created |
| 193 | automatically. A general index of terms is also generated by Sphinx |
| 194 | automatically. |
| 195 | |
| 196 | Global substitutions |
| 197 | ==================== |
| 198 | |
| 199 | The Yocto Project documentation makes heavy use of global |
| 200 | variables. In Docbook these variables are stored in the file |
| 201 | poky.ent. This Docbook feature is not handled automatically with |
| 202 | Pandoc. Sphinx has builtin support for substitutions |
| 203 | (https://www.sphinx-doc.org/en/master/usage/restructuredtext/basics.html#substitutions), |
| 204 | however there are important shortcomings. For example they cannot be |
| 205 | used/nested inside code-block sections. |
| 206 | |
| 207 | A Sphinx extension was implemented to support variable substitutions |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 208 | to mimic the DocBook based documentation behavior. Variable |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 209 | substitutions are done while reading/parsing the .rst files. The |
| 210 | pattern for variables substitutions is the same as with DocBook, |
| 211 | e.g. `&VAR;`. |
| 212 | |
| 213 | The implementation of the extension can be found here in the file |
| 214 | documentation/sphinx/yocto-vars.py, this extension is enabled by |
| 215 | default when building the Yocto Project documentation. All variables |
| 216 | are set in a file call poky.yaml, which was initially generated from |
| 217 | poky.ent. The file was converted into YAML so that it is easier to |
| 218 | process by the custom Sphinx extension (which is a Python module). |
| 219 | |
| 220 | For example, the following .rst content will produce the 'expected' |
| 221 | content: |
| 222 | |
| 223 | .. code-block:: |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 224 | $ mkdir poky-&DISTRO; |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 225 | or |
| 226 | $ git clone &YOCTO_GIT_URL;/git/poky -b &DISTRO_NAME_NO_CAP; |
| 227 | |
| 228 | Variables can be nested, like it was the case for DocBook: |
| 229 | |
Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 230 | YOCTO_HOME_URL : "https://www.yoctoproject.org" |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 231 | YOCTO_DOCS_URL : "&YOCTO_HOME_URL;/docs" |
| 232 | |
| 233 | Note directive |
| 234 | ============== |
| 235 | |
| 236 | Sphinx has a builtin 'note' directive that produces clean Note section |
| 237 | in the output file. There are various types of directives such as |
| 238 | "attention", "caution", "danger", "error", "hint", "important", "tip", |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 239 | "warning", "admonition" that are supported, and additional directives |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 240 | can be added as Sphinx extension if needed. |
| 241 | |
| 242 | Figures |
| 243 | ======= |
| 244 | |
| 245 | The Yocto Project documentation has many figures/images. Sphinx has a |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 246 | 'figure' directive which is straightforward to use. To include a |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 247 | figure in the body of the documentation: |
| 248 | |
| 249 | .. image:: figures/YP-flow-diagram.png |
| 250 | |
| 251 | Links and References |
| 252 | ==================== |
| 253 | |
| 254 | The following types of links can be used: links to other locations in |
| 255 | the same document, to locations in other documents and to external |
| 256 | websites. |
| 257 | |
| 258 | More information can be found here: |
| 259 | https://sublime-and-sphinx-guide.readthedocs.io/en/latest/references.html. |
| 260 | |
Andrew Geissler | 3b8a17c | 2021-04-15 15:55:55 -0500 | [diff] [blame] | 261 | Anchor (<#link>) links are forbidden as they are not checked by Sphinx during |
| 262 | the build and may be broken without knowing about it. |
| 263 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 264 | References |
| 265 | ========== |
| 266 | |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 267 | The following extension is enabled by default: |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 268 | sphinx.ext.autosectionlabel |
| 269 | (https://www.sphinx-doc.org/en/master/usage/extensions/autosectionlabel.html). |
| 270 | |
| 271 | This extension allows you to refer sections by their titles. Note that |
| 272 | autosectionlabel_prefix_document is enabled by default, so that we can |
| 273 | insert references from any document. |
| 274 | |
| 275 | For example, to insert an HTML link to a section from |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 276 | documentation/manual/intro.rst, use: |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 277 | |
| 278 | Please check this :ref:`manual/intro:Cross-References to Locations in the Same Document` |
| 279 | |
| 280 | Alternatively a custom text can be used instead of using the section |
| 281 | text: |
| 282 | |
| 283 | Please check this :ref:`section <manual/intro:Cross-References to Locations in the Same Document>` |
| 284 | |
| 285 | TIP: The following command can be used to dump all the references that |
| 286 | are defined in the project documentation: |
| 287 | |
| 288 | python -msphinx.ext.intersphinx <path to build folder>/html/objects.inv |
| 289 | |
| 290 | This dump contains all links and for each link it shows the default |
| 291 | "Link Text" that Sphinx would use. If the default link text is not |
| 292 | appropriate, a custom link text can be used in the ':ref:' directive. |
| 293 | |
| 294 | Extlinks |
| 295 | ======== |
| 296 | |
| 297 | The sphinx.ext.extlinks extension is enabled by default |
| 298 | (https://sublime-and-sphinx-guide.readthedocs.io/en/latest/references.html#use-the-external-links-extension), |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 299 | and it is configured with the 'extlinks' definitions in |
| 300 | the 'documentation/conf.py' file: |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 301 | |
| 302 | 'yocto_home': ('https://yoctoproject.org%s', None), |
| 303 | 'yocto_wiki': ('https://wiki.yoctoproject.org%s', None), |
| 304 | 'yocto_dl': ('https://downloads.yoctoproject.org%s', None), |
| 305 | 'yocto_lists': ('https://lists.yoctoproject.org%s', None), |
| 306 | 'yocto_bugs': ('https://bugzilla.yoctoproject.org%s', None), |
| 307 | 'yocto_ab': ('https://autobuilder.yoctoproject.org%s', None), |
| 308 | 'yocto_docs': ('https://docs.yoctoproject.org%s', None), |
| 309 | 'yocto_git': ('https://git.yoctoproject.org%s', None), |
| 310 | 'oe_home': ('https://www.openembedded.org%s', None), |
| 311 | 'oe_lists': ('https://lists.openembedded.org%s', None), |
Andrew Geissler | 95ac1b8 | 2021-03-31 14:34:31 -0500 | [diff] [blame] | 312 | 'oe_git': ('https://git.openembedded.org%s', None), |
| 313 | 'oe_wiki': ('https://www.openembedded.org/wiki%s', None), |
| 314 | 'oe_layerindex': ('https://layers.openembedded.org%s', None), |
| 315 | 'oe_layer': ('https://layers.openembedded.org/layerindex/branch/master/layer%s', None), |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 316 | |
| 317 | It creates convenient shortcuts which can be used throughout the |
| 318 | documentation rst files, as: |
| 319 | |
| 320 | Please check this :yocto_wiki:`wiki page </Weekly_Status>` |
| 321 | |
| 322 | Intersphinx links |
| 323 | ================= |
| 324 | |
| 325 | The sphinx.ext.intersphinx extension is enabled by default |
| 326 | (https://www.sphinx-doc.org/en/master/usage/extensions/intersphinx.html), |
| 327 | so that we can cross reference content from other Sphinx based |
| 328 | documentation projects, such as the BitBake manual. |
| 329 | |
Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 330 | References to the BitBake manual can be done: |
| 331 | - With a specific description instead of the section name: |
| 332 | :ref:`Azure Storage fetcher (az://) <bitbake:bitbake-user-manual/bitbake-user-manual-fetching:fetchers>` |
| 333 | - With the section name: |
| 334 | ":ref:`bitbake:bitbake-user-manual/bitbake-user-manual-intro:usage and syntax` option |
| 335 | - Linking to the entire BitBake manual: |
| 336 | :doc:`BitBake User Manual <bitbake:index>` |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 337 | |
Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 338 | Note that a reference to a variable (:term:`VARIABLE`) automatically points to |
| 339 | the BitBake manual if the variable is not described in the Reference Manual's Variable Glossary. |
| 340 | However, if you need to bypass this, you can explicitely refer to a description in the |
| 341 | BitBake manual as follows: |
| 342 | |
Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 343 | :term:`bitbake:BB_NUMBER_PARSE_THREADS` |
Andrew Geissler | 6ce62a2 | 2020-11-30 19:58:47 -0600 | [diff] [blame] | 344 | |
| 345 | Submitting documentation changes |
| 346 | ================================ |
| 347 | |
| 348 | Please see the top level README file in this repository for details of where |
| 349 | to send patches. |