Skip to main content

Use Sphinx to build documentation for zope.org.

Project description

z3c.recipe.sphinxdoc

Introduction

This buildout recipe aids in the generation of documentation for the zope.org website from restructured text files located in a package. It uses Sphinx to build static html files which can stand alone as a very nice looking website.

Usage Instructions

Suppose you have a package called z3c.form. In the setup.py for z3c.form it is recommended that you add a docs section to the extras_require argument. It should look something like this:

extras_require = dict(
    docs = ['Sphinx',
            'z3c.recipe.sphinxdoc']
    )

Then in the buildout.cfg file for your package, add a docs section that looks like this:

[docs]
recipe = z3c.recipe.sphinxdoc
eggs = z3c.form [docs]

Be sure to include it in the parts, as in:

[buildout]
develop = .
parts = docs

Now you can rerun buildout. The recipe will have created an executable script in the bin directory called docs.

This script will run the Sphinx documentation generation tool on your source code. By default, it expects there to be an index.rst file in the source code. In this case, index.rst would have to be in src/z3c/form/index.rst. This file can be a standard restructured text file, and can use all the sphinx goodies. For example, your index.txt might look like this:

Welcome to z3c.form's documentation!
====================================

Contents:

.. toctree::
   :maxdepth: 2

   README

Indices and tables
==================

* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`

You should read the documentation for Sphinx to learn more about it. It is available here: http://sphinx.pocoo.org/

Now you should be able to run the docs script:

$ ./bin/docs

This generates all the documentation for you and placed it in the parts directory. You can then open it up in firefox and take a look:

$ firefox parts/docs/z3c.form/build/index.html

Additional Options

By default, this recipe generates documentation that looks like the new zope website ( http://new.zope.org ) by overriding the default layout template and css file used by sphinx. You can modify this behavior with options in your buildout configuration.

Give me back Sphinx’s default look!

To get back the default look of sphinx, you could use a configuration like this:

[docs]
recipe = z3c.recipe.sphinxdoc
eggs = z3c.form [docs]
default.css =
layout.html =

I want my own custom look

You can also specify your own layout template and css like so:

[docs]
recipe = z3c.recipe.sphinxdoc
eggs = z3c.form [docs]
default.css = http://my.own.website.com/mystyles/some-theme.css
layout.html = /path/to/layout.html

Note that you can either specify a path on the local file system or a url to an external css file.

Use sphinx extension modules

Sphinx provides a set of extensions, for example sphinx.ext.autodoc or sphinx.ext.doctest. To use such an extension change your configuration like:

[docs]
recipe = z3c.recipe.sphinxdoc
eggs = z3c.form [docs]
extensions = sphinx.ext.autodoc sphinx.ext.doctest

Arbitrary Configuration

Sphinx and its extensions offer many configuration options. You can specify any of those by using the extra-conf option. This option takes a sequence of lines that are simply inserted into the generated conf.py. Anything you specify here will override other settings this recipe established (just watch your leading line indentation):

[docs]
recipe = z3c.recipe.sphinxdoc
eggs = z3c.form [docs]
extensions = sphinx.ext.autodoc
             sphinx.ext.todo
             sphinx.ext.viewcode
             sphinx.ext.intersphinx
             repoze.sphinx.autointerface
             sphinxcontrib.programoutput
default.css =
layout.html =
extra-conf =
         autodoc_default_flags = ['members', 'show-inheritance',]
         autoclass_content = 'both'
         intersphinx_mapping = {
         'python':  ('http://docs.python.org/2.7/', None),
         'boto': ('http://boto.readthedocs.org/en/latest/', None),
         'gunicorn': ('http://docs.gunicorn.org/en/latest/', None),
         'pyquery': ('http://packages.python.org/pyquery/', None) }
         intersphinx_cache_limit = -1
         todo_include_todos = True

         # The suffix of source filenames. Override back to txt.
         source_suffix = '.txt'

         # Choose an entire theme. Note that we disabled layout.html
         # and default.css.
         html_theme = 'classic'

CHANGES

1.1.0 (2017-07-05)

  • Add support for Python 3.4, 3.5 and 3.6 and PyPy.

  • Remove support for Python 2.6 and 3.3.

  • Change the default source suffix from .txt to .rst. You can override this using the new extra-conf setting.

  • Add the ability to specify arbitrary configuration in the extra-conf setting. This is useful for things like configuring extensions, overriding the defaults set by this recipe, and configuring a sphinx theme.

  • Stop forcing a value of default.css for html_style even when the default.css setting is configured to an empty value. This makes it possible to use html_theme to set a sphinx theme, and it properly lets the default Sphinx theme be used (by setting both default.css and layout.html to empty values).

  • Ignore bad eggs in the documentation working set. Previously they would raise internal errors without any explanation. Now, they log a warning pinpointing the bad egg. Fixes issue 6.

1.0.0 (2013-02-23)

  • Added Python 3.3 support.

  • Bug: fix layout directory if layout is overriden by user

0.0.8 (2009-05-01)

  • Feature: Added new option doc-eggs which specifies the list of eggs for which to create documentation explicitely.

  • Feature: Changed building behavior so that the documentation for each package is built in its own sub-directory.

  • Feature: Added new option extensions which takes a whitespace separated list of sphinx extension modules. This extensions can be used to build the documentation.

0.0.7 (2009-02-15)

  • Bug: fix python 2.4 support

  • Bug: fix broken srcDir path generation for windows

0.0.6 (2009-01-19)

  • Feature: Allow you to specify a url or local file path to your own default.css and layout.html files.

0.0.5 (2008-05-11)

  • Initial release.

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

z3c.recipe.sphinxdoc-1.1.0.tar.gz (21.9 kB view details)

Uploaded Source

Built Distributions

z3c.recipe.sphinxdoc-1.1.0-py3-none-any.whl (22.4 kB view details)

Uploaded Python 3

z3c.recipe.sphinxdoc-1.1.0-py2.py3-none-any.whl (22.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file z3c.recipe.sphinxdoc-1.1.0.tar.gz.

File metadata

File hashes

Hashes for z3c.recipe.sphinxdoc-1.1.0.tar.gz
Algorithm Hash digest
SHA256 9e2ac4d17544a1a4939d225440655471e2fe675256fd34453a4dae96cb2f0d6a
MD5 8728d40166492e3091ac627a7c73aede
BLAKE2b-256 f2b1e8f020e067840c04395c8c79a13093107300a20190d7028c5a7f32df5db8

See more details on using hashes here.

File details

Details for the file z3c.recipe.sphinxdoc-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for z3c.recipe.sphinxdoc-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 27efe2a4c78b4272aada596e4ada2182c6edb61d5152a1a25d483dcd2c19c0ba
MD5 3721a2baa2e43385e4847151e209df18
BLAKE2b-256 f3eb952739a97740fc97dae88ce4a2d1d31ab4d4526e130cdea08081493cc2c4

See more details on using hashes here.

File details

Details for the file z3c.recipe.sphinxdoc-1.1.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for z3c.recipe.sphinxdoc-1.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 fa3a9af3238c3fa36d876c2019cdb00efd3bb5260189b14a0df48330f27494e7
MD5 933cdf34a471ab14f5eb3c146f660bd8
BLAKE2b-256 38246c7ba2b81f98af0b33021c1d2cf119d87ee92bd7285b015d3833d0ec9a3d

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