2019-09-15 17:07:41 +01:00
|
|
|
# Configuration file for the Sphinx documentation builder.
|
|
|
|
|
#
|
|
|
|
|
# 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.
|
2025-12-21 02:45:11 +00:00
|
|
|
|
|
|
|
|
# NOTE: To generate docs:
|
|
|
|
|
# $ cd docs
|
|
|
|
|
# $ rm -rf _build api
|
|
|
|
|
# $ python -m sphinx -T -b html -d _build/doctrees -D language=en . _build/output/html
|
|
|
|
|
|
|
|
|
|
# pylint:skip-file
|
|
|
|
|
import logging
|
2019-09-15 17:07:41 +01:00
|
|
|
import os
|
|
|
|
|
import sys
|
2022-07-17 17:54:22 +01:00
|
|
|
from unittest import mock
|
|
|
|
|
|
2025-12-21 02:45:11 +00:00
|
|
|
os.environ["FACESWAP_BACKEND"] = "cpu"
|
|
|
|
|
os.environ["KERAS_BACKEND"] = "torch"
|
|
|
|
|
|
2019-09-15 17:07:41 +01:00
|
|
|
sys.path.insert(0, os.path.abspath('../'))
|
|
|
|
|
sys.setrecursionlimit(1500)
|
|
|
|
|
|
2023-01-06 14:45:57 +00:00
|
|
|
|
2025-12-21 02:45:11 +00:00
|
|
|
MOCK_MODULES = ["pynvml", "ctypes.windll", "comtypes"]
|
2022-07-17 17:54:22 +01:00
|
|
|
for mod_name in MOCK_MODULES:
|
|
|
|
|
sys.modules[mod_name] = mock.Mock()
|
|
|
|
|
|
2019-09-15 17:07:41 +01:00
|
|
|
# -- Project information -----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
project = 'faceswap'
|
2025-12-21 02:45:11 +00:00
|
|
|
copyright = '2025, faceswap.dev'
|
2019-09-15 17:07:41 +01:00
|
|
|
author = 'faceswap.dev'
|
|
|
|
|
|
|
|
|
|
# The full version, including alpha/beta/rc tags
|
2025-12-21 02:45:11 +00:00
|
|
|
release = '3.0'
|
2019-09-15 17:07:41 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- General configuration ---------------------------------------------------
|
|
|
|
|
|
|
|
|
|
# Add any Sphinx extension module names here, as strings. They can be
|
|
|
|
|
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
|
|
|
|
|
# ones.
|
2025-12-21 02:45:11 +00:00
|
|
|
extensions = ['sphinx.ext.napoleon', "sphinx_automodapi.automodapi"]
|
2022-07-17 17:54:22 +01:00
|
|
|
napoleon_custom_sections = ['License']
|
2025-12-21 02:45:11 +00:00
|
|
|
numpydoc_show_class_members = False
|
|
|
|
|
automodsumm_inherited_members = True
|
2019-09-15 17:07:41 +01:00
|
|
|
|
|
|
|
|
# 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']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- 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'
|
2020-04-08 11:32:31 +01:00
|
|
|
html_theme_options = {
|
|
|
|
|
'analytics_id': 'UA-145659566-2',
|
|
|
|
|
'logo_only': True,
|
|
|
|
|
# Toc options
|
|
|
|
|
'navigation_depth': -1,
|
|
|
|
|
}
|
|
|
|
|
html_logo = '_static/logo.png'
|
|
|
|
|
latext_logo = '_static/logo.png'
|
2019-09-15 17:07:41 +01:00
|
|
|
|
|
|
|
|
# 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']
|
2019-09-15 16:15:38 +00:00
|
|
|
|
|
|
|
|
master_doc = 'index'
|
2020-04-06 15:38:02 +01:00
|
|
|
|
2025-12-21 02:45:11 +00:00
|
|
|
# Suppress warnings from all 3rd party libraries
|
|
|
|
|
_suppressed_warning_count = 0
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def _suppress_third_party_warnings():
|
|
|
|
|
""" Override Sphinx logging to ignore any warnings generated by 3rd party libraries """
|
|
|
|
|
skip = ["lib/python", "site-packages", # system packages/python lib
|
|
|
|
|
".variables", ".non_trainable_variables"] # keras layer inheritance
|
|
|
|
|
root = logging.getLogger("sphinx")
|
|
|
|
|
for handler in root.handlers:
|
|
|
|
|
orig_emit = handler.emit
|
|
|
|
|
|
|
|
|
|
def make_filtered_emit(orig_emit):
|
|
|
|
|
|
|
|
|
|
def filtered_emit(record):
|
|
|
|
|
if record.levelname in ("WARNING", "ERROR"):
|
|
|
|
|
try:
|
|
|
|
|
msg = record.getMessage()
|
|
|
|
|
except TypeError:
|
|
|
|
|
orig_emit(record)
|
|
|
|
|
return
|
|
|
|
|
loc = getattr(record, "location", "")
|
|
|
|
|
if any(x in msg or x in str(loc) for x in skip):
|
|
|
|
|
global _suppressed_warning_count
|
|
|
|
|
_suppressed_warning_count += 1
|
|
|
|
|
return
|
|
|
|
|
orig_emit(record)
|
|
|
|
|
return filtered_emit
|
|
|
|
|
handler.emit = make_filtered_emit(orig_emit)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def _on_build_finish(app, exception):
|
|
|
|
|
""" Subtract our suppressed warnings from the total warnings count """
|
|
|
|
|
if hasattr(app, "_warncount") and _suppressed_warning_count:
|
|
|
|
|
setattr(app, "_warncount", max(0,
|
|
|
|
|
getattr(app,
|
|
|
|
|
"_warncount", 0) - _suppressed_warning_count))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def setup(app):
|
|
|
|
|
""" Install our warnings filter and capture suppressed counts """
|
|
|
|
|
_suppress_third_party_warnings()
|
|
|
|
|
app.connect("build-finished", _on_build_finish)
|