Hasan Iqbal
commited on
Added documentation initial skeleton
Browse files- .gitignore +2 -0
- assets/splash.png +0 -0
- docs/Makefile +20 -0
- docs/make.bat +35 -0
- docs/src/_extension/component_directive.py +99 -0
- docs/src/_extension/gallery_directive.py +144 -0
- docs/src/_static/android-chrome-192x192.png +0 -0
- docs/src/_static/android-chrome-512x512.png +0 -0
- docs/src/_static/apple-touch-icon.png +0 -0
- docs/src/_static/custom-icons.js +16 -0
- docs/src/_static/favicon-16x16.png +0 -0
- docs/src/_static/favicon-32x32.png +0 -0
- docs/src/_static/favicon.ico +0 -0
- docs/src/_static/favicon.png +0 -0
- docs/src/_static/favicon.svg +48 -0
- docs/src/_static/logo/logo.svg +95 -0
- docs/src/_static/logo/logo_dark.svg +95 -0
- docs/src/_static/logo/logo_light.svg +96 -0
- docs/src/_static/versions.json +12 -0
- docs/src/api/index.md +1 -0
- docs/src/conf.py +303 -0
- docs/src/index.md +36 -0
- docs/src/usage/index.md +1 -0
- docs/versions.py +42 -0
- pyproject.toml +14 -0
- readthedocs.yaml +38 -0
.gitignore
CHANGED
@@ -10,6 +10,8 @@ ignore.*.tfvars
|
|
10 |
.vscode/
|
11 |
|
12 |
# Project Specific
|
|
|
|
|
13 |
DEVNOTES
|
14 |
tmp/
|
15 |
dev*.json
|
|
|
10 |
.vscode/
|
11 |
|
12 |
# Project Specific
|
13 |
+
/logo/
|
14 |
+
/favicon/
|
15 |
DEVNOTES
|
16 |
tmp/
|
17 |
dev*.json
|
assets/splash.png
CHANGED
docs/Makefile
ADDED
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# Minimal makefile for Sphinx documentation
|
2 |
+
#
|
3 |
+
|
4 |
+
# You can set these variables from the command line, and also
|
5 |
+
# from the environment for the first two.
|
6 |
+
SPHINXOPTS ?=
|
7 |
+
SPHINXBUILD ?= sphinx-build
|
8 |
+
SOURCEDIR = src
|
9 |
+
BUILDDIR = build
|
10 |
+
|
11 |
+
# Put it first so that "make" without argument is like "make help".
|
12 |
+
help:
|
13 |
+
@$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
|
14 |
+
|
15 |
+
.PHONY: help Makefile
|
16 |
+
|
17 |
+
# Catch-all target: route all unknown targets to Sphinx using the new
|
18 |
+
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS).
|
19 |
+
%: Makefile
|
20 |
+
@$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
|
docs/make.bat
ADDED
@@ -0,0 +1,35 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@ECHO OFF
|
2 |
+
|
3 |
+
pushd %~dp0
|
4 |
+
|
5 |
+
REM Command file for Sphinx documentation
|
6 |
+
|
7 |
+
if "%SPHINXBUILD%" == "" (
|
8 |
+
set SPHINXBUILD=sphinx-build
|
9 |
+
)
|
10 |
+
set SOURCEDIR=src
|
11 |
+
set BUILDDIR=build
|
12 |
+
|
13 |
+
%SPHINXBUILD% >NUL 2>NUL
|
14 |
+
if errorlevel 9009 (
|
15 |
+
echo.
|
16 |
+
echo.The 'sphinx-build' command was not found. Make sure you have Sphinx
|
17 |
+
echo.installed, then set the SPHINXBUILD environment variable to point
|
18 |
+
echo.to the full path of the 'sphinx-build' executable. Alternatively you
|
19 |
+
echo.may add the Sphinx directory to PATH.
|
20 |
+
echo.
|
21 |
+
echo.If you don't have Sphinx installed, grab it from
|
22 |
+
echo.https://www.sphinx-doc.org/
|
23 |
+
exit /b 1
|
24 |
+
)
|
25 |
+
|
26 |
+
if "%1" == "" goto help
|
27 |
+
|
28 |
+
%SPHINXBUILD% -M %1 %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O%
|
29 |
+
goto end
|
30 |
+
|
31 |
+
:help
|
32 |
+
%SPHINXBUILD% -M help %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O%
|
33 |
+
|
34 |
+
:end
|
35 |
+
popd
|
docs/src/_extension/component_directive.py
ADDED
@@ -0,0 +1,99 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""A directive to generate the list of all the built-in components.
|
2 |
+
|
3 |
+
Read the content of the component folder and generate a list of all the components.
|
4 |
+
This list will display some informations about the component and a link to the
|
5 |
+
GitHub file.
|
6 |
+
"""
|
7 |
+
|
8 |
+
import re
|
9 |
+
from pathlib import Path
|
10 |
+
from typing import Any, Dict, List
|
11 |
+
|
12 |
+
from docutils import nodes
|
13 |
+
from sphinx.application import Sphinx
|
14 |
+
from sphinx.util import logging
|
15 |
+
from sphinx.util.docutils import SphinxDirective
|
16 |
+
|
17 |
+
logger = logging.getLogger(__name__)
|
18 |
+
|
19 |
+
|
20 |
+
class ComponentListDirective(SphinxDirective):
|
21 |
+
"""A directive to generate the list of all the built-in components.
|
22 |
+
|
23 |
+
Read the content of the component folder and generate a list of all the components.
|
24 |
+
This list will display some informations about the component and a link to the
|
25 |
+
GitHub file.
|
26 |
+
"""
|
27 |
+
|
28 |
+
name = "component-list"
|
29 |
+
has_content = True
|
30 |
+
required_arguments = 0
|
31 |
+
optional_arguments = 0
|
32 |
+
final_argument_whitespace = True
|
33 |
+
|
34 |
+
def run(self) -> List[nodes.Node]:
|
35 |
+
"""Create the list."""
|
36 |
+
# get the list of all th jinja templates
|
37 |
+
# not that to remain compatible with sphinx they are labeled as html files
|
38 |
+
root = Path(__file__).parents[2]
|
39 |
+
component_dir = (
|
40 |
+
root
|
41 |
+
/ "src"
|
42 |
+
/ "pydata_sphinx_theme"
|
43 |
+
/ "theme"
|
44 |
+
/ "pydata_sphinx_theme"
|
45 |
+
/ "components"
|
46 |
+
)
|
47 |
+
if not component_dir.is_dir():
|
48 |
+
raise FileNotFoundError(
|
49 |
+
f"Could not find component folder at {component_dir}."
|
50 |
+
)
|
51 |
+
components = sorted(component_dir.glob("*.html"))
|
52 |
+
|
53 |
+
# create the list of all the components description using bs4
|
54 |
+
# at the moment we use dummy information
|
55 |
+
docs = []
|
56 |
+
pattern = re.compile(r"(?<={#).*?(?=#})", flags=re.DOTALL)
|
57 |
+
for c in components:
|
58 |
+
comment = pattern.findall(c.read_text())
|
59 |
+
docs.append(comment[0].strip() if comment else "No description available.")
|
60 |
+
|
61 |
+
# get the urls from the github repo latest branch
|
62 |
+
github_url = "https://github.com/pydata/pydata-sphinx-theme/blob/main"
|
63 |
+
urls = [
|
64 |
+
f"{github_url}/{component.relative_to(root)}" for component in components
|
65 |
+
]
|
66 |
+
|
67 |
+
# build the list of all the components
|
68 |
+
items = []
|
69 |
+
for component, url, doc in zip(components, urls, docs):
|
70 |
+
items.append(
|
71 |
+
nodes.list_item(
|
72 |
+
"",
|
73 |
+
nodes.paragraph(
|
74 |
+
"",
|
75 |
+
"",
|
76 |
+
nodes.reference("", component.stem, internal=False, refuri=url),
|
77 |
+
nodes.Text(f": {doc}"),
|
78 |
+
),
|
79 |
+
)
|
80 |
+
)
|
81 |
+
|
82 |
+
return [nodes.bullet_list("", *items)]
|
83 |
+
|
84 |
+
|
85 |
+
def setup(app: Sphinx) -> Dict[str, Any]:
|
86 |
+
"""Add custom configuration to sphinx app.
|
87 |
+
|
88 |
+
Args:
|
89 |
+
app: the Sphinx application
|
90 |
+
|
91 |
+
Returns:
|
92 |
+
the 2 parallel parameters set to ``True``.
|
93 |
+
"""
|
94 |
+
app.add_directive("component-list", ComponentListDirective)
|
95 |
+
|
96 |
+
return {
|
97 |
+
"parallel_read_safe": True,
|
98 |
+
"parallel_write_safe": True,
|
99 |
+
}
|
docs/src/_extension/gallery_directive.py
ADDED
@@ -0,0 +1,144 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""A directive to generate a gallery of images from structured data.
|
2 |
+
|
3 |
+
Generating a gallery of images that are all the same size is a common
|
4 |
+
pattern in documentation, and this can be cumbersome if the gallery is
|
5 |
+
generated programmatically. This directive wraps this particular use-case
|
6 |
+
in a helper-directive to generate it with a single YAML configuration file.
|
7 |
+
|
8 |
+
It currently exists for maintainers of the pydata-sphinx-theme,
|
9 |
+
but might be abstracted into a standalone package if it proves useful.
|
10 |
+
"""
|
11 |
+
|
12 |
+
from pathlib import Path
|
13 |
+
from typing import Any, ClassVar, Dict, List
|
14 |
+
|
15 |
+
from docutils import nodes
|
16 |
+
from docutils.parsers.rst import directives
|
17 |
+
from sphinx.application import Sphinx
|
18 |
+
from sphinx.util import logging
|
19 |
+
from sphinx.util.docutils import SphinxDirective
|
20 |
+
from yaml import safe_load
|
21 |
+
|
22 |
+
logger = logging.getLogger(__name__)
|
23 |
+
|
24 |
+
|
25 |
+
TEMPLATE_GRID = """
|
26 |
+
`````{{grid}} {columns}
|
27 |
+
{options}
|
28 |
+
|
29 |
+
{content}
|
30 |
+
|
31 |
+
`````
|
32 |
+
"""
|
33 |
+
|
34 |
+
GRID_CARD = """
|
35 |
+
````{{grid-item-card}} {title}
|
36 |
+
{options}
|
37 |
+
|
38 |
+
{content}
|
39 |
+
````
|
40 |
+
"""
|
41 |
+
|
42 |
+
|
43 |
+
class GalleryGridDirective(SphinxDirective):
|
44 |
+
"""A directive to show a gallery of images and links in a Bootstrap grid.
|
45 |
+
|
46 |
+
The grid can be generated from a YAML file that contains a list of items, or
|
47 |
+
from the content of the directive (also formatted in YAML). Use the parameter
|
48 |
+
"class-card" to add an additional CSS class to all cards. When specifying the grid
|
49 |
+
items, you can use all parameters from "grid-item-card" directive to customize
|
50 |
+
individual cards + ["image", "header", "content", "title"].
|
51 |
+
|
52 |
+
Danger:
|
53 |
+
This directive can only be used in the context of a Myst documentation page as
|
54 |
+
the templates use Markdown flavored formatting.
|
55 |
+
"""
|
56 |
+
|
57 |
+
name = "gallery-grid"
|
58 |
+
has_content = True
|
59 |
+
required_arguments = 0
|
60 |
+
optional_arguments = 1
|
61 |
+
final_argument_whitespace = True
|
62 |
+
option_spec: ClassVar[dict[str, Any]] = {
|
63 |
+
# A class to be added to the resulting container
|
64 |
+
"grid-columns": directives.unchanged,
|
65 |
+
"class-container": directives.unchanged,
|
66 |
+
"class-card": directives.unchanged,
|
67 |
+
}
|
68 |
+
|
69 |
+
def run(self) -> List[nodes.Node]:
|
70 |
+
"""Create the gallery grid."""
|
71 |
+
if self.arguments:
|
72 |
+
# If an argument is given, assume it's a path to a YAML file
|
73 |
+
# Parse it and load it into the directive content
|
74 |
+
path_data_rel = Path(self.arguments[0])
|
75 |
+
path_doc, _ = self.get_source_info()
|
76 |
+
path_doc = Path(path_doc).parent
|
77 |
+
path_data = (path_doc / path_data_rel).resolve()
|
78 |
+
if not path_data.exists():
|
79 |
+
logger.info(f"Could not find grid data at {path_data}.")
|
80 |
+
nodes.text("No grid data found at {path_data}.")
|
81 |
+
return
|
82 |
+
yaml_string = path_data.read_text()
|
83 |
+
else:
|
84 |
+
yaml_string = "\n".join(self.content)
|
85 |
+
|
86 |
+
# Use all the element with an img-bottom key as sites to show
|
87 |
+
# and generate a card item for each of them
|
88 |
+
grid_items = []
|
89 |
+
for item in safe_load(yaml_string):
|
90 |
+
# remove parameters that are not needed for the card options
|
91 |
+
title = item.pop("title", "")
|
92 |
+
|
93 |
+
# build the content of the card using some extra parameters
|
94 |
+
header = f"{item.pop('header')} \n^^^ \n" if "header" in item else ""
|
95 |
+
image = f"![image]({item.pop('image')}) \n" if "image" in item else ""
|
96 |
+
content = f"{item.pop('content')} \n" if "content" in item else ""
|
97 |
+
|
98 |
+
# optional parameter that influence all cards
|
99 |
+
if "class-card" in self.options:
|
100 |
+
item["class-card"] = self.options["class-card"]
|
101 |
+
|
102 |
+
loc_options_str = "\n".join(f":{k}: {v}" for k, v in item.items()) + " \n"
|
103 |
+
|
104 |
+
card = GRID_CARD.format(
|
105 |
+
options=loc_options_str, content=header + image + content, title=title
|
106 |
+
)
|
107 |
+
grid_items.append(card)
|
108 |
+
|
109 |
+
# Parse the template with Sphinx Design to create an output container
|
110 |
+
# Prep the options for the template grid
|
111 |
+
class_ = "gallery-directive" + f' {self.options.get("class-container", "")}'
|
112 |
+
options = {"gutter": 2, "class-container": class_}
|
113 |
+
options_str = "\n".join(f":{k}: {v}" for k, v in options.items())
|
114 |
+
|
115 |
+
# Create the directive string for the grid
|
116 |
+
grid_directive = TEMPLATE_GRID.format(
|
117 |
+
columns=self.options.get("grid-columns", "1 2 3 4"),
|
118 |
+
options=options_str,
|
119 |
+
content="\n".join(grid_items),
|
120 |
+
)
|
121 |
+
|
122 |
+
# Parse content as a directive so Sphinx Design processes it
|
123 |
+
container = nodes.container()
|
124 |
+
self.state.nested_parse([grid_directive], 0, container)
|
125 |
+
|
126 |
+
# Sphinx Design outputs a container too, so just use that
|
127 |
+
return [container.children[0]]
|
128 |
+
|
129 |
+
|
130 |
+
def setup(app: Sphinx) -> Dict[str, Any]:
|
131 |
+
"""Add custom configuration to sphinx app.
|
132 |
+
|
133 |
+
Args:
|
134 |
+
app: the Sphinx application
|
135 |
+
|
136 |
+
Returns:
|
137 |
+
the 2 parallel parameters set to ``True``.
|
138 |
+
"""
|
139 |
+
app.add_directive("gallery-grid", GalleryGridDirective)
|
140 |
+
|
141 |
+
return {
|
142 |
+
"parallel_read_safe": True,
|
143 |
+
"parallel_write_safe": True,
|
144 |
+
}
|
docs/src/_static/android-chrome-192x192.png
ADDED
docs/src/_static/android-chrome-512x512.png
ADDED
docs/src/_static/apple-touch-icon.png
ADDED
docs/src/_static/custom-icons.js
ADDED
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
/*******************************************************************************
|
2 |
+
* Set a custom icon for pypi as it's not available in the fa built-in brands
|
3 |
+
*/
|
4 |
+
FontAwesome.library.add(
|
5 |
+
(faListOldStyle = {
|
6 |
+
prefix: "fa-custom",
|
7 |
+
iconName: "pypi",
|
8 |
+
icon: [
|
9 |
+
17.313, // viewBox width
|
10 |
+
19.807, // viewBox height
|
11 |
+
[], // ligature
|
12 |
+
"e001", // unicode codepoint - private use area
|
13 |
+
"m10.383 0.2-3.239 1.1769 3.1883 1.1614 3.239-1.1798zm-3.4152 1.2411-3.2362 1.1769 3.1855 1.1614 3.2369-1.1769zm6.7177 0.00281-3.2947 1.2009v3.8254l3.2947-1.1988zm-3.4145 1.2439-3.2926 1.1981v3.8254l0.17548-0.064132 3.1171-1.1347zm-6.6564 0.018325v3.8247l3.244 1.1805v-3.8254zm10.191 0.20931v2.3137l3.1777-1.1558zm3.2947 1.2425-3.2947 1.1988v3.8254l3.2947-1.1988zm-8.7058 0.45739c0.00929-1.931e-4 0.018327-2.977e-4 0.027485 0 0.25633 0.00851 0.4263 0.20713 0.42638 0.49826 1.953e-4 0.38532-0.29327 0.80469-0.65542 0.93662-0.36226 0.13215-0.65608-0.073306-0.65613-0.4588-6.28e-5 -0.38556 0.2938-0.80504 0.65613-0.93662 0.068422-0.024919 0.13655-0.038114 0.20156-0.039466zm5.2913 0.78369-3.2947 1.1988v3.8247l3.2947-1.1981zm-10.132 1.239-3.2362 1.1769 3.1883 1.1614 3.2362-1.1769zm6.7177 0.00213-3.2926 1.2016v3.8247l3.2926-1.2009zm-3.4124 1.2439-3.2947 1.1988v3.8254l3.2947-1.1988zm-6.6585 0.016195v3.8275l3.244 1.1805v-3.8254zm16.9 0.21143-3.2947 1.1988v3.8247l3.2947-1.1981zm-3.4145 1.2411-3.2926 1.2016v3.8247l3.2926-1.2009zm-3.4145 1.2411-3.2926 1.2016v3.8247l3.2926-1.2009zm-3.4124 1.2432-3.2947 1.1988v3.8254l3.2947-1.1988zm-6.6585 0.019027v3.8247l3.244 1.1805v-3.8254zm13.485 1.4497-3.2947 1.1988v3.8247l3.2947-1.1981zm-3.4145 1.2411-3.2926 1.2016v3.8247l3.2926-1.2009zm2.4018 0.38127c0.0093-1.83e-4 0.01833-3.16e-4 0.02749 0 0.25633 0.0085 0.4263 0.20713 0.42638 0.49826 1.97e-4 0.38532-0.29327 0.80469-0.65542 0.93662-0.36188 0.1316-0.65525-0.07375-0.65542-0.4588-1.95e-4 -0.38532 0.29328-0.80469 0.65542-0.93662 0.06842-0.02494 0.13655-0.03819 0.20156-0.03947zm-5.8142 0.86403-3.244 1.1805v1.4201l3.244 1.1805z", // svg path (https://simpleicons.org/icons/pypi.svg)
|
14 |
+
],
|
15 |
+
}),
|
16 |
+
);
|
docs/src/_static/favicon-16x16.png
ADDED
docs/src/_static/favicon-32x32.png
ADDED
docs/src/_static/favicon.ico
ADDED
docs/src/_static/favicon.png
ADDED
docs/src/_static/favicon.svg
ADDED
docs/src/_static/logo/logo.svg
ADDED
docs/src/_static/logo/logo_dark.svg
ADDED
docs/src/_static/logo/logo_light.svg
ADDED
docs/src/_static/versions.json
ADDED
@@ -0,0 +1,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
[
|
2 |
+
{
|
3 |
+
"version": "dev",
|
4 |
+
"url": "https://openfactcheck.readthedocs.io/en/latest/"
|
5 |
+
},
|
6 |
+
{
|
7 |
+
"name": "0.2.2 (stable)",
|
8 |
+
"version": "v0.2.2",
|
9 |
+
"url": "https://openfactcheck.readthedocs.io/en/stable/",
|
10 |
+
"preferred": true
|
11 |
+
}
|
12 |
+
]
|
docs/src/api/index.md
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
# API Reference
|
docs/src/conf.py
ADDED
@@ -0,0 +1,303 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""Configuration file for the Sphinx documentation builder.
|
2 |
+
|
3 |
+
This file only contains a selection of the most common options. For a full
|
4 |
+
list see the documentation:
|
5 |
+
https://www.sphinx-doc.org/en/master/usage/configuration.html
|
6 |
+
"""
|
7 |
+
|
8 |
+
# -- Path setup --------------------------------------------------------------
|
9 |
+
import os
|
10 |
+
import sys
|
11 |
+
from pathlib import Path
|
12 |
+
from typing import Any, Dict
|
13 |
+
|
14 |
+
import openfactcheck
|
15 |
+
from sphinx.application import Sphinx
|
16 |
+
from sphinx.locale import _
|
17 |
+
|
18 |
+
sys.path.append(str(Path(".").resolve()))
|
19 |
+
|
20 |
+
# -- Project information -----------------------------------------------------
|
21 |
+
|
22 |
+
project = 'OpenFactCheck'
|
23 |
+
copyright = '2024, MBZUAI'
|
24 |
+
author = 'OpenFactCheck Team and Contributors'
|
25 |
+
|
26 |
+
# -- General configuration ---------------------------------------------------
|
27 |
+
|
28 |
+
extensions = [
|
29 |
+
"sphinx.ext.napoleon",
|
30 |
+
"sphinx.ext.autodoc",
|
31 |
+
"sphinx.ext.autosummary",
|
32 |
+
"sphinx.ext.todo",
|
33 |
+
"sphinx.ext.viewcode",
|
34 |
+
"sphinx.ext.intersphinx",
|
35 |
+
"sphinx.ext.graphviz",
|
36 |
+
"sphinxext.rediraffe",
|
37 |
+
"sphinx_design",
|
38 |
+
"sphinx_copybutton",
|
39 |
+
"sphinx_togglebutton",
|
40 |
+
"sphinx_favicon",
|
41 |
+
"myst_parser",
|
42 |
+
#"autoapi.extension",
|
43 |
+
#"ablog",
|
44 |
+
#"jupyter_sphinx",
|
45 |
+
#"sphinxcontrib.youtube",
|
46 |
+
#"nbsphinx",
|
47 |
+
#"numpydoc",
|
48 |
+
#"jupyterlite_sphinx",
|
49 |
+
|
50 |
+
# -- Custom configuration ---------------------------------------------------
|
51 |
+
"_extension.gallery_directive",
|
52 |
+
"_extension.component_directive",
|
53 |
+
]
|
54 |
+
|
55 |
+
# jupyterlite_config = "jupyterlite_config.json"
|
56 |
+
|
57 |
+
# Add any paths that contain templates here, relative to this directory.
|
58 |
+
templates_path = ["_templates"]
|
59 |
+
|
60 |
+
# List of patterns, relative to source directory, that match files and
|
61 |
+
# directories to ignore when looking for source files.
|
62 |
+
# This pattern also affects html_static_path and html_extra_path.
|
63 |
+
exclude_patterns = ["_build", "Thumbs.db", ".DS_Store", "**.ipynb_checkpoints"]
|
64 |
+
|
65 |
+
intersphinx_mapping = {"sphinx": ("https://www.sphinx-doc.org/en/master", None)}
|
66 |
+
|
67 |
+
# -- Sitemap -----------------------------------------------------------------
|
68 |
+
|
69 |
+
# ReadTheDocs has its own way of generating sitemaps, etc.
|
70 |
+
if not os.environ.get("READTHEDOCS"):
|
71 |
+
extensions += ["sphinx_sitemap"]
|
72 |
+
|
73 |
+
html_baseurl = os.environ.get("SITEMAP_URL_BASE", "http://127.0.0.1:8000/")
|
74 |
+
sitemap_locales = [None]
|
75 |
+
sitemap_url_scheme = "{link}"
|
76 |
+
|
77 |
+
# -- MyST options ------------------------------------------------------------
|
78 |
+
|
79 |
+
# This allows us to use ::: to denote directives, useful for admonitions
|
80 |
+
# myst_enable_extensions = ["colon_fence", "linkify", "substitution"]
|
81 |
+
# myst_heading_anchors = 2
|
82 |
+
# myst_substitutions = {"rtd": "[Read the Docs](https://readthedocs.org/)"}
|
83 |
+
|
84 |
+
# -- Internationalization ----------------------------------------------------
|
85 |
+
|
86 |
+
# specifying the natural language populates some key tags
|
87 |
+
language = "en"
|
88 |
+
|
89 |
+
# -- Ablog options -----------------------------------------------------------
|
90 |
+
|
91 |
+
# blog_path = "examples/blog/index"
|
92 |
+
# blog_authors = {
|
93 |
+
# "pydata": ("PyData", "https://pydata.org"),
|
94 |
+
# "jupyter": ("Jupyter", "https://jupyter.org"),
|
95 |
+
# }
|
96 |
+
|
97 |
+
# -- sphinx_ext_graphviz options ---------------------------------------------
|
98 |
+
|
99 |
+
graphviz_output_format = "svg"
|
100 |
+
inheritance_graph_attrs = dict(
|
101 |
+
rankdir="LR",
|
102 |
+
fontsize=14,
|
103 |
+
ratio="compress",
|
104 |
+
)
|
105 |
+
|
106 |
+
# -- sphinx_togglebutton options ---------------------------------------------
|
107 |
+
togglebutton_hint = str(_("Click to expand"))
|
108 |
+
togglebutton_hint_hide = str(_("Click to collapse"))
|
109 |
+
|
110 |
+
# -- Sphinx-copybutton options ---------------------------------------------
|
111 |
+
# Exclude copy button from appearing over notebook cell numbers by using :not()
|
112 |
+
# The default copybutton selector is `div.highlight pre`
|
113 |
+
# https://github.com/executablebooks/sphinx-copybutton/blob/master/sphinx_copybutton/__init__.py#L82
|
114 |
+
copybutton_selector = ":not(.prompt) > div.highlight pre"
|
115 |
+
|
116 |
+
# -- Options for HTML output -------------------------------------------------
|
117 |
+
|
118 |
+
html_theme = "pydata_sphinx_theme"
|
119 |
+
html_logo = "_static/logo/logo.svg"
|
120 |
+
html_favicon = "_static/favicon.svg"
|
121 |
+
html_sourcelink_suffix = ""
|
122 |
+
html_last_updated_fmt = "" # to reveal the build date in the pages meta
|
123 |
+
|
124 |
+
# Define the json_url for our version switcher.
|
125 |
+
json_url = "https://openfactcheck.readthedocs.io/en/latest/_static/versions.json"
|
126 |
+
|
127 |
+
# Define the version we use for matching in the version switcher.
|
128 |
+
version_match = os.environ.get("READTHEDOCS_VERSION")
|
129 |
+
release = openfactcheck.__version__
|
130 |
+
# If READTHEDOCS_VERSION doesn't exist, we're not on RTD
|
131 |
+
# If it is an integer, we're in a PR build and the version isn't correct.
|
132 |
+
# If it's "latest" → change to "dev" (that's what we want the switcher to call it)
|
133 |
+
if not version_match or version_match.isdigit() or version_match == "latest":
|
134 |
+
# For local development, infer the version to match from the package.
|
135 |
+
if "dev" in release or "rc" in release:
|
136 |
+
version_match = "dev"
|
137 |
+
# We want to keep the relative reference if we are in dev mode
|
138 |
+
# but we want the whole url if we are effectively in a released version
|
139 |
+
json_url = "_static/switcher.json"
|
140 |
+
else:
|
141 |
+
version_match = f"v{release}"
|
142 |
+
elif version_match == "stable":
|
143 |
+
version_match = f"v{release}"
|
144 |
+
|
145 |
+
html_theme_options = {
|
146 |
+
"external_links": [],
|
147 |
+
"header_links_before_dropdown": 4,
|
148 |
+
"icon_links": [
|
149 |
+
{
|
150 |
+
"name": "GitHub",
|
151 |
+
"url": "https://github.com/hasaniqbal777/openfactcheck",
|
152 |
+
"icon": "fa-brands fa-github",
|
153 |
+
},
|
154 |
+
{
|
155 |
+
"name": "PyPI",
|
156 |
+
"url": "https://pypi.org/project/openfactcheck",
|
157 |
+
"icon": "fa-custom fa-pypi",
|
158 |
+
},
|
159 |
+
{
|
160 |
+
"name": "HuggingFace Space",
|
161 |
+
"url": "https://huggingface.co/spaces/hasaniqbal777/OpenFactCheck",
|
162 |
+
"icon": "fa-solid fa-rocket",
|
163 |
+
},
|
164 |
+
],
|
165 |
+
# alternative way to set twitter and github header icons
|
166 |
+
# "github_url": "https://github.com/hasaniqbal777/openfactcheck",
|
167 |
+
# "twitter_url": "https://twitter.com/hasaniqbal777",
|
168 |
+
"logo": {
|
169 |
+
"image_light": "_static/logo/logo_dark.svg",
|
170 |
+
"image_dark": "_static/logo/logo_light.svg",
|
171 |
+
},
|
172 |
+
"use_edit_page_button": True,
|
173 |
+
"show_toc_level": 1,
|
174 |
+
"navbar_align": "left", # [left, content, right] For testing that the navbar items align properly
|
175 |
+
# "show_nav_level": 2,
|
176 |
+
# "announcement": "https://raw.githubusercontent.com/pydata/pydata-sphinx-theme/main/docs/_templates/custom-template.html",
|
177 |
+
# "show_version_warning_banner": True,
|
178 |
+
# "navbar_center": ["navbar-nav"],
|
179 |
+
# "navbar_start": ["navbar-logo"],
|
180 |
+
"navbar_end": ["version-switcher", "theme-switcher", "navbar-icon-links"],
|
181 |
+
#"navbar_persistent": ["search-button"],
|
182 |
+
"primary_sidebar_end": ["sidebar-ethical-ads"],
|
183 |
+
# "article_footer_items": ["test", "test"],
|
184 |
+
# "content_footer_items": ["test", "test"],
|
185 |
+
"footer_start": ["copyright"],
|
186 |
+
#"footer_left": ["sphinx-version"],
|
187 |
+
"secondary_sidebar_items": {
|
188 |
+
"**/*": ["page-toc", "edit-this-page", "sourcelink"],
|
189 |
+
"examples/no-sidebar": [],
|
190 |
+
},
|
191 |
+
"switcher": {
|
192 |
+
"json_url": json_url,
|
193 |
+
"version_match": version_match,
|
194 |
+
},
|
195 |
+
"back_to_top_button": False,
|
196 |
+
}
|
197 |
+
|
198 |
+
|
199 |
+
html_sidebars = {
|
200 |
+
"community/index": [
|
201 |
+
"sidebar-nav-bs",
|
202 |
+
"custom-template",
|
203 |
+
], # This ensures we test for custom sidebars
|
204 |
+
"examples/no-sidebar": [], # Test what page looks like with no sidebar items
|
205 |
+
"examples/persistent-search-field": ["search-field"],
|
206 |
+
# Blog sidebars
|
207 |
+
# ref: https://ablog.readthedocs.io/manual/ablog-configuration-options/#blog-sidebars
|
208 |
+
"examples/blog/*": [
|
209 |
+
"ablog/postcard.html",
|
210 |
+
"ablog/recentposts.html",
|
211 |
+
"ablog/tagcloud.html",
|
212 |
+
"ablog/categories.html",
|
213 |
+
"ablog/authors.html",
|
214 |
+
"ablog/languages.html",
|
215 |
+
"ablog/locations.html",
|
216 |
+
"ablog/archives.html",
|
217 |
+
],
|
218 |
+
}
|
219 |
+
|
220 |
+
html_context = {
|
221 |
+
"github_user": "hasaniqbal777",
|
222 |
+
"github_repo": "openfactcheck",
|
223 |
+
"github_version": "main",
|
224 |
+
"doc_path": "docs",
|
225 |
+
}
|
226 |
+
|
227 |
+
# Add any paths that contain custom static files (such as style sheets) here,
|
228 |
+
# relative to this directory. They are copied after the builtin static files,
|
229 |
+
# so a file named "default.css" will overwrite the builtin "default.css".
|
230 |
+
html_static_path = ["_static"]
|
231 |
+
html_css_files = ["custom.css"]
|
232 |
+
html_js_files = ["custom-icons.js"]
|
233 |
+
todo_include_todos = True
|
234 |
+
|
235 |
+
# -- rediraffe options -------------------------------------------------------
|
236 |
+
rediraffe_redirects = {}
|
237 |
+
|
238 |
+
# -- favicon options ---------------------------------------------------------
|
239 |
+
|
240 |
+
# see https://sphinx-favicon.readthedocs.io for more information about the
|
241 |
+
# sphinx-favicon extension
|
242 |
+
favicons = [
|
243 |
+
# generic icons compatible with most browsers
|
244 |
+
"favicon-32x32.png",
|
245 |
+
"favicon-16x16.png",
|
246 |
+
{"rel": "shortcut icon", "sizes": "any", "href": "favicon.ico"},
|
247 |
+
# chrome specific
|
248 |
+
"android-chrome-192x192.png",
|
249 |
+
"android-chrome-512x512.png",
|
250 |
+
# apple icons
|
251 |
+
{"rel": "mask-icon", "href": "favicon.svg"},
|
252 |
+
{"rel": "apple-touch-icon", "href": "apple-touch-icon.png"}
|
253 |
+
]
|
254 |
+
|
255 |
+
# -- Options for autosummary/autodoc output ------------------------------------
|
256 |
+
# autosummary_generate = True
|
257 |
+
# autodoc_typehints = "description"
|
258 |
+
# autodoc_member_order = "groupwise"
|
259 |
+
|
260 |
+
# -- Options for autoapi -------------------------------------------------------
|
261 |
+
# autoapi_type = "python"
|
262 |
+
# autoapi_dirs = ["../../src/openfactcheck"]
|
263 |
+
# autoapi_keep_files = True
|
264 |
+
# autoapi_root = "api"
|
265 |
+
# autoapi_member_order = "groupwise"
|
266 |
+
|
267 |
+
# -- application setup -------------------------------------------------------
|
268 |
+
|
269 |
+
|
270 |
+
def setup_to_main(
|
271 |
+
app: Sphinx, pagename: str, templatename: str, context, doctree
|
272 |
+
) -> None:
|
273 |
+
"""Add a function that jinja can access for returning an "edit this page" link pointing to `main`."""
|
274 |
+
|
275 |
+
def to_main(link: str) -> str:
|
276 |
+
"""Transform "edit on github" links and make sure they always point to the main branch.
|
277 |
+
|
278 |
+
Args:
|
279 |
+
link: the link to the github edit interface
|
280 |
+
|
281 |
+
Returns:
|
282 |
+
the link to the tip of the main branch for the same file
|
283 |
+
"""
|
284 |
+
links = link.split("/")
|
285 |
+
idx = links.index("edit")
|
286 |
+
return "/".join(links[: idx + 1]) + "/main/" + "/".join(links[idx + 2 :])
|
287 |
+
|
288 |
+
context["to_main"] = to_main
|
289 |
+
|
290 |
+
def setup(app: Sphinx) -> Dict[str, Any]:
|
291 |
+
"""Add custom configuration to sphinx app.
|
292 |
+
|
293 |
+
Args:
|
294 |
+
app: the Sphinx application
|
295 |
+
Returns:
|
296 |
+
the 2 parallel parameters set to ``True``.
|
297 |
+
"""
|
298 |
+
app.connect("html-page-context", setup_to_main)
|
299 |
+
|
300 |
+
return {
|
301 |
+
"parallel_read_safe": True,
|
302 |
+
"parallel_write_safe": True,
|
303 |
+
}
|
docs/src/index.md
ADDED
@@ -0,0 +1,36 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
---
|
2 |
+
myst:
|
3 |
+
html_meta:
|
4 |
+
"description lang=en": |
|
5 |
+
Top-level documentation for openfactcheck, with links to the rest
|
6 |
+
of the site..
|
7 |
+
html_theme.sidebar_secondary.remove: true
|
8 |
+
---
|
9 |
+
|
10 |
+
# OpenFactCheck Documentation
|
11 |
+
|
12 |
+
OpenFactCheck is an open source, Apache-licensed library designed to facilitate the evaluation and enhancement of factuality in responses generated by large language models (LLMs).
|
13 |
+
|
14 |
+
## Installation
|
15 |
+
|
16 |
+
To install OpenFactCheck, run the following command:
|
17 |
+
|
18 |
+
## Usage
|
19 |
+
|
20 |
+
The usage of OpenFactCheck is documented below.
|
21 |
+
|
22 |
+
```{toctree}
|
23 |
+
:maxdepth: 2
|
24 |
+
|
25 |
+
Usage <usage/index>
|
26 |
+
```
|
27 |
+
|
28 |
+
## API
|
29 |
+
|
30 |
+
The content of the exposed `openfactcheck` API is documented below.
|
31 |
+
|
32 |
+
```{toctree}
|
33 |
+
:maxdepth: 2
|
34 |
+
|
35 |
+
API <api/index>
|
36 |
+
```
|
docs/src/usage/index.md
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
# Usage
|
docs/versions.py
ADDED
@@ -0,0 +1,42 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""Module for generating switch.json file."""
|
2 |
+
|
3 |
+
#!/usr/bin/env python3
|
4 |
+
from __future__ import annotations
|
5 |
+
|
6 |
+
import json
|
7 |
+
import os
|
8 |
+
|
9 |
+
ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))
|
10 |
+
WEBSITE_HOME = "https://openfactcheck.readthedocs.io/en/"
|
11 |
+
DOCS_HOME = "docs"
|
12 |
+
DOCS_LATEST = "latest"
|
13 |
+
DOCS_ROOT = os.path.join(ROOT, DOCS_HOME)
|
14 |
+
DOCS_DEST = os.path.join(ROOT, "public")
|
15 |
+
VERSION_FILE = os.path.join(DOCS_ROOT, "src", "_static", "versions.json")
|
16 |
+
|
17 |
+
|
18 |
+
def format_version_entry(version: str) -> dict[str, str]:
|
19 |
+
"""Format a single entry of switcher.json, as expected by `pydata-sphinx-theme`."""
|
20 |
+
return {
|
21 |
+
"url": "/".join((WEBSITE_HOME, version, "")),
|
22 |
+
"version": version,
|
23 |
+
}
|
24 |
+
|
25 |
+
|
26 |
+
def validate_docs_folder(path: str) -> bool:
|
27 |
+
"""Check that folder with path specified contains valid documentation."""
|
28 |
+
return os.path.isdir(path) and os.path.isfile(os.path.join(path, "index.html"))
|
29 |
+
|
30 |
+
|
31 |
+
def get_versions() -> list[str]:
|
32 |
+
"""List available versions of the package in the expected order."""
|
33 |
+
with open(VERSION_FILE) as infile:
|
34 |
+
versions = json.load(infile)
|
35 |
+
|
36 |
+
print("Available versions:")
|
37 |
+
for version in versions:
|
38 |
+
print(f" - {version}")
|
39 |
+
|
40 |
+
|
41 |
+
if __name__ == "__main__":
|
42 |
+
get_versions()
|
pyproject.toml
CHANGED
@@ -9,6 +9,7 @@ authors = [
|
|
9 |
{name = "Hasan Iqbal", email = "[email protected]"},
|
10 |
{name = "Yuxia Wang", email = "[email protected]"},
|
11 |
{name = "Minghan Wang", email = "[email protected]"},
|
|
|
12 |
{name = "Jiahui Geng", email = "[email protected]"},
|
13 |
{name = "Preslav Nakov", email = "[email protected]"}
|
14 |
]
|
@@ -41,6 +42,19 @@ classifiers = [
|
|
41 |
[tool.setuptools.dynamic]
|
42 |
dependencies = {file = ["requirements.txt"]}
|
43 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
44 |
[tool.setuptools.package-data]
|
45 |
openfactcheck = [
|
46 |
"data/*.jsonl",
|
|
|
9 |
{name = "Hasan Iqbal", email = "[email protected]"},
|
10 |
{name = "Yuxia Wang", email = "[email protected]"},
|
11 |
{name = "Minghan Wang", email = "[email protected]"},
|
12 |
+
{name = "Georgi Georgiev", email = "[email protected]"},
|
13 |
{name = "Jiahui Geng", email = "[email protected]"},
|
14 |
{name = "Preslav Nakov", email = "[email protected]"}
|
15 |
]
|
|
|
42 |
[tool.setuptools.dynamic]
|
43 |
dependencies = {file = ["requirements.txt"]}
|
44 |
|
45 |
+
[project.optional-dependencies]
|
46 |
+
docs = [
|
47 |
+
"sphinx",
|
48 |
+
"sphinx-design",
|
49 |
+
"sphinx-favicon",
|
50 |
+
"sphinx-autobuild",
|
51 |
+
"sphinx-copybutton",
|
52 |
+
"sphinxext-rediraffe",
|
53 |
+
"sphinx-togglebutton",
|
54 |
+
"pydata-sphinx-theme",
|
55 |
+
"myst-parser"
|
56 |
+
]
|
57 |
+
|
58 |
[tool.setuptools.package-data]
|
59 |
openfactcheck = [
|
60 |
"data/*.jsonl",
|
readthedocs.yaml
ADDED
@@ -0,0 +1,38 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# Read the Docs configuration file for Sphinx projects
|
2 |
+
# See https://docs.readthedocs.io/en/stable/config-file/v2.html for details
|
3 |
+
|
4 |
+
# Required
|
5 |
+
version: 2
|
6 |
+
|
7 |
+
# Set the OS, Python version and other tools you might need
|
8 |
+
build:
|
9 |
+
os: ubuntu-22.04
|
10 |
+
tools:
|
11 |
+
python: "3.11"
|
12 |
+
# You can also specify other tool versions:
|
13 |
+
# nodejs: "20"
|
14 |
+
# rust: "1.70"
|
15 |
+
# golang: "1.20"
|
16 |
+
|
17 |
+
# Build documentation in the "docs/" directory with Sphinx
|
18 |
+
sphinx:
|
19 |
+
configuration: docs/src/conf.py
|
20 |
+
# You can configure Sphinx to use a different builder, for instance use the dirhtml builder for simpler URLs
|
21 |
+
# builder: "dirhtml"
|
22 |
+
# Fail on all warnings to avoid broken references
|
23 |
+
# fail_on_warning: true
|
24 |
+
|
25 |
+
# Optionally build your docs in additional formats such as PDF and ePub
|
26 |
+
formats:
|
27 |
+
- pdf
|
28 |
+
- epub
|
29 |
+
|
30 |
+
# Optional but recommended, declare the Python requirements required
|
31 |
+
# to build your documentation
|
32 |
+
# See https://docs.readthedocs.io/en/stable/guides/reproducible-builds.html
|
33 |
+
python:
|
34 |
+
install:
|
35 |
+
- method: pip
|
36 |
+
path: .
|
37 |
+
extra_requirements:
|
38 |
+
- docs
|