sphinx/doc/extdev/appapi.rst

400 lines
12 KiB
ReStructuredText
Raw Normal View History

2008-03-18 13:19:21 -05:00
.. highlight:: rest
Application API
===============
.. module:: sphinx.application
:synopsis: Application class and extensibility interface.
2008-03-12 16:37:22 -05:00
Each Sphinx extension is a Python module with at least a :func:`setup`
function. This function is called at initialization time with one argument,
the application object representing the Sphinx process.
.. class:: Sphinx
This application object has the public API described in the following.
Extension setup
---------------
These methods are usually called in an extension's ``setup()`` function.
Examples of using the Sphinx extension API can be seen in the :mod:`sphinx.ext`
package.
2008-03-12 16:37:22 -05:00
.. currentmodule:: sphinx.application
.. automethod:: Sphinx.setup_extension(name)
.. automethod:: Sphinx.require_sphinx(version)
.. automethod:: Sphinx.connect(event, callback)
.. automethod:: Sphinx.disconnect(listener_id)
.. automethod:: Sphinx.add_builder(builder)
.. automethod:: Sphinx.add_config_value(name, default, rebuild)
.. automethod:: Sphinx.add_event(name)
.. automethod:: Sphinx.set_translator(name, translator_class)
.. automethod:: Sphinx.add_node(node, \*\*kwds)
.. automethod:: Sphinx.add_enumerable_node(node, figtype, title_getter=None, \*\*kwds)
.. method:: Sphinx.add_directive(name, func, content, arguments, \*\*options)
.. automethod:: Sphinx.add_directive(name, directiveclass)
.. automethod:: Sphinx.add_role(name, role)
.. automethod:: Sphinx.add_generic_role(name, nodeclass)
.. automethod:: Sphinx.add_domain(domain)
.. automethod:: Sphinx.override_domain(domain)
.. method:: Sphinx.add_directive_to_domain(domain, name, func, content, arguments, \*\*options)
.. automethod:: Sphinx.add_directive_to_domain(domain, name, directiveclass)
2008-03-18 13:19:21 -05:00
.. automethod:: Sphinx.add_role_to_domain(domain, name, role)
2008-03-18 13:19:21 -05:00
.. automethod:: Sphinx.add_index_to_domain(domain, index)
2008-03-18 13:19:21 -05:00
.. automethod:: Sphinx.add_object_type(directivename, rolename, indextemplate='', parse_node=None, ref_nodeclass=None, objname='', doc_field_types=[])
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_crossref_type(directivename, rolename, indextemplate='', ref_nodeclass=None, objname='')
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_transform(transform)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_post_transform(transform)
2008-03-12 16:37:22 -05:00
.. automethod:: Sphinx.add_javascript(filename)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_stylesheet(filename, alternate=None, title=None)
.. automethod:: Sphinx.add_latex_package(packagename, options=None)
.. automethod:: Sphinx.add_lexer(alias, lexer)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_autodocumenter(cls)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_autodoc_attrgetter(type, getter)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_search_language(cls)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_source_parser(suffix, parser)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_env_collector(collector)
2008-03-28 13:45:32 -05:00
.. automethod:: Sphinx.add_html_theme(name, theme_path)
.. exception:: ExtensionError
All these methods raise this exception if something went wrong with the
extension API.
Emitting events
---------------
.. class:: Sphinx
.. automethod:: emit(event, \*arguments)
.. automethod:: emit_firstresult(event, \*arguments)
2008-03-12 16:37:22 -05:00
Producing messages / logging
----------------------------
The application object also provides support for emitting leveled messages.
2014-01-21 02:54:31 -06:00
.. note::
There is no "error" call: in Sphinx, errors are defined as things that stop
2014-01-21 03:05:23 -06:00
the build; just raise an exception (:exc:`sphinx.errors.SphinxError` or a
custom subclass) to do that.
2014-01-21 02:54:31 -06:00
2017-01-07 00:10:53 -06:00
.. deprecated:: 1.6
Please use :ref:`logging-api` instead.
.. automethod:: Sphinx.warn
2008-03-12 16:37:22 -05:00
.. automethod:: Sphinx.info
2008-03-12 16:37:22 -05:00
.. automethod:: Sphinx.verbose
2008-03-12 16:37:22 -05:00
.. automethod:: Sphinx.debug
.. automethod:: Sphinx.debug2
2008-03-12 16:37:22 -05:00
2017-07-15 11:48:09 -05:00
Sphinx runtime information
--------------------------
The application object also provides runtime information as attributes.
.. attribute:: srcdir
Source directory.
.. attribute:: confdir
Directory containing ``conf.py``.
.. attribute:: doctreedir
Directory for storing pickled doctrees.
.. attribute:: outdir
Directory for storing built document.
2008-03-12 16:37:22 -05:00
.. _events:
Sphinx core events
------------------
These events are known to the core. The arguments shown are given to the
2014-03-26 01:30:48 -05:00
registered event handlers. Use :meth:`.connect` in an extension's ``setup``
function (note that ``conf.py`` can also have a ``setup`` function) to connect
handlers to the events. Example:
.. code-block:: python
def source_read_handler(app, docname, source):
print('do something here...')
def setup(app):
app.connect('source-read', source_read_handler)
.. event:: builder-inited (app)
Emitted when the builder object has been created. It is available as
``app.builder``.
2018-01-20 06:09:12 -06:00
.. event:: config-inited (app, config)
Emitted when the config object has been initialized.
.. versionadded:: 1.8
.. event:: env-get-outdated (app, env, added, changed, removed)
Emitted when the environment determines which source files have changed and
should be re-read. *added*, *changed* and *removed* are sets of docnames
that the environment has determined. You can return a list of docnames to
re-read in addition to these.
.. versionadded:: 1.1
.. event:: env-purge-doc (app, env, docname)
Emitted when all traces of a source file should be cleaned from the
environment, that is, if the source file is removed or before it is freshly
read. This is for extensions that keep their own caches in attributes of the
environment.
For example, there is a cache of all modules on the environment. When a
source file has been changed, the cache's entries for the file are cleared,
since the module declarations could have been removed from the file.
.. versionadded:: 0.5
.. event:: env-before-read-docs (app, env, docnames)
Emitted after the environment has determined the list of all added and
changed files and just before it reads them. It allows extension authors to
reorder the list of docnames (*inplace*) before processing, or add more
2014-09-22 07:51:47 -05:00
docnames that Sphinx did not consider changed (but never add any docnames
that are not in ``env.found_docs``).
You can also remove document names; do this with caution since it will make
Sphinx treat changed files as unchanged.
.. versionadded:: 1.3
2008-10-16 14:04:45 -05:00
.. event:: source-read (app, docname, source)
Emitted when a source file has been read. The *source* argument is a list
whose single element is the contents of the source file. You can process the
contents and replace this item to implement source-level transformations.
For example, if you want to use ``$`` signs to delimit inline math, like in
LaTeX, you can use a regular expression to replace ``$...$`` by
``:math:`...```.
2008-10-16 14:04:45 -05:00
.. versionadded:: 0.5
.. event:: doctree-read (app, doctree)
Emitted when a doctree has been parsed and read by the environment, and is
about to be pickled. The *doctree* can be modified in-place.
.. event:: missing-reference (app, env, node, contnode)
Emitted when a cross-reference to a Python module or object cannot be
resolved. If the event handler can resolve the reference, it should return a
new docutils node to be inserted in the document tree in place of the node
*node*. Usually this node is a :class:`reference` node containing *contnode*
as a child.
:param env: The build environment (``app.builder.env``).
:param node: The :class:`pending_xref` node to be resolved. Its attributes
``reftype``, ``reftarget``, ``modname`` and ``classname`` attributes
determine the type and target of the reference.
:param contnode: The node that carries the text and formatting inside the
future reference and should be a child of the returned reference node.
.. versionadded:: 0.5
.. event:: doctree-resolved (app, doctree, docname)
Emitted when a doctree has been "resolved" by the environment, that is, all
references have been resolved and TOCs have been inserted. The *doctree* can
be modified in place.
Here is the place to replace custom nodes that don't have visitor methods in
the writers, so that they don't cause errors when the writers encounter them.
.. event:: env-merge-info (env, docnames, other)
This event is only emitted when parallel reading of documents is enabled. It
is emitted once for every subprocess that has read some documents.
You must handle this event in an extension that stores data in the
environment in a custom location. Otherwise the environment in the main
process will not be aware of the information stored in the subprocess.
*other* is the environment object from the subprocess, *env* is the
environment from the main process. *docnames* is a set of document names
that have been read in the subprocess.
For a sample of how to deal with this event, look at the standard
``sphinx.ext.todo`` extension. The implementation is often similar to that
of :event:`env-purge-doc`, only that information is not removed, but added to
the main environment from the other environment.
.. versionadded:: 1.3
.. event:: env-updated (app, env)
Emitted when the :meth:`update` method of the build environment has
completed, that is, the environment and all doctrees are now up-to-date.
You can return an iterable of docnames from the handler. These documents
will then be considered updated, and will be (re-)written during the writing
phase.
.. versionadded:: 0.5
.. versionchanged:: 1.3
The handlers' return value is now used.
.. event:: env-check-consistency (env)
2018-01-20 06:09:47 -06:00
Emitted when Consistency checks phase. You can check consistency of
metadata for whole of documents.
.. versionadded:: 1.6
2017-05-07 02:13:19 -05:00
As a **experimental** event
2010-01-13 16:42:58 -06:00
.. event:: html-collect-pages (app)
Emitted when the HTML builder is starting to write non-document pages. You
can add pages to write by returning an iterable from this event consisting of
``(pagename, context, templatename)``.
.. versionadded:: 1.0
.. event:: html-page-context (app, pagename, templatename, context, doctree)
Emitted when the HTML builder has created a context dictionary to render a
template with -- this can be used to add custom elements to the context.
The *pagename* argument is the canonical name of the page being rendered,
that is, without ``.html`` suffix and using slashes as path separators. The
*templatename* is the name of the template to render, this will be
``'page.html'`` for all pages from reST documents.
The *context* argument is a dictionary of values that are given to the
template engine to render the page and can be modified to include custom
values. Keys must be strings.
The *doctree* argument will be a doctree when the page is created from a reST
documents; it will be ``None`` when the page is created from an HTML template
alone.
You can return a string from the handler, it will then replace
``'page.html'`` as the HTML template for this page.
.. versionadded:: 0.4
.. versionchanged:: 1.3
The return value can now specify a template name.
2008-08-06 08:04:14 -05:00
.. event:: build-finished (app, exception)
Emitted when a build has finished, before Sphinx exits, usually used for
cleanup. This event is emitted even when the build process raised an
exception, given as the *exception* argument. The exception is reraised in
the application after the event handlers have run. If the build process
raised no exception, *exception* will be ``None``. This allows to customize
cleanup actions depending on the exception status.
.. versionadded:: 0.5
Checking the Sphinx version
---------------------------
.. currentmodule:: sphinx
Use this to adapt your extension to API changes in Sphinx.
.. autodata:: version_info
The Config object
-----------------
.. currentmodule:: sphinx.config
2013-10-12 14:01:25 -05:00
.. autoclass:: Config
.. _template-bridge:
The template bridge
-------------------
.. currentmodule:: sphinx.application
.. autoclass:: TemplateBridge
:members:
2014-01-21 02:54:31 -06:00
.. _exceptions:
Exceptions
----------
.. module:: sphinx.errors
.. autoexception:: SphinxError
2014-01-21 02:54:31 -06:00
.. autoexception:: ConfigError
2014-01-21 02:54:31 -06:00
.. autoexception:: ExtensionError
2014-01-21 02:54:31 -06:00
.. autoexception:: ThemeError
2014-01-21 02:54:31 -06:00
.. autoexception:: VersionRequirementError