Skip to main content

Zzzeek's Sphinx Layout and Utilities.

Project description

This is zzzeek’s own Sphinx layout, used by SQLAlchemy.

This layout is first and foremost pulled in for the SQLAlchemy documentation builds (and possibly other related projects).

Features include:

  • Uses Mako templates instead of Jinja, for more programmatic capabilities inside of templates.

  • Layout includes an independently scrollable sidebar

  • A unique (to Sphinx) “contextual” sidebar contents that shows the current page in context with all sibling pages (like that of MySQL’s docs). This is a form of TOC that Sphinx doesn’t typically have a lot of capability to do (well it could, with some simple feature adds), but IMO this kind of navigation is critical for very large and nested documentation sets, so that the navbar stays relatively small yet provides context as to where you are in the docs and what else is locally available.

  • Modifications to autodoc which illustrate inherited classes, bases, method documentation illustrates if a method is only inherited from the base or overridden.

  • A “dynamic base” feature that will, under ReadTheDocs, pull in optional .mako and .py files from the website of your choice that will serve as an alternate base template and a source of extra config setup, respectively, allowing the layout to be integrated into the layout of an external site when viewing on the web.

  • A “viewsource” extension that can provide highlighted sourcecode to any Python file arbitrarily.

  • SQLAlchemy-specific stuff, like the [SQL] popups, the dialect info directives.

  • scss support using pyscss.

Config

in conf.py, the extension is:

extensions = [
    'zzzeeksphinx',
]

The theme is:

html_theme = 'zzzeeksphinx'

Other configs that SQLAlchemy has set up; these two are probably needed:

# The short X.Y version.
version = "1.0"
# The full version, including alpha/beta/rc tags.
release = "1.0.0"

release_date = "Not released"

Additional configs for the “dynamic site thing” look like:

site_base = os.environ.get("RTD_SITE_BASE", "http://www.sqlalchemy.org")
site_adapter_template = "docs_adapter.mako"
site_adapter_py = "docs_adapter.py"

Configs which do some last-minute translation of module names when running autodoc to display API documentation:

autodocmods_convert_modname = {
    "sqlalchemy.sql.sqltypes": "sqlalchemy.types",
    "sqlalchemy.sql.type_api": "sqlalchemy.types",
    "sqlalchemy.sql.schema": "sqlalchemy.schema",
    "sqlalchemy.sql.elements": "sqlalchemy.sql.expression",
    "sqlalchemy.sql.selectable": "sqlalchemy.sql.expression",
    "sqlalchemy.sql.dml": "sqlalchemy.sql.expression",
    "sqlalchemy.sql.ddl": "sqlalchemy.schema",
    "sqlalchemy.sql.base": "sqlalchemy.sql.expression"
}

autodocmods_convert_modname_w_class = {
    ("sqlalchemy.engine.interfaces", "Connectable"): "sqlalchemy.engine",
    ("sqlalchemy.sql.base", "DialectKWArgs"): "sqlalchemy.sql.base",
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zzzeeksphinx-1.2.2.tar.gz (74.1 kB view details)

Uploaded Source

Built Distribution

zzzeeksphinx-1.2.2-py3-none-any.whl (77.6 kB view details)

Uploaded Python 3

File details

Details for the file zzzeeksphinx-1.2.2.tar.gz.

File metadata

  • Download URL: zzzeeksphinx-1.2.2.tar.gz
  • Upload date:
  • Size: 74.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.9.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for zzzeeksphinx-1.2.2.tar.gz
Algorithm Hash digest
SHA256 f0df5093db7cc53ed09a5b069545e47e3d83a4073b07882c4b5033b792351004
MD5 1bd5ade1674ee61249c15055530801ea
BLAKE2b-256 db4759e9f4c444f0c6487c9ce320da2c124bacdd0714a6deb7bc7dbe5c91b802

See more details on using hashes here.

File details

Details for the file zzzeeksphinx-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: zzzeeksphinx-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 77.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.9.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for zzzeeksphinx-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 752d378e1a8d95328afe66548eeb5aa735193a5fa9934c2451ccd0418ebd1875
MD5 c875451e52aa26abd1bb5fd81b7c36f3
BLAKE2b-256 56b844fde3917e6602609fae92f0687a1a6457986ee8125150f7b2268ae5c148

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page