| | |
| | | warnings.simplefilter('ignore', DeprecationWarning) |
| | | |
| | | import pkg_resources |
| | | import pylons_sphinx_themes |
| | | |
| | | # skip raw nodes |
| | | from sphinx.writers.text import TextTranslator |
| | |
| | | # Add any Sphinx extension module names here, as strings. They can be extensions |
| | | # coming with Sphinx (named 'sphinx.ext.*') or your custom ones. |
| | | extensions = [ |
| | | 'repoze.sphinx.autointerface', |
| | | 'sphinx.ext.autodoc', |
| | | 'sphinx.ext.doctest', |
| | | 'repoze.sphinx.autointerface', |
| | | 'sphinx.ext.intersphinx', |
| | | 'sphinx.ext.todo', |
| | | 'sphinx.ext.viewcode', |
| | | 'sphinx.ext.intersphinx' |
| | | 'sphinxcontrib.autoprogram', |
| | | # enable pylons_sphinx_latesturl when this branch is no longer "latest" |
| | | 'pylons_sphinx_latesturl', |
| | | ] |
| | | |
| | | # Looks for objects in external projects |
| | | intersphinx_mapping = { |
| | | 'tutorials': ('http://docs.pylonsproject.org/projects/pyramid_tutorials/en/latest/', None), |
| | | 'jinja2': ('http://docs.pylonsproject.org/projects/pyramid_jinja2/en/latest/', None), |
| | | 'tm': ( |
| | | 'http://docs.pylonsproject.org/projects/pyramid_tm/en/latest/', |
| | | None, |
| | | ), |
| | | 'zcomponent': ('http://docs.zope.org/zope.component', None), |
| | | 'webtest': ('http://webtest.pythonpaste.org/en/latest', None), |
| | | 'webob': ('http://docs.webob.org/en/latest', None), |
| | | 'colander': ( |
| | | 'http://docs.pylonsproject.org/projects/colander/en/latest', |
| | | None), |
| | | 'deform': ( |
| | | 'http://docs.pylonsproject.org/projects/deform/en/latest', |
| | | None), |
| | | 'colander': ('https://docs.pylonsproject.org/projects/colander/en/latest', None), |
| | | 'cookbook': ('https://docs.pylonsproject.org/projects/pyramid-cookbook/en/latest/', None), |
| | | 'cookiecutter': ('https://cookiecutter.readthedocs.io/en/latest/', None), |
| | | 'deform': ('https://docs.pylonsproject.org/projects/deform/en/latest', None), |
| | | 'jinja2': ('https://docs.pylonsproject.org/projects/pyramid-jinja2/en/latest/', None), |
| | | 'pylonswebframework': ('https://docs.pylonsproject.org/projects/pylons-webframework/en/latest/', None), |
| | | 'python': ('https://docs.python.org/3', None), |
| | | 'pytest': ('https://docs.pytest.org/en/latest/', None), |
| | | 'sphinx': ('http://www.sphinx-doc.org/en/latest', None), |
| | | 'sqla': ('http://docs.sqlalchemy.org/en/latest', None), |
| | | 'who': ('http://docs.repoze.org/who/latest', None), |
| | | 'python': ('http://docs.python.org', None), |
| | | 'python3': ('http://docs.python.org/3', None), |
| | | 'tstring': |
| | | ('http://docs.pylonsproject.org/projects/translationstring/en/latest', |
| | | None), |
| | | 'venusian': |
| | | ('http://docs.pylonsproject.org/projects/venusian/en/latest', None), |
| | | 'toolbar': |
| | | ('http://docs.pylonsproject.org/projects/pyramid_debugtoolbar/en/latest', |
| | | None), |
| | | 'zcml': |
| | | ('http://docs.pylonsproject.org/projects/pyramid_zcml/en/latest', |
| | | None), |
| | | 'tm': ('https://docs.pylonsproject.org/projects/pyramid-tm/en/latest/', None), |
| | | 'toolbar': ('https://docs.pylonsproject.org/projects/pyramid-debugtoolbar/en/latest', None), |
| | | 'tstring': ('https://docs.pylonsproject.org/projects/translationstring/en/latest', None), |
| | | 'tutorials': ('https://docs.pylonsproject.org/projects/pyramid-tutorials/en/latest/', None), |
| | | 'venusian': ('https://docs.pylonsproject.org/projects/venusian/en/latest', None), |
| | | 'webob': ('https://docs.pylonsproject.org/projects/webob/en/latest/', None), |
| | | 'webtest': ('http://webtest.pythonpaste.org/en/latest', None), |
| | | 'who': ('http://repozewho.readthedocs.io/en/latest', None), |
| | | 'zcml': ('https://docs.pylonsproject.org/projects/pyramid-zcml/en/latest', None), |
| | | 'zcomponent': ('http://zopecomponent.readthedocs.io/en/latest/', None), |
| | | 'zinterface': ('http://zopeinterface.readthedocs.io/en/latest/', None), |
| | | } |
| | | |
| | | |
| | |
| | | # unit titles (such as .. function::). |
| | | add_module_names = False |
| | | |
| | | # Add support for todo items |
| | | todo_include_todos = True |
| | | |
| | | # The name of the Pygments (syntax highlighting) style to use. |
| | | #pygments_style = book and 'bw' or 'tango' |
| | | if book: |
| | |
| | | |
| | | # Options for HTML output |
| | | # ----------------------- |
| | | # enable pylons_sphinx_latesturl when this branch is no longer "latest" |
| | | pylons_sphinx_latesturl_base = ( |
| | | 'https://docs.pylonsproject.org/projects/pyramid/en/latest/') |
| | | pylons_sphinx_latesturl_pagename_overrides = { |
| | | # map old pagename -> new pagename |
| | | 'whatsnew-1.0': 'index', |
| | | 'whatsnew-1.1': 'index', |
| | | 'whatsnew-1.2': 'index', |
| | | 'whatsnew-1.3': 'index', |
| | | 'whatsnew-1.4': 'index', |
| | | 'whatsnew-1.5': 'index', |
| | | 'whatsnew-1.6': 'index', |
| | | 'whatsnew-1.7': 'index', |
| | | 'whatsnew-1.8': 'index', |
| | | 'tutorials/gae/index': 'index', |
| | | 'api/chameleon_text': 'api', |
| | | 'api/chameleon_zpt': 'api', |
| | | } |
| | | |
| | | # Add and use Pylons theme |
| | | if 'sphinx-build' in ' '.join(sys.argv): # protect against dumb importers |
| | | from subprocess import call, Popen, PIPE |
| | | |
| | | p = Popen('which git', shell=True, stdout=PIPE) |
| | | cwd = os.getcwd() |
| | | _themes = os.path.join(cwd, '_themes') |
| | | git = p.stdout.read().strip() |
| | | if not os.listdir(_themes): |
| | | call([git, 'submodule', '--init']) |
| | | else: |
| | | call([git, 'submodule', 'update']) |
| | | |
| | | sys.path.append(os.path.abspath('_themes')) |
| | | |
| | | html_theme_path = ['_themes'] |
| | | html_theme = 'pyramid' |
| | | html_theme_path = pylons_sphinx_themes.get_html_themes_path() |
| | | html_theme_options = dict( |
| | | github_url='https://github.com/Pylons/pyramid', |
| | | in_progress='true', |
| | | # On master branch and new branch still in |
| | | # pre-release status: true; else: false. |
| | | in_progress='false', |
| | | # On branches previous to "latest": true; else: false. |
| | | outdated='true', |
| | | ) |
| | | |
| | | # Control display of sidebars |
| | | html_sidebars = {'**': [ |
| | | 'localtoc.html', |
| | | 'ethicalads.html', |
| | | 'relations.html', |
| | | 'sourcelink.html', |
| | | 'searchbox.html', |
| | | ]} |
| | | |
| | | # The name for this set of Sphinx documents. If None, it defaults to |
| | | # "<project> v<release> documentation". |
| | |
| | | # using the given strftime format. |
| | | html_last_updated_fmt = '%b %d, %Y' |
| | | |
| | | # If true, SmartyPants will be used to convert quotes and dashes to |
| | | # typographically correct entities. |
| | | html_use_smartypants = False # people use cutnpaste in some places |
| | | # Do not use smart quotes. |
| | | smartquotes = False |
| | | |
| | | # Output file base name for HTML help builder. |
| | | htmlhelp_basename = 'pyramid' |
| | |
| | | |
| | | # For "manual" documents, if this is true, then toplevel headings are parts, |
| | | # not chapters. |
| | | latex_use_parts = True |
| | | latex_toplevel_sectioning = "section" |
| | | |
| | | # If false, no module index is generated. |
| | | latex_use_modindex = False |
| | | latex_domain_indices = False |
| | | |
| | | ## Say, for a moment that you have a twoside document that needs a 3cm |
| | | ## inner margin to allow for binding and at least two centimetres the |
| | |
| | | |
| | | latex_elements = { |
| | | 'preamble': _PREAMBLE, |
| | | 'wrapperclass': 'book', |
| | | 'date': '', |
| | | 'releasename': 'Version', |
| | | 'title': r'The Pyramid Web Framework', |