mirror of
https://github.com/facebookresearch/pytorch3d.git
synced 2025-12-21 14:50:36 +08:00
Initial commit
fbshipit-source-id: ad58e416e3ceeca85fae0583308968d04e78fe0d
This commit is contained in:
200
docs/conf.py
Normal file
200
docs/conf.py
Normal file
@@ -0,0 +1,200 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved
|
||||
|
||||
# flake8: noqa
|
||||
|
||||
# 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
|
||||
|
||||
# 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.
|
||||
#
|
||||
import os
|
||||
import sys
|
||||
|
||||
import pytorch3d # isort: skip
|
||||
|
||||
import mock
|
||||
from recommonmark.parser import CommonMarkParser
|
||||
from recommonmark.states import DummyStateMachine
|
||||
from sphinx.builders.html import StandaloneHTMLBuilder
|
||||
from sphinx.ext.autodoc import between
|
||||
|
||||
# Monkey patch to fix recommonmark 0.4 doc reference issues.
|
||||
orig_run_role = DummyStateMachine.run_role
|
||||
|
||||
|
||||
def run_role(self, name, options=None, content=None):
|
||||
if name == "doc":
|
||||
name = "any"
|
||||
return orig_run_role(self, name, options, content)
|
||||
|
||||
|
||||
DummyStateMachine.run_role = run_role
|
||||
|
||||
|
||||
StandaloneHTMLBuilder.supported_image_types = [
|
||||
"image/svg+xml",
|
||||
"image/gif",
|
||||
"image/png",
|
||||
"image/jpeg",
|
||||
]
|
||||
|
||||
# -- Path setup --------------------------------------------------------------
|
||||
|
||||
|
||||
sys.path.insert(0, os.path.abspath("../"))
|
||||
sys.path.insert(0, os.path.abspath("../pytorch3d"))
|
||||
sys.path.insert(0, os.path.abspath("../../"))
|
||||
|
||||
DEPLOY = os.environ.get("READTHEDOCS") == "True"
|
||||
needs_sphinx = "1.7"
|
||||
|
||||
|
||||
# The short X.Y version
|
||||
version = pytorch3d.__version__
|
||||
# The full version, including alpha/beta/rc tags
|
||||
release = version
|
||||
|
||||
try:
|
||||
import torch # noqa
|
||||
except ImportError:
|
||||
for m in [
|
||||
"torch",
|
||||
"torchvision",
|
||||
"torch.nn",
|
||||
"torch.autograd",
|
||||
"torch.autograd.function",
|
||||
"torch.nn.modules",
|
||||
"torch.nn.modules.utils",
|
||||
"torch.utils",
|
||||
"torch.utils.data",
|
||||
"torchvision",
|
||||
"torchvision.ops",
|
||||
]:
|
||||
sys.modules[m] = mock.Mock(name=m)
|
||||
|
||||
for m in ["cv2", "scipy", "numpy", "pytorch3d._C", "np.eye", "np.zeros"]:
|
||||
sys.modules[m] = mock.Mock(name=m)
|
||||
|
||||
# -- Project information -----------------------------------------------------
|
||||
|
||||
project = "PyTorch3D"
|
||||
copyright = "2019, facebookresearch"
|
||||
author = "facebookresearch"
|
||||
|
||||
# The full version, including alpha/beta/rc tags
|
||||
release = "v0.1"
|
||||
|
||||
# -- 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.
|
||||
|
||||
extensions = [
|
||||
"sphinx_markdown_tables",
|
||||
"sphinx.ext.autodoc",
|
||||
"sphinx.ext.mathjax",
|
||||
"sphinx.ext.napoleon",
|
||||
"sphinx.ext.intersphinx",
|
||||
"sphinx.ext.todo",
|
||||
"sphinx.ext.coverage",
|
||||
"sphinx.ext.viewcode",
|
||||
"sphinx.ext.githubpages",
|
||||
]
|
||||
|
||||
# -- Configurations for plugins ------------
|
||||
napoleon_google_docstring = True
|
||||
napoleon_include_init_with_doc = True
|
||||
napoleon_include_special_with_doc = True
|
||||
napoleon_numpy_docstring = False
|
||||
# napoleon_use_param = False
|
||||
napoleon_use_rtype = False
|
||||
autodoc_inherit_docstrings = False
|
||||
autodoc_member_order = "bysource"
|
||||
|
||||
source_parsers = {".md": CommonMarkParser}
|
||||
|
||||
|
||||
# The suffix(es) of source filenames.
|
||||
# You can specify multiple suffix as a list of string:
|
||||
#
|
||||
source_suffix = [".rst", ".md"]
|
||||
|
||||
# The master toctree document.
|
||||
master_doc = "index"
|
||||
|
||||
# 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", "build", "README.md"]
|
||||
|
||||
# The name of the Pygments (syntax highlighting) style to use.
|
||||
pygments_style = "sphinx"
|
||||
|
||||
# -- 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"
|
||||
|
||||
# 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"]
|
||||
|
||||
html_theme_options = {"collapse_navigation": True}
|
||||
|
||||
|
||||
def url_resolver(url):
|
||||
if ".html" not in url:
|
||||
url = url.replace("../", "")
|
||||
return (
|
||||
"https://github.com/facebookresearch/pytorch3d/blob/master/" + url
|
||||
)
|
||||
else:
|
||||
if DEPLOY:
|
||||
return "http://pytorch3d.readthedocs.io/" + url
|
||||
else:
|
||||
return "/" + url
|
||||
|
||||
|
||||
def setup(app):
|
||||
# Add symlink to root README
|
||||
if DEPLOY:
|
||||
import subprocess
|
||||
|
||||
subprocess.call(["ln", "-s", "../README.md", "overview.md"])
|
||||
|
||||
from recommonmark.transform import AutoStructify
|
||||
|
||||
app.add_config_value(
|
||||
"recommonmark_config",
|
||||
{
|
||||
"url_resolver": url_resolver,
|
||||
"auto_toc_tree_section": "Contents",
|
||||
"enable_math": True,
|
||||
"enable_inline_math": True,
|
||||
"enable_eval_rst": True,
|
||||
"enable_auto_toc_tree": True,
|
||||
},
|
||||
True,
|
||||
)
|
||||
|
||||
# Register a sphinx.ext.autodoc.between listener to ignore everything
|
||||
# between lines that contain the word IGNORE
|
||||
app.connect(
|
||||
"autodoc-process-docstring", between("^.*IGNORE.*$", exclude=True)
|
||||
)
|
||||
app.add_transform(AutoStructify)
|
||||
|
||||
return app
|
||||
Reference in New Issue
Block a user