Skip to main content

Display a warning at the top of module documentation that it has additional requirements.

Project description

Travis Build Status Documentation Status PyPI PyPI - Python Version PyPI - Wheel PyPI - Implementation License GitHub top language GitHub commits since tagged version GitHub last commit Maintenance CodeFactor Grade

Display a warning at the top of module documentation that it has additional requirements.


Overview

This extension assumes you have a repository laid out like this:

/
├── chemistry_tools
│   ├── __init__.py
│   ├── formulae
│   │   ├── __init__.py
│   │   ├── compound.py
│   │   ├── formula.py
│   │   ├── parser.py
│   │   └── requirements.txt
│   ├── constants.py
│   └── utils.py
├── doc-source
│   ├── api
│   │   ├── chemistry_tools.rst
│   │   ├── elements.rst
│   │   ├── formulae.rst
│   │   └── pubchem.rst
│   ├── conf.py
│   ├── index.rst
│   └── requirements.txt
├── LICENSE
├── README.rst
├── requirements.txt
├── setup.py
└── tox.ini

The file /chemistry_tools/formulae/requirements.txt contains the additional requirements to run the formulae subpackage. These would be defined in setup.py like this:

setup(
    extras_require = {
        'formulae': [
            'mathematical>=0.1.7',
            'pandas>=1.0.1',
            'pyparsing>=2.2.0',
            'tabulate>=0.8.3',
            'cawdrey>=0.1.2',
            'quantities>=0.12.4',
            ],
    }
)

A message can be displayed in the documentation to indicate that the subpackage has these additional requirements that must be installed.

For instance, this:

.. extras-require::
    :file: formulae/requirements.txt
    :extra: formulae

will look like this:

.images/example.png

The path given in :file: is relative to the package_root variable given in conf.py, which in turn is relative to the parent directory of the sphinx documentation.

i.e, this line:

package_root = "chemistry_tools"

points to /chemistry_tools, and therefore :file: formulae/requirements.txt points to /chemistry_tools/formulae/requirements.txt.

Installation

extras_require can be installed with pip:

$ python -m pip install extras_require

Enable extras_require by adding the following line to the extensions variable in conf.py:

"sphinxcontrib.extras_require",

For more information see https://www.sphinx-doc.org/en/master/usage/extensions/index.html#third-party-extensions .

Future Enhancements

  • Allow use of different “scopes”, e.g. package, module, class, function, depending on what the additional requirements are for.

  • Support different methods of defining the requirements, e.g. setup.cfg, setup.py, __pkginfo__.py, pyproject.toml, or typing as entries in the directive itself.

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

extras_require-0.0.2.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

extras_require-0.0.2-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file extras_require-0.0.2.tar.gz.

File metadata

  • Download URL: extras_require-0.0.2.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.7

File hashes

Hashes for extras_require-0.0.2.tar.gz
Algorithm Hash digest
SHA256 c8c25304d5385817cda382829dcdbee5500f832a41f13639bd26f89436d0fa33
MD5 38527b86f015e47ec3f09d3ad5ab3db0
BLAKE2b-256 2c70675310c71ab2540aa371cc5582229519c4f4890b7e0f7e83cb95c6c3722b

See more details on using hashes here.

File details

Details for the file extras_require-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: extras_require-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 6.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.7

File hashes

Hashes for extras_require-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 54e1f84b74ceeaa4e768b9e84d09629980bdcde76ebac4709017a62946b8adfd
MD5 4b67002d9afa5df29a2d59b312b46473
BLAKE2b-256 f092cd39b9821b50c5d5c55bc992399dcda2bb6f9400f783a70b752f6bfce6ea

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