mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-05 05:04:44 +02:00

Merge in the changes from master allowing conf.py to use information from poky.yaml. This allows the head version mapped to X.999 on the website to have the version information displayed clearly and correctly. (From yocto-docs rev: f462982ddb6e32052217d44c0c44e8a4df115589) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
158 lines
5.5 KiB
Python
158 lines
5.5 KiB
Python
# Configuration file for the Sphinx documentation builder.
|
|
#
|
|
# SPDX-License-Identifier: CC-BY-SA-2.0-UK
|
|
#
|
|
# This file only contains a selection of the most common options. For a full
|
|
# list see the documentation:
|
|
# https://www.sphinx-doc.org/en/master/usage/configuration.html
|
|
|
|
# -- Path setup --------------------------------------------------------------
|
|
|
|
# If extensions (or modules to document with autodoc) are in another directory,
|
|
# add these directories to sys.path here. If the directory is relative to the
|
|
# documentation root, use os.path.abspath to make it absolute, like shown here.
|
|
#
|
|
import os
|
|
import sys
|
|
import datetime
|
|
try:
|
|
import yaml
|
|
except ImportError:
|
|
sys.stderr.write("The Yocto Project Sphinx documentation requires PyYAML.\
|
|
\nPlease make sure to install pyyaml python package.\n")
|
|
sys.exit(1)
|
|
|
|
# current_version = "dev"
|
|
# bitbake_version = "" # Leave empty for development branch
|
|
# Obtain versions from poky.yaml instead
|
|
with open("poky.yaml") as data:
|
|
buff = data.read()
|
|
subst_vars = yaml.safe_load(buff)
|
|
if "DOCCONF_VERSION" not in subst_vars:
|
|
sys.stderr.write("Please set DOCCONF_VERSION in poky.yaml")
|
|
sys.exit(1)
|
|
current_version = subst_vars["DOCCONF_VERSION"]
|
|
if "BITBAKE_SERIES" not in subst_vars:
|
|
sys.stderr.write("Please set BITBAKE_SERIES in poky.yaml")
|
|
sys.exit(1)
|
|
bitbake_version = subst_vars["BITBAKE_SERIES"]
|
|
|
|
# String used in sidebar
|
|
version = 'Version: ' + current_version
|
|
if current_version == 'dev':
|
|
version = 'Version: Current Development'
|
|
# Version seen in documentation_options.js and hence in js switchers code
|
|
release = current_version
|
|
|
|
|
|
# -- Project information -----------------------------------------------------
|
|
project = 'The Yocto Project \xae'
|
|
copyright = '2010-%s, The Linux Foundation' % datetime.datetime.now().year
|
|
author = 'The Linux Foundation'
|
|
|
|
# -- General configuration ---------------------------------------------------
|
|
|
|
# Prevent building with an outdated version of sphinx
|
|
needs_sphinx = "3.1"
|
|
|
|
# to load local extension from the folder 'sphinx'
|
|
sys.path.insert(0, os.path.abspath('sphinx'))
|
|
|
|
# Add any Sphinx extension module names here, as strings. They can be
|
|
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
|
|
# ones.
|
|
extensions = [
|
|
'sphinx.ext.autosectionlabel',
|
|
'sphinx.ext.extlinks',
|
|
'sphinx.ext.intersphinx',
|
|
'yocto-vars'
|
|
]
|
|
autosectionlabel_prefix_document = True
|
|
|
|
# Add any paths that contain templates here, relative to this directory.
|
|
templates_path = ['_templates']
|
|
|
|
# List of patterns, relative to source directory, that match files and
|
|
# directories to ignore when looking for source files.
|
|
# This pattern also affects html_static_path and html_extra_path.
|
|
exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'boilerplate.rst']
|
|
|
|
# master document name. The default changed from contents to index. so better
|
|
# set it ourselves.
|
|
master_doc = 'index'
|
|
|
|
# create substitution for project configuration variables
|
|
rst_prolog = """
|
|
.. |project_name| replace:: %s
|
|
.. |copyright| replace:: %s
|
|
.. |author| replace:: %s
|
|
""" % (project, copyright, author)
|
|
|
|
# external links and substitutions
|
|
extlinks = {
|
|
'yocto_home': ('https://www.yoctoproject.org%s', None),
|
|
'yocto_wiki': ('https://wiki.yoctoproject.org/wiki%s', None),
|
|
'yocto_dl': ('https://downloads.yoctoproject.org%s', None),
|
|
'yocto_lists': ('https://lists.yoctoproject.org%s', None),
|
|
'yocto_bugs': ('https://bugzilla.yoctoproject.org%s', None),
|
|
'yocto_ab': ('https://autobuilder.yoctoproject.org%s', None),
|
|
'yocto_docs': ('https://docs.yoctoproject.org%s', None),
|
|
'yocto_git': ('https://git.yoctoproject.org/cgit/cgit.cgi%s', None),
|
|
'oe_home': ('https://www.openembedded.org%s', None),
|
|
'oe_lists': ('https://lists.openembedded.org%s', None),
|
|
'oe_git': ('https://git.openembedded.org%s', None),
|
|
'oe_wiki': ('https://www.openembedded.org/wiki%s', None),
|
|
'oe_layerindex': ('https://layers.openembedded.org%s', None),
|
|
'oe_layer': ('https://layers.openembedded.org/layerindex/branch/master/layer%s', None),
|
|
}
|
|
|
|
# Intersphinx config to use cross reference with Bitbake user manual
|
|
intersphinx_mapping = {
|
|
'bitbake': ('https://docs.yoctoproject.org/bitbake/' + bitbake_version, None)
|
|
}
|
|
|
|
# -- Options for HTML output -------------------------------------------------
|
|
|
|
# The theme to use for HTML and HTML Help pages. See the documentation for
|
|
# a list of builtin themes.
|
|
#
|
|
try:
|
|
import sphinx_rtd_theme
|
|
html_theme = 'sphinx_rtd_theme'
|
|
html_theme_options = {
|
|
'sticky_navigation': False,
|
|
}
|
|
except ImportError:
|
|
sys.stderr.write("The Sphinx sphinx_rtd_theme HTML theme was not found.\
|
|
\nPlease make sure to install the sphinx_rtd_theme python package.\n")
|
|
sys.exit(1)
|
|
|
|
html_logo = 'sphinx-static/YoctoProject_Logo_RGB.jpg'
|
|
|
|
# Add any paths that contain custom static files (such as style sheets) here,
|
|
# relative to this directory. They are copied after the builtin static files,
|
|
# so a file named "default.css" will overwrite the builtin "default.css".
|
|
html_static_path = ['sphinx-static']
|
|
|
|
html_context = {
|
|
'current_version': current_version,
|
|
}
|
|
|
|
# Add customm CSS and JS files
|
|
html_css_files = ['theme_overrides.css']
|
|
html_js_files = ['switchers.js']
|
|
|
|
# Hide 'Created using Sphinx' text
|
|
html_show_sphinx = False
|
|
|
|
# Add 'Last updated' on each page
|
|
html_last_updated_fmt = '%b %d, %Y'
|
|
|
|
# Remove the trailing 'dot' in section numbers
|
|
html_secnumber_suffix = " "
|
|
|
|
latex_elements = {
|
|
'passoptionstopackages': '\PassOptionsToPackage{bookmarksdepth=5}{hyperref}',
|
|
'preamble': '\setcounter{tocdepth}{2}',
|
|
}
|