2015-01-27 16:53:17 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import codecs
|
|
|
|
import os
|
|
|
|
import re
|
|
|
|
|
|
|
|
|
|
|
|
def read(*parts):
|
|
|
|
"""
|
|
|
|
Build an absolute path from *parts* and and return the contents of the
|
|
|
|
resulting file. Assume UTF-8 encoding.
|
|
|
|
"""
|
|
|
|
here = os.path.abspath(os.path.dirname(__file__))
|
|
|
|
with codecs.open(os.path.join(here, *parts), "rb", "utf-8") as f:
|
|
|
|
return f.read()
|
|
|
|
|
|
|
|
|
|
|
|
def find_version(*file_paths):
|
|
|
|
"""
|
|
|
|
Build a path from *file_paths* and search for a ``__version__``
|
|
|
|
string inside.
|
|
|
|
"""
|
|
|
|
version_file = read(*file_paths)
|
2018-06-10 17:40:07 +00:00
|
|
|
version_match = re.search(
|
|
|
|
r"^__version__ = ['\"]([^'\"]*)['\"]", version_file, re.M
|
|
|
|
)
|
2015-01-27 16:53:17 +00:00
|
|
|
if version_match:
|
|
|
|
return version_match.group(1)
|
|
|
|
raise RuntimeError("Unable to find version string.")
|
|
|
|
|
|
|
|
|
|
|
|
# -- General configuration ------------------------------------------------
|
|
|
|
|
2020-11-05 09:51:23 +00:00
|
|
|
linkcheck_ignore = [
|
|
|
|
r"https://github.com/.*/(issues|pull)/\d+",
|
|
|
|
]
|
|
|
|
|
2019-09-09 13:02:16 +00:00
|
|
|
# In nitpick mode (-n), still ignore any of the following "broken" references
|
|
|
|
# to non-types.
|
|
|
|
nitpick_ignore = [
|
|
|
|
("py:class", "Any value"),
|
|
|
|
("py:class", "callable"),
|
|
|
|
("py:class", "callables"),
|
|
|
|
("py:class", "tuple of types"),
|
|
|
|
]
|
|
|
|
|
2015-01-27 16:53:17 +00:00
|
|
|
# Add any Sphinx extension module names here, as strings. They can be
|
|
|
|
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
|
|
|
|
# ones.
|
|
|
|
extensions = [
|
2018-06-10 17:40:07 +00:00
|
|
|
"sphinx.ext.autodoc",
|
|
|
|
"sphinx.ext.doctest",
|
|
|
|
"sphinx.ext.intersphinx",
|
|
|
|
"sphinx.ext.todo",
|
2015-01-27 16:53:17 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
# Add any paths that contain templates here, relative to this directory.
|
2018-06-10 17:40:07 +00:00
|
|
|
templates_path = ["_templates"]
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# The suffix of source filenames.
|
2018-06-10 17:40:07 +00:00
|
|
|
source_suffix = ".rst"
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# The master toctree document.
|
2018-06-10 17:40:07 +00:00
|
|
|
master_doc = "index"
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# General information about the project.
|
2018-06-10 17:40:07 +00:00
|
|
|
project = u"attrs"
|
|
|
|
copyright = u"2015, Hynek Schlawack"
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# The version info for the project you're documenting, acts as replacement for
|
|
|
|
# |version| and |release|, also used in various other places throughout the
|
|
|
|
# built documents.
|
|
|
|
#
|
|
|
|
# The short X.Y version.
|
2015-10-16 13:09:28 +00:00
|
|
|
release = find_version("../src/attr/__init__.py")
|
2015-01-27 16:53:17 +00:00
|
|
|
version = release.rsplit(u".", 1)[0]
|
|
|
|
# The full version, including alpha/beta/rc tags.
|
|
|
|
|
|
|
|
# List of patterns, relative to source directory, that match files and
|
|
|
|
# directories to ignore when looking for source files.
|
2018-06-10 17:40:07 +00:00
|
|
|
exclude_patterns = ["_build"]
|
2015-01-27 16:53:17 +00:00
|
|
|
|
2019-09-09 13:02:16 +00:00
|
|
|
# The reST default role (used for this markup: `text`) to use for all
|
|
|
|
# documents.
|
|
|
|
default_role = "any"
|
|
|
|
|
2015-01-27 16:53:17 +00:00
|
|
|
# If true, '()' will be appended to :func: etc. cross-reference text.
|
2017-02-20 12:41:20 +00:00
|
|
|
add_function_parentheses = True
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# -- Options for HTML output ----------------------------------------------
|
|
|
|
|
|
|
|
# The theme to use for HTML and HTML Help pages. See the documentation for
|
|
|
|
# a list of builtin themes.
|
|
|
|
|
2020-10-05 05:35:40 +00:00
|
|
|
html_theme = "furo"
|
2017-05-23 23:11:37 +00:00
|
|
|
html_theme_options = {
|
2020-10-05 05:35:40 +00:00
|
|
|
"sidebar_hide_name": True,
|
2020-11-16 06:52:35 +00:00
|
|
|
"light_logo": "attrs_logo.svg",
|
|
|
|
"dark_logo": "attrs_logo_white.svg",
|
2017-05-23 23:11:37 +00:00
|
|
|
}
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
# The name of an image file (within the static path) to use as favicon of the
|
|
|
|
# docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32
|
|
|
|
# pixels large.
|
2017-02-20 12:41:20 +00:00
|
|
|
# html_favicon = None
|
2015-01-27 16:53:17 +00: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".
|
2018-06-10 17:40:07 +00:00
|
|
|
html_static_path = ["_static"]
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If false, no module index is generated.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_domain_indices = True
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If false, no index is generated.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_use_index = True
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If true, the index is split into individual pages for each letter.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_split_index = False
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If true, links to the reST sources are added to the pages.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_show_sourcelink = False
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If true, "Created using Sphinx" is shown in the HTML footer. Default is True.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_show_sphinx = True
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If true, "(C) Copyright ..." is shown in the HTML footer. Default is True.
|
2017-02-20 12:41:20 +00:00
|
|
|
html_show_copyright = True
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# If true, an OpenSearch description file will be output, and all pages will
|
|
|
|
# contain a <link> tag referring to it. The value of this option must be the
|
|
|
|
# base URL from which the finished HTML is served.
|
2017-02-20 12:41:20 +00:00
|
|
|
# html_use_opensearch = ''
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# Output file base name for HTML help builder.
|
2018-06-10 17:40:07 +00:00
|
|
|
htmlhelp_basename = "attrsdoc"
|
2015-01-27 16:53:17 +00:00
|
|
|
|
|
|
|
# -- Options for manual page output ---------------------------------------
|
|
|
|
|
|
|
|
# One entry per manual page. List of tuples
|
|
|
|
# (source start file, name, description, authors, manual section).
|
|
|
|
man_pages = [
|
2018-06-10 17:40:07 +00:00
|
|
|
("index", "attrs", u"attrs Documentation", [u"Hynek Schlawack"], 1)
|
2015-01-27 16:53:17 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
# -- Options for Texinfo output -------------------------------------------
|
|
|
|
|
|
|
|
# Grouping the document tree into Texinfo files. List of tuples
|
|
|
|
# (source start file, target name, title, author,
|
|
|
|
# dir menu entry, description, category)
|
|
|
|
texinfo_documents = [
|
2018-06-10 17:40:07 +00:00
|
|
|
(
|
|
|
|
"index",
|
|
|
|
"attrs",
|
|
|
|
u"attrs Documentation",
|
|
|
|
u"Hynek Schlawack",
|
|
|
|
"attrs",
|
|
|
|
"One line description of project.",
|
|
|
|
"Miscellaneous",
|
|
|
|
)
|
2015-01-27 16:53:17 +00:00
|
|
|
]
|
|
|
|
|
2019-09-09 13:02:16 +00:00
|
|
|
intersphinx_mapping = {
|
|
|
|
"https://docs.python.org/3": None,
|
|
|
|
}
|
2017-03-04 07:43:34 +00:00
|
|
|
|
|
|
|
# Allow non-local URIs so we can have images in CHANGELOG etc.
|
2018-06-10 17:40:07 +00:00
|
|
|
suppress_warnings = ["image.nonlocal_uri"]
|