| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 1 | # Configuration file for the Sphinx documentation builder. | 
|  | 2 | # | 
| Andrew Geissler | f034379 | 2020-11-18 10:42:21 -0600 | [diff] [blame] | 3 | # SPDX-License-Identifier: CC-BY-SA-2.0-UK | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 4 | # | 
|  | 5 | # This file only contains a selection of the most common options. For a full | 
|  | 6 | # list see the documentation: | 
|  | 7 | # https://www.sphinx-doc.org/en/master/usage/configuration.html | 
|  | 8 |  | 
|  | 9 | # -- Path setup -------------------------------------------------------------- | 
|  | 10 |  | 
|  | 11 | # If extensions (or modules to document with autodoc) are in another directory, | 
|  | 12 | # add these directories to sys.path here. If the directory is relative to the | 
|  | 13 | # documentation root, use os.path.abspath to make it absolute, like shown here. | 
|  | 14 | # | 
|  | 15 | import os | 
|  | 16 | import sys | 
|  | 17 | import datetime | 
| Andrew Geissler | 9aee500 | 2022-03-30 16:27:02 +0000 | [diff] [blame] | 18 | try: | 
|  | 19 | import yaml | 
|  | 20 | except ImportError: | 
|  | 21 | sys.stderr.write("The Yocto Project Sphinx documentation requires PyYAML.\ | 
| Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 22 | \nPlease make sure to install pyyaml Python package.\n") | 
| Andrew Geissler | 9aee500 | 2022-03-30 16:27:02 +0000 | [diff] [blame] | 23 | sys.exit(1) | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 24 |  | 
| Andrew Geissler | 9aee500 | 2022-03-30 16:27:02 +0000 | [diff] [blame] | 25 | # current_version = "dev" | 
|  | 26 | # bitbake_version = "" # Leave empty for development branch | 
|  | 27 | # Obtain versions from poky.yaml instead | 
|  | 28 | with open("poky.yaml") as data: | 
|  | 29 | buff = data.read() | 
|  | 30 | subst_vars = yaml.safe_load(buff) | 
|  | 31 | if "DOCCONF_VERSION" not in subst_vars: | 
|  | 32 | sys.stderr.write("Please set DOCCONF_VERSION in poky.yaml") | 
|  | 33 | sys.exit(1) | 
|  | 34 | current_version = subst_vars["DOCCONF_VERSION"] | 
|  | 35 | if "BITBAKE_SERIES" not in subst_vars: | 
|  | 36 | sys.stderr.write("Please set BITBAKE_SERIES in poky.yaml") | 
|  | 37 | sys.exit(1) | 
|  | 38 | bitbake_version = subst_vars["BITBAKE_SERIES"] | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 39 |  | 
|  | 40 | # String used in sidebar | 
|  | 41 | version = 'Version: ' + current_version | 
|  | 42 | if current_version == 'dev': | 
|  | 43 | version = 'Version: Current Development' | 
|  | 44 | # Version seen in documentation_options.js and hence in js switchers code | 
|  | 45 | release = current_version | 
|  | 46 |  | 
|  | 47 |  | 
|  | 48 | # -- Project information ----------------------------------------------------- | 
| Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 49 | project = 'The Yocto Project \xae' | 
| Patrick Williams | 0ca19cc | 2021-08-16 14:03:13 -0500 | [diff] [blame] | 50 | copyright = '2010-%s, The Linux Foundation, CC-BY-SA-2.0-UK license' % datetime.datetime.now().year | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 51 | author = 'The Linux Foundation' | 
|  | 52 |  | 
|  | 53 | # -- General configuration --------------------------------------------------- | 
|  | 54 |  | 
| Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 55 | # Prevent building with an outdated version of sphinx | 
| Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 56 | needs_sphinx = "4.0" | 
| Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 57 |  | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 58 | # to load local extension from the folder 'sphinx' | 
|  | 59 | sys.path.insert(0, os.path.abspath('sphinx')) | 
|  | 60 |  | 
|  | 61 | # Add any Sphinx extension module names here, as strings. They can be | 
|  | 62 | # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom | 
|  | 63 | # ones. | 
|  | 64 | extensions = [ | 
|  | 65 | 'sphinx.ext.autosectionlabel', | 
|  | 66 | 'sphinx.ext.extlinks', | 
|  | 67 | 'sphinx.ext.intersphinx', | 
|  | 68 | 'yocto-vars' | 
|  | 69 | ] | 
|  | 70 | autosectionlabel_prefix_document = True | 
|  | 71 |  | 
|  | 72 | # Add any paths that contain templates here, relative to this directory. | 
|  | 73 | templates_path = ['_templates'] | 
|  | 74 |  | 
|  | 75 | # List of patterns, relative to source directory, that match files and | 
|  | 76 | # directories to ignore when looking for source files. | 
|  | 77 | # This pattern also affects html_static_path and html_extra_path. | 
| Andrew Geissler | 6ce62a2 | 2020-11-30 19:58:47 -0600 | [diff] [blame] | 78 | exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'boilerplate.rst'] | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 79 |  | 
|  | 80 | # master document name. The default changed from contents to index. so better | 
|  | 81 | # set it ourselves. | 
|  | 82 | master_doc = 'index' | 
|  | 83 |  | 
|  | 84 | # create substitution for project configuration variables | 
|  | 85 | rst_prolog = """ | 
|  | 86 | .. |project_name| replace:: %s | 
|  | 87 | .. |copyright| replace:: %s | 
|  | 88 | .. |author| replace:: %s | 
|  | 89 | """ % (project, copyright, author) | 
|  | 90 |  | 
|  | 91 | # external links and substitutions | 
|  | 92 | extlinks = { | 
| Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 93 | 'cve': ('https://nvd.nist.gov/vuln/detail/CVE-%s', 'CVE-%s'), | 
| Patrick Williams | b542dec | 2023-06-09 01:26:37 -0500 | [diff] [blame] | 94 | 'cve_mitre': ('https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-%s', 'CVE-%s'), | 
| Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 95 | 'yocto_home': ('https://www.yoctoproject.org%s', None), | 
| Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 96 | 'yocto_wiki': ('https://wiki.yoctoproject.org/wiki%s', None), | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 97 | 'yocto_dl': ('https://downloads.yoctoproject.org%s', None), | 
|  | 98 | 'yocto_lists': ('https://lists.yoctoproject.org%s', None), | 
|  | 99 | 'yocto_bugs': ('https://bugzilla.yoctoproject.org%s', None), | 
|  | 100 | 'yocto_ab': ('https://autobuilder.yoctoproject.org%s', None), | 
|  | 101 | 'yocto_docs': ('https://docs.yoctoproject.org%s', None), | 
| Patrick Williams | 92b42cb | 2022-09-03 06:53:57 -0500 | [diff] [blame] | 102 | 'yocto_git': ('https://git.yoctoproject.org%s', None), | 
| Andrew Geissler | eff2747 | 2021-10-29 15:35:00 -0500 | [diff] [blame] | 103 | 'yocto_sstate': ('http://sstate.yoctoproject.org%s', None), | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 104 | 'oe_home': ('https://www.openembedded.org%s', None), | 
|  | 105 | 'oe_lists': ('https://lists.openembedded.org%s', None), | 
| Andrew Geissler | 6ce62a2 | 2020-11-30 19:58:47 -0600 | [diff] [blame] | 106 | 'oe_git': ('https://git.openembedded.org%s', None), | 
| Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 107 | 'oe_wiki': ('https://www.openembedded.org/wiki%s', None), | 
|  | 108 | 'oe_layerindex': ('https://layers.openembedded.org%s', None), | 
|  | 109 | 'oe_layer': ('https://layers.openembedded.org/layerindex/branch/master/layer%s', None), | 
| Patrick Williams | 7784c42 | 2022-11-17 07:29:11 -0600 | [diff] [blame] | 110 | 'wikipedia': ('https://en.wikipedia.org/wiki/%s', None), | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 111 | } | 
|  | 112 |  | 
| Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 113 | # Intersphinx config to use cross reference with BitBake user manual | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 114 | intersphinx_mapping = { | 
| Andrew Geissler | 595f630 | 2022-01-24 19:11:47 +0000 | [diff] [blame] | 115 | 'bitbake': ('https://docs.yoctoproject.org/bitbake/' + bitbake_version, None) | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 116 | } | 
|  | 117 |  | 
| Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 118 | # Suppress "WARNING: unknown mimetype for ..." | 
|  | 119 | suppress_warnings = ['epub.unknown_project_files'] | 
|  | 120 |  | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 121 | # -- Options for HTML output ------------------------------------------------- | 
|  | 122 |  | 
|  | 123 | # The theme to use for HTML and HTML Help pages.  See the documentation for | 
|  | 124 | # a list of builtin themes. | 
|  | 125 | # | 
| Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 126 | try: | 
|  | 127 | import sphinx_rtd_theme | 
|  | 128 | html_theme = 'sphinx_rtd_theme' | 
|  | 129 | html_theme_options = { | 
|  | 130 | 'sticky_navigation': False, | 
|  | 131 | } | 
|  | 132 | except ImportError: | 
|  | 133 | sys.stderr.write("The Sphinx sphinx_rtd_theme HTML theme was not found.\ | 
| Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 134 | \nPlease make sure to install the sphinx_rtd_theme Python package.\n") | 
| Andrew Geissler | c3d88e4 | 2020-10-02 09:45:00 -0500 | [diff] [blame] | 135 | sys.exit(1) | 
| Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 136 |  | 
|  | 137 | html_logo = 'sphinx-static/YoctoProject_Logo_RGB.jpg' | 
|  | 138 |  | 
|  | 139 | # Add any paths that contain custom static files (such as style sheets) here, | 
|  | 140 | # relative to this directory. They are copied after the builtin static files, | 
|  | 141 | # so a file named "default.css" will overwrite the builtin "default.css". | 
|  | 142 | html_static_path = ['sphinx-static'] | 
|  | 143 |  | 
|  | 144 | html_context = { | 
|  | 145 | 'current_version': current_version, | 
|  | 146 | } | 
|  | 147 |  | 
|  | 148 | # Add customm CSS and JS files | 
|  | 149 | html_css_files = ['theme_overrides.css'] | 
|  | 150 | html_js_files = ['switchers.js'] | 
|  | 151 |  | 
|  | 152 | # Hide 'Created using Sphinx' text | 
|  | 153 | html_show_sphinx = False | 
|  | 154 |  | 
|  | 155 | # Add 'Last updated' on each page | 
|  | 156 | html_last_updated_fmt = '%b %d, %Y' | 
|  | 157 |  | 
|  | 158 | # Remove the trailing 'dot' in section numbers | 
|  | 159 | html_secnumber_suffix = " " | 
| Andrew Geissler | 6ce62a2 | 2020-11-30 19:58:47 -0600 | [diff] [blame] | 160 |  | 
|  | 161 | latex_elements = { | 
|  | 162 | 'passoptionstopackages': '\PassOptionsToPackage{bookmarksdepth=5}{hyperref}', | 
|  | 163 | 'preamble': '\setcounter{tocdepth}{2}', | 
|  | 164 | } | 
| Andrew Geissler | eff2747 | 2021-10-29 15:35:00 -0500 | [diff] [blame] | 165 |  | 
|  | 166 | # Make the EPUB builder prefer PNG to SVG because of issues rendering Inkscape SVG | 
|  | 167 | from sphinx.builders.epub3 import Epub3Builder | 
|  | 168 | Epub3Builder.supported_image_types = ['image/png', 'image/gif', 'image/jpeg'] |