2020-02-25 17:03:11 +01:00
|
|
|
import io
|
|
|
|
import os
|
2021-09-16 11:39:26 +02:00
|
|
|
import sys
|
2021-11-23 16:25:09 +08:00
|
|
|
from typing import Any, Dict, List
|
2018-12-03 19:59:09 +01:00
|
|
|
|
2020-02-25 17:03:11 +01:00
|
|
|
import docutils
|
|
|
|
import docutils.parsers.rst
|
2018-12-03 19:59:09 +01:00
|
|
|
|
|
|
|
# -- Project information -----------------------------------------------------
|
|
|
|
|
2020-02-25 17:03:11 +01:00
|
|
|
project = "Tutor"
|
2019-10-17 17:20:22 +02:00
|
|
|
copyright = ""
|
2020-02-25 17:03:11 +01:00
|
|
|
author = "Overhang.io"
|
2018-12-03 19:59:09 +01:00
|
|
|
|
|
|
|
# The short X.Y version
|
2020-02-25 17:03:11 +01:00
|
|
|
version = ""
|
2018-12-03 19:59:09 +01:00
|
|
|
# The full version, including alpha/beta/rc tags
|
2020-02-25 17:03:11 +01:00
|
|
|
release = ""
|
2018-12-03 19:59:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
# -- General configuration ---------------------------------------------------
|
2020-02-25 17:03:11 +01:00
|
|
|
extensions = []
|
|
|
|
templates_path = ["_templates"]
|
|
|
|
source_suffix = ".rst"
|
|
|
|
master_doc = "index"
|
2018-12-03 19:59:09 +01:00
|
|
|
language = None
|
2020-02-25 17:03:11 +01:00
|
|
|
exclude_patterns = ["_build", "Thumbs.db", ".DS_Store"]
|
2018-12-03 19:59:09 +01:00
|
|
|
pygments_style = None
|
|
|
|
|
2022-02-07 18:11:43 +01:00
|
|
|
# Autodocumentation of modules
|
|
|
|
extensions.append("sphinx.ext.autodoc")
|
|
|
|
autodoc_typehints = "description"
|
|
|
|
|
2021-09-16 11:39:26 +02:00
|
|
|
# -- Sphinx-Click configuration
|
|
|
|
# https://sphinx-click.readthedocs.io/
|
2021-11-23 16:25:09 +08:00
|
|
|
extensions.append("sphinx_click")
|
2021-09-16 11:39:26 +02:00
|
|
|
# This is to avoid the addition of the local username to the docs
|
|
|
|
os.environ["HOME"] = "~"
|
|
|
|
# Make sure that sphinx-click can find the tutor module
|
|
|
|
sys.path.append(os.path.join(os.path.dirname(__file__), ".."))
|
2018-12-03 19:59:09 +01:00
|
|
|
|
|
|
|
# -- Options for HTML output -------------------------------------------------
|
2020-02-25 17:03:11 +01:00
|
|
|
html_theme = "sphinx_rtd_theme"
|
2019-10-17 17:20:22 +02:00
|
|
|
html_theme_options = {
|
2020-02-25 17:03:11 +01:00
|
|
|
"logo_only": True,
|
2019-10-17 17:20:22 +02:00
|
|
|
"style_nav_header_background": "#EFEFEF",
|
|
|
|
}
|
|
|
|
html_context = {
|
2020-02-25 17:03:11 +01:00
|
|
|
"display_github": True,
|
|
|
|
"github_user": "overhangio",
|
|
|
|
"github_repo": "tutor",
|
|
|
|
"github_version": "master",
|
|
|
|
"conf_py_path": "/docs/",
|
2019-10-17 17:20:22 +02:00
|
|
|
}
|
2020-02-25 17:03:11 +01:00
|
|
|
html_static_path = ["img"]
|
2018-12-03 19:59:09 +01:00
|
|
|
|
2019-10-17 17:20:22 +02:00
|
|
|
# Custom settings
|
|
|
|
html_logo = "./img/tutor-logo.png"
|
2019-10-25 10:53:59 +02:00
|
|
|
html_favicon = "./img/favicon.png"
|
2019-10-17 17:20:22 +02:00
|
|
|
html_show_sourcelink = False
|
|
|
|
html_display_github = True
|
|
|
|
html_show_sphinx = False
|
|
|
|
html_github_user = "overhangio"
|
|
|
|
html_github_repo = "tutor"
|
|
|
|
# Images do not link to themselves
|
|
|
|
html_scaled_image_link = False
|
|
|
|
html_show_copyright = False
|
2018-12-03 19:59:09 +01:00
|
|
|
|
2019-04-22 13:29:53 +02:00
|
|
|
# Custom variables
|
|
|
|
here = os.path.abspath(os.path.dirname(__file__))
|
2021-11-23 16:25:09 +08:00
|
|
|
about: Dict[str, str] = {}
|
2020-02-25 17:02:39 +01:00
|
|
|
with io.open(
|
|
|
|
os.path.join(here, "..", "tutor", "__about__.py"), "rt", encoding="utf-8"
|
|
|
|
) as f:
|
2019-04-22 13:29:53 +02:00
|
|
|
exec(f.read(), about)
|
|
|
|
rst_prolog = """
|
|
|
|
.. |tutor_version| replace:: {}
|
|
|
|
""".format(
|
2020-02-25 17:02:39 +01:00
|
|
|
about["__version__"],
|
2019-04-22 13:29:53 +02:00
|
|
|
)
|
2020-02-25 17:02:39 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Custom directives
|
|
|
|
def youtube(
|
2021-11-23 16:25:09 +08:00
|
|
|
_name: Any,
|
|
|
|
_args: Any,
|
|
|
|
_options: Any,
|
|
|
|
content: List[str],
|
|
|
|
_lineno: Any,
|
|
|
|
_contentOffset: Any,
|
|
|
|
_blockText: Any,
|
|
|
|
_state: Any,
|
|
|
|
_stateMachine: Any,
|
|
|
|
) -> Any:
|
|
|
|
"""Restructured text extension for inserting youtube embedded videos"""
|
2020-02-25 17:02:39 +01:00
|
|
|
if not content:
|
|
|
|
return []
|
|
|
|
video_id = content[0]
|
|
|
|
return [
|
|
|
|
docutils.nodes.raw(
|
|
|
|
"",
|
|
|
|
"""
|
|
|
|
<iframe width="560" height="315"
|
|
|
|
src="https://www.youtube-nocookie.com/embed/{video_id}"
|
|
|
|
frameborder="0"
|
|
|
|
allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen>
|
|
|
|
</iframe>""".format(
|
|
|
|
video_id=video_id
|
|
|
|
),
|
|
|
|
format="html",
|
|
|
|
)
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2022-02-07 18:11:43 +01:00
|
|
|
# Tutor's own extension
|
|
|
|
sys.path.append(os.path.join(os.path.dirname(__file__), "_ext"))
|
|
|
|
extensions.append("tutordocs")
|
|
|
|
|
|
|
|
|
|
|
|
setattr(youtube, "content", True)
|
|
|
|
docutils.parsers.rst.directives.register_directive("youtube", youtube) # type: ignore
|