forked from mirrors/gecko-dev
Backed out changeset ff3fb0b4a512 (bug 1672023) Backed out changeset e7834b600201 (bug 1654103) Backed out changeset 807893ca8069 (bug 1518999) Backed out changeset 13e6b92440e9 (bug 1518999) Backed out changeset 8b2ac5a6c98a (bug 1518999) Backed out changeset 575748295752 (bug 1518999) Backed out changeset 65f07ce7b39b (bug 1518999) Backed out changeset 4bb80556158d (bug 1518999) Backed out changeset 8ac8461d7bd7 (bug 1518999) Backed out changeset e8ba13ee17f5 (bug 1518999)
124 lines
3.7 KiB
Python
124 lines
3.7 KiB
Python
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
from __future__ import absolute_import, unicode_literals
|
|
|
|
import os
|
|
import sys
|
|
|
|
from recommonmark.transform import AutoStructify
|
|
|
|
# Set up Python environment to load build system packages.
|
|
OUR_DIR = os.path.dirname(__file__)
|
|
topsrcdir = os.path.normpath(os.path.join(OUR_DIR, ".."))
|
|
|
|
copybutton_prompt_text = ">>> |\\\\$ |\\[\\d*\\]: |\\.\\.\\.: "
|
|
copybutton_prompt_is_regexp = True
|
|
|
|
EXTRA_PATHS = (
|
|
"layout/tools/reftest",
|
|
"python/mach",
|
|
"python/mozbuild",
|
|
"python/mozversioncontrol",
|
|
"testing/mozbase/manifestparser",
|
|
"testing/mozbase/mozfile",
|
|
"testing/mozbase/mozprocess",
|
|
"third_party/python/futures",
|
|
"third_party/python/jsmin",
|
|
"third_party/python/which",
|
|
"toolkit/components/glean/sphinx",
|
|
)
|
|
|
|
sys.path[:0] = [os.path.join(topsrcdir, p) for p in EXTRA_PATHS]
|
|
|
|
sys.path.insert(0, OUR_DIR)
|
|
|
|
extensions = [
|
|
"sphinx.ext.autodoc",
|
|
"sphinx.ext.autosectionlabel",
|
|
"sphinx.ext.doctest",
|
|
"sphinx.ext.graphviz",
|
|
"sphinx.ext.napoleon",
|
|
"sphinx.ext.todo",
|
|
"mozbuild.sphinx",
|
|
"sphinx_js",
|
|
"sphinxcontrib.mermaid",
|
|
"recommonmark",
|
|
"sphinx_copybutton",
|
|
"sphinx_markdown_tables",
|
|
"glean",
|
|
]
|
|
|
|
# JSDoc must run successfully for dirs specified, so running
|
|
# tree-wide (the default) will not work currently.
|
|
js_source_path = [
|
|
"../browser/components/extensions",
|
|
"../browser/components/uitour",
|
|
"../testing/marionette",
|
|
"../toolkit/components/extensions",
|
|
"../toolkit/components/extensions/parent",
|
|
"../toolkit/components/featuregates",
|
|
"../toolkit/mozapps/extensions",
|
|
"../toolkit/components/prompts/src",
|
|
]
|
|
root_for_relative_js_paths = ".."
|
|
jsdoc_config_path = "jsdoc.json"
|
|
|
|
templates_path = ["_templates"]
|
|
source_suffix = [".rst", ".md"]
|
|
master_doc = "index"
|
|
project = "Firefox Source Docs"
|
|
html_logo = os.path.join(topsrcdir, "browser/branding/nightly/content/firefox-wordmark.svg")
|
|
html_favicon = os.path.join(topsrcdir, "browser/branding/nightly/firefox.ico")
|
|
|
|
exclude_patterns = ["_build", "_staging", "_venv"]
|
|
pygments_style = "sphinx"
|
|
|
|
# We need to perform some adjustment of the settings and environment
|
|
# when running on Read The Docs.
|
|
on_rtd = os.environ.get("READTHEDOCS", None) == "True"
|
|
|
|
if on_rtd:
|
|
# SHELL isn't set on RTD and mach.mixin.process's import raises if a
|
|
# shell-related environment variable can't be found. Set the variable here
|
|
# to hack us into working on RTD.
|
|
assert "SHELL" not in os.environ
|
|
os.environ["SHELL"] = "/bin/bash"
|
|
else:
|
|
# We only need to set the RTD theme when not on RTD because the RTD
|
|
# environment handles this otherwise.
|
|
import sphinx_rtd_theme
|
|
|
|
html_theme = "sphinx_rtd_theme"
|
|
html_theme_path = [sphinx_rtd_theme.get_html_theme_path()]
|
|
|
|
|
|
html_static_path = ["_static"]
|
|
htmlhelp_basename = "MozillaTreeDocs"
|
|
|
|
moz_project_name = "main"
|
|
|
|
html_show_copyright = False
|
|
|
|
# Only run autosection for the page title.
|
|
# Otherwise, we have a huge number of duplicate links.
|
|
# For example, the page https://firefox-source-docs.mozilla.org/code-quality/lint/
|
|
# is called "Linting"
|
|
# just like https://firefox-source-docs.mozilla.org/remote/CodeStyle.html
|
|
autosectionlabel_maxdepth = 1
|
|
|
|
|
|
def setup(app):
|
|
app.add_config_value(
|
|
"recommonmark_config",
|
|
{
|
|
# Crashes with sphinx
|
|
"enable_inline_math": False,
|
|
# We use it for testing/web-platform/tests
|
|
"enable_eval_rst": True,
|
|
},
|
|
True,
|
|
)
|
|
app.add_stylesheet("custom_theme.css")
|
|
app.add_transform(AutoStructify)
|