2024-03-01 20:10:28 -06:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
#
|
|
|
|
|
# Configuration file for the Sphinx documentation builder.
|
|
|
|
|
#
|
|
|
|
|
# This file does only contain a selection of the most common options. For a
|
|
|
|
|
# full list see the documentation:
|
|
|
|
|
# http://www.sphinx-doc.org/en/master/config
|
|
|
|
|
|
|
|
|
|
# -- Path setup --------------------------------------------------------------
|
|
|
|
|
|
2025-01-02 13:29:47 -08:00
|
|
|
import subprocess as sp
|
|
|
|
|
import sys
|
|
|
|
|
|
2024-03-01 20:10:28 -06:00
|
|
|
# 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
|
2025-01-02 13:29:47 -08:00
|
|
|
# documentation root, use str(Path(<rel_path>).absolute().resolve()) to make it absolute, like shown here.
|
2024-03-01 20:10:28 -06:00
|
|
|
#
|
2025-01-02 13:29:47 -08:00
|
|
|
from pathlib import Path
|
2024-03-01 20:10:28 -06:00
|
|
|
|
2025-01-02 13:29:47 -08:00
|
|
|
sys.path.insert(0, str(Path("..").absolute().resolve()))
|
2024-03-01 20:10:28 -06:00
|
|
|
|
|
|
|
|
repo_version = "unknown"
|
|
|
|
|
# Determine short version by file in repo
|
2025-01-02 13:29:47 -08:00
|
|
|
if Path("./VERSION").is_file():
|
2024-03-01 20:19:50 -06:00
|
|
|
with open("./VERSION") as f:
|
2024-03-01 20:10:28 -06:00
|
|
|
repo_version = f.readline().strip()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def install(package):
|
|
|
|
|
sp.call([sys.executable, "-m", "pip", "install", package])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Project information -----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
project = "Omniperf"
|
|
|
|
|
copyright = "2022, Audacious Software Group"
|
|
|
|
|
author = "Audacious Software Group"
|
|
|
|
|
|
|
|
|
|
# The short X.Y version
|
|
|
|
|
version = repo_version
|
|
|
|
|
# The full version, including alpha/beta/rc tags
|
|
|
|
|
release = ""
|
|
|
|
|
|
|
|
|
|
# -- General configuration ---------------------------------------------------
|
|
|
|
|
|
|
|
|
|
install("sphinx_rtd_theme")
|
|
|
|
|
|
|
|
|
|
# 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.githubpages",
|
|
|
|
|
"myst_parser",
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
myst_heading_anchors = 2
|
|
|
|
|
# enable replacement of (tm) & friends
|
|
|
|
|
myst_enable_extensions = ["replacements"]
|
|
|
|
|
|
|
|
|
|
# Add any paths that contain templates here, relative to this directory.
|
|
|
|
|
templates_path = ["_templates"]
|
|
|
|
|
|
|
|
|
|
# The suffix(es) of source filenames.
|
|
|
|
|
# You can specify multiple suffix as a list of string:
|
|
|
|
|
source_suffix = {
|
|
|
|
|
".rst": "restructuredtext",
|
|
|
|
|
".txt": "markdown",
|
|
|
|
|
".md": "markdown",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
from recommonmark.parser import CommonMarkParser
|
|
|
|
|
|
|
|
|
|
source_parsers = {".md": CommonMarkParser}
|
|
|
|
|
|
|
|
|
|
# The master toctree document.
|
|
|
|
|
master_doc = "index"
|
|
|
|
|
|
|
|
|
|
# The language for content autogenerated by Sphinx. Refer to documentation
|
|
|
|
|
# for a list of supported languages.
|
|
|
|
|
#
|
|
|
|
|
# This is also used if you do content translation via gettext catalogs.
|
|
|
|
|
# Usually you set "language" from the command line for these cases.
|
|
|
|
|
language = "en"
|
|
|
|
|
|
|
|
|
|
# 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"]
|
|
|
|
|
|
|
|
|
|
# The name of the Pygments (syntax highlighting) style to use.
|
|
|
|
|
pygments_style = None
|
|
|
|
|
|
|
|
|
|
# options for latex output
|
|
|
|
|
latex_engine = "lualatex"
|
|
|
|
|
latex_show_urls = "footnote"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Options for HTML output -------------------------------------------------
|
|
|
|
|
|
|
|
|
|
# The theme to use for HTML and HTML Help pages. See the documentation for
|
|
|
|
|
# a list of builtin themes.
|
|
|
|
|
#
|
|
|
|
|
html_theme = "sphinx_rtd_theme"
|
|
|
|
|
|
|
|
|
|
# Theme options are theme-specific and customize the look and feel of a theme
|
|
|
|
|
# further. For a list of options available for each theme, see the
|
|
|
|
|
# documentation.
|
|
|
|
|
#
|
|
|
|
|
# html_theme_options = {}
|
|
|
|
|
|
|
|
|
|
# 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 = ["_static"]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Options for HTMLHelp output ---------------------------------------------
|
|
|
|
|
|
|
|
|
|
# Output file base name for HTML help builder.
|
|
|
|
|
htmlhelp_basename = "Omniperfdoc"
|
|
|
|
|
|
|
|
|
|
html_theme_options = {
|
|
|
|
|
"analytics_id": "G-C5DYLCE9ED", # Provided by Google in your dashboard
|
|
|
|
|
"analytics_anonymize_ip": False,
|
|
|
|
|
"logo_only": False,
|
|
|
|
|
"display_version": True,
|
|
|
|
|
"prev_next_buttons_location": "bottom",
|
|
|
|
|
"style_external_links": False,
|
|
|
|
|
"vcs_pageview_mode": "",
|
|
|
|
|
# 'style_nav_header_background': 'white',
|
|
|
|
|
# Toc options
|
|
|
|
|
"collapse_navigation": True,
|
|
|
|
|
"sticky_navigation": True,
|
|
|
|
|
"navigation_depth": 4,
|
|
|
|
|
"includehidden": True,
|
|
|
|
|
"titles_only": False,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
from pygments.styles import get_all_styles
|
|
|
|
|
|
|
|
|
|
# The name of the Pygments (syntax highlighting) style to use.
|
|
|
|
|
styles = list(get_all_styles())
|
|
|
|
|
preferences = ("emacs", "pastie", "colorful")
|
|
|
|
|
for pref in preferences:
|
|
|
|
|
if pref in styles:
|
|
|
|
|
pygments_style = pref
|
|
|
|
|
break
|
|
|
|
|
|
|
|
|
|
from recommonmark.transform import AutoStructify
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# app setup hook
|
|
|
|
|
def setup(app):
|
|
|
|
|
app.add_config_value(
|
|
|
|
|
"recommonmark_config",
|
|
|
|
|
{
|
|
|
|
|
"auto_toc_tree_section": "Contents",
|
|
|
|
|
"enable_eval_rst": True,
|
|
|
|
|
"enable_auto_doc_ref": False,
|
|
|
|
|
},
|
|
|
|
|
True,
|
|
|
|
|
)
|
|
|
|
|
app.add_transform(AutoStructify)
|
|
|
|
|
app.add_config_value("docstring_replacements", {}, True)
|
|
|
|
|
app.connect("source-read", replaceString)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# function to replace version string througout documentation
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def replaceString(app, docname, source):
|
|
|
|
|
result = source[0]
|
|
|
|
|
for key in app.config.docstring_replacements:
|
|
|
|
|
result = result.replace(key, app.config.docstring_replacements[key])
|
|
|
|
|
source[0] = result
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
docstring_replacements = {"{__VERSION__}": version}
|