diff env/lib/python3.7/site-packages/humanfriendly/sphinx.py @ 5:9b1c78e6ba9c draft default tip

"planemo upload commit 6c0a8142489327ece472c84e558c47da711a9142"
author shellac
date Mon, 01 Jun 2020 08:59:25 -0400
parents 79f47841a781
children
line wrap: on
line diff
--- a/env/lib/python3.7/site-packages/humanfriendly/sphinx.py	Thu May 14 16:47:39 2020 -0400
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,311 +0,0 @@
-# Human friendly input/output in Python.
-#
-# Author: Peter Odding <peter@peterodding.com>
-# Last Change: March 1, 2020
-# URL: https://humanfriendly.readthedocs.io
-
-"""
-Customizations for and integration with the Sphinx_ documentation generator.
-
-The :mod:`humanfriendly.sphinx` module uses the `Sphinx extension API`_ to
-customize the process of generating Sphinx based Python documentation. To
-explore the functionality this module offers its best to start reading
-from the :func:`setup()` function.
-
-.. _Sphinx: http://www.sphinx-doc.org/
-.. _Sphinx extension API: http://sphinx-doc.org/extdev/appapi.html
-"""
-
-# Standard library modules.
-import logging
-import types
-
-# External dependencies (if Sphinx is installed docutils will be installed).
-import docutils.nodes
-import docutils.utils
-
-# Modules included in our package.
-from humanfriendly.deprecation import get_aliases
-from humanfriendly.text import compact, dedent, format
-from humanfriendly.usage import USAGE_MARKER, render_usage
-
-# Public identifiers that require documentation.
-__all__ = (
-    "deprecation_note_callback",
-    "enable_deprecation_notes",
-    "enable_man_role",
-    "enable_pypi_role",
-    "enable_special_methods",
-    "enable_usage_formatting",
-    "logger",
-    "man_role",
-    "pypi_role",
-    "setup",
-    "special_methods_callback",
-    "usage_message_callback",
-)
-
-# Initialize a logger for this module.
-logger = logging.getLogger(__name__)
-
-
-def deprecation_note_callback(app, what, name, obj, options, lines):
-    """
-    Automatically document aliases defined using :func:`~humanfriendly.deprecation.define_aliases()`.
-
-    Refer to :func:`enable_deprecation_notes()` to enable the use of this
-    function (you probably don't want to call :func:`deprecation_note_callback()`
-    directly).
-
-    This function implements a callback for ``autodoc-process-docstring`` that
-    reformats module docstrings to append an overview of aliases defined by the
-    module.
-
-    The parameters expected by this function are those defined for Sphinx event
-    callback functions (i.e. I'm not going to document them here :-).
-    """
-    if isinstance(obj, types.ModuleType) and lines:
-        aliases = get_aliases(obj.__name__)
-        if aliases:
-            # Convert the existing docstring to a string and remove leading
-            # indentation from that string, otherwise our generated content
-            # would have to match the existing indentation in order not to
-            # break docstring parsing (because indentation is significant
-            # in the reStructuredText format).
-            blocks = [dedent("\n".join(lines))]
-            # Use an admonition to group the deprecated aliases together and
-            # to distinguish them from the autodoc entries that follow.
-            blocks.append(".. note:: Deprecated names")
-            indent = " " * 3
-            if len(aliases) == 1:
-                explanation = """
-                    The following alias exists to preserve backwards compatibility,
-                    however a :exc:`~exceptions.DeprecationWarning` is triggered
-                    when it is accessed, because this alias will be removed
-                    in a future release.
-                """
-            else:
-                explanation = """
-                    The following aliases exist to preserve backwards compatibility,
-                    however a :exc:`~exceptions.DeprecationWarning` is triggered
-                    when they are accessed, because these aliases will be
-                    removed in a future release.
-                """
-            blocks.append(indent + compact(explanation))
-            for name, target in aliases.items():
-                blocks.append(format("%s.. data:: %s", indent, name))
-                blocks.append(format("%sAlias for :obj:`%s`.", indent * 2, target))
-            update_lines(lines, "\n\n".join(blocks))
-
-
-def enable_deprecation_notes(app):
-    """
-    Enable documenting backwards compatibility aliases using the autodoc_ extension.
-
-    :param app: The Sphinx application object.
-
-    This function connects the :func:`deprecation_note_callback()` function to
-    ``autodoc-process-docstring`` events.
-
-    .. _autodoc: http://www.sphinx-doc.org/en/stable/ext/autodoc.html
-    """
-    app.connect("autodoc-process-docstring", deprecation_note_callback)
-
-
-def enable_man_role(app):
-    """
-    Enable the ``:man:`` role for linking to Debian Linux manual pages.
-
-    :param app: The Sphinx application object.
-
-    This function registers the :func:`man_role()` function to handle the
-    ``:man:`` role.
-    """
-    app.add_role("man", man_role)
-
-
-def enable_pypi_role(app):
-    """
-    Enable the ``:pypi:`` role for linking to the Python Package Index.
-
-    :param app: The Sphinx application object.
-
-    This function registers the :func:`pypi_role()` function to handle the
-    ``:pypi:`` role.
-    """
-    app.add_role("pypi", pypi_role)
-
-
-def enable_special_methods(app):
-    """
-    Enable documenting "special methods" using the autodoc_ extension.
-
-    :param app: The Sphinx application object.
-
-    This function connects the :func:`special_methods_callback()` function to
-    ``autodoc-skip-member`` events.
-
-    .. _autodoc: http://www.sphinx-doc.org/en/stable/ext/autodoc.html
-    """
-    app.connect("autodoc-skip-member", special_methods_callback)
-
-
-def enable_usage_formatting(app):
-    """
-    Reformat human friendly usage messages to reStructuredText_.
-
-    :param app: The Sphinx application object (as given to ``setup()``).
-
-    This function connects the :func:`usage_message_callback()` function to
-    ``autodoc-process-docstring`` events.
-
-    .. _reStructuredText: https://en.wikipedia.org/wiki/ReStructuredText
-    """
-    app.connect("autodoc-process-docstring", usage_message_callback)
-
-
-def man_role(role, rawtext, text, lineno, inliner, options={}, content=[]):
-    """
-    Convert a Linux manual topic to a hyperlink.
-
-    Using the ``:man:`` role is very simple, here's an example:
-
-    .. code-block:: rst
-
-        See the :man:`python` documentation.
-
-    This results in the following:
-
-      See the :man:`python` documentation.
-
-    As the example shows you can use the role inline, embedded in sentences of
-    text. In the generated documentation the ``:man:`` text is omitted and a
-    hyperlink pointing to the Debian Linux manual pages is emitted.
-    """
-    man_url = "https://manpages.debian.org/%s" % text
-    reference = docutils.nodes.reference(rawtext, docutils.utils.unescape(text), refuri=man_url, **options)
-    return [reference], []
-
-
-def pypi_role(role, rawtext, text, lineno, inliner, options={}, content=[]):
-    """
-    Generate hyperlinks to the Python Package Index.
-
-    Using the ``:pypi:`` role is very simple, here's an example:
-
-    .. code-block:: rst
-
-        See the :pypi:`humanfriendly` package.
-
-    This results in the following:
-
-      See the :pypi:`humanfriendly` package.
-
-    As the example shows you can use the role inline, embedded in sentences of
-    text. In the generated documentation the ``:pypi:`` text is omitted and a
-    hyperlink pointing to the Python Package Index is emitted.
-    """
-    pypi_url = "https://pypi.org/project/%s/" % text
-    reference = docutils.nodes.reference(rawtext, docutils.utils.unescape(text), refuri=pypi_url, **options)
-    return [reference], []
-
-
-def setup(app):
-    """
-    Enable all of the provided Sphinx_ customizations.
-
-    :param app: The Sphinx application object.
-
-    The :func:`setup()` function makes it easy to enable all of the Sphinx
-    customizations provided by the :mod:`humanfriendly.sphinx` module with the
-    least amount of code. All you need to do is to add the module name to the
-    ``extensions`` variable in your ``conf.py`` file:
-
-    .. code-block:: python
-
-       # Sphinx extension module names.
-       extensions = [
-           'sphinx.ext.autodoc',
-           'sphinx.ext.doctest',
-           'sphinx.ext.intersphinx',
-           'humanfriendly.sphinx',
-       ]
-
-    When Sphinx sees the :mod:`humanfriendly.sphinx` name it will import the
-    module and call its :func:`setup()` function. This function will then call
-    the following:
-
-    - :func:`enable_deprecation_notes()`
-    - :func:`enable_man_role()`
-    - :func:`enable_pypi_role()`
-    - :func:`enable_special_methods()`
-    - :func:`enable_usage_formatting()`
-
-    Of course more functionality may be added at a later stage. If you don't
-    like that idea you may be better of calling the individual functions from
-    your own ``setup()`` function.
-    """
-    enable_deprecation_notes(app)
-    enable_man_role(app)
-    enable_pypi_role(app)
-    enable_special_methods(app)
-    enable_usage_formatting(app)
-
-
-def special_methods_callback(app, what, name, obj, skip, options):
-    """
-    Enable documenting "special methods" using the autodoc_ extension.
-
-    Refer to :func:`enable_special_methods()` to enable the use of this
-    function (you probably don't want to call
-    :func:`special_methods_callback()` directly).
-
-    This function implements a callback for ``autodoc-skip-member`` events to
-    include documented "special methods" (method names with two leading and two
-    trailing underscores) in your documentation. The result is similar to the
-    use of the ``special-members`` flag with one big difference: Special
-    methods are included but other types of members are ignored. This means
-    that attributes like ``__weakref__`` will always be ignored (this was my
-    main annoyance with the ``special-members`` flag).
-
-    The parameters expected by this function are those defined for Sphinx event
-    callback functions (i.e. I'm not going to document them here :-).
-    """
-    if getattr(obj, "__doc__", None) and isinstance(obj, (types.FunctionType, types.MethodType)):
-        return False
-    else:
-        return skip
-
-
-def update_lines(lines, text):
-    """Private helper for ``autodoc-process-docstring`` callbacks."""
-    while lines:
-        lines.pop()
-    lines.extend(text.splitlines())
-
-
-def usage_message_callback(app, what, name, obj, options, lines):
-    """
-    Reformat human friendly usage messages to reStructuredText_.
-
-    Refer to :func:`enable_usage_formatting()` to enable the use of this
-    function (you probably don't want to call :func:`usage_message_callback()`
-    directly).
-
-    This function implements a callback for ``autodoc-process-docstring`` that
-    reformats module docstrings using :func:`.render_usage()` so that Sphinx
-    doesn't mangle usage messages that were written to be human readable
-    instead of machine readable. Only module docstrings whose first line starts
-    with :data:`.USAGE_MARKER` are reformatted.
-
-    The parameters expected by this function are those defined for Sphinx event
-    callback functions (i.e. I'm not going to document them here :-).
-    """
-    # Make sure we only modify the docstrings of modules.
-    if isinstance(obj, types.ModuleType) and lines:
-        # Make sure we only modify docstrings containing a usage message.
-        if lines[0].startswith(USAGE_MARKER):
-            # Convert the usage message to reStructuredText.
-            text = render_usage("\n".join(lines))
-            # Fill up the buffer with our modified docstring.
-            update_lines(lines, text)