Skip to main content

render CLI arguments (sub-commands friendly) defined by argparse module

Project description

sphinx-argparse-cli

PyPI PyPI - Implementation PyPI - Python Version Downloads PyPI - License check

Render CLI arguments (sub-commands friendly) defined by the argparse module.

Getting started

Install the package:

python -m pip install sphinx-argparse-cli

Add the extension to your conf.py:

extensions = ["sphinx_argparse_cli"]

Use the directive in any reStructuredText file:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser

:module: points to the Python module containing the parser, and :func: names a zero-argument function that returns an ArgumentParser. Build your docs and the full CLI reference appears automatically.

How-to guides

Override the program name

By default the program name comes from the parser. Use :prog: to replace it:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :prog: my-cli

Hook into a parser that is not returned

When a function creates and uses a parser internally without returning it, set the :hook: flag to intercept argparse.ArgumentParser:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: main
  :hook:
  :prog: my-cli

Customize section titles

Control how group and subcommand headings are rendered with :group_title_prefix: and :group_sub_title_prefix:. Both accept {prog} and the sub-title also accepts {subcommand}:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :group_title_prefix: {prog}
  :group_sub_title_prefix: {prog} {subcommand}

Suppress default values

Hide (default: ...) annotations from the output:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :no_default_values:

Control usage display

Set the character width for usage lines and optionally show usage before the description:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :usage_width: 80
  :usage_first:

Override title, description, or epilog

Replace auto-detected values, or pass an empty string to suppress them entirely:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :title: Custom Title
  :description: Custom description text.
  :epilog:

Cross-reference generated anchors

The directive registers Sphinx reference labels for every command, group, and flag. Use the :ref: role to link to them.

With sphinx_argparse_cli_prefix_document = False (default):

:ref:`tox-optional-arguments`
:ref:`tox-run`
:ref:`tox-run---magic`

With sphinx_argparse_cli_prefix_document = True (anchors prefixed by document name, avoids clashes across documents):

:ref:`cli:tox-optional-arguments`
:ref:`cli:tox-run`
:ref:`cli:tox-run---magic`

The anchor text is visible after the # in the URL when you click a heading.

Handle mixed-case references

Sphinx :ref: only supports lower-case targets. When your program name or flags contain capital letters, set :force_refs_lower: to convert them — each upper-case letter becomes its lower-case form prefixed with _ (e.g. A becomes _a):

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser
  :force_refs_lower:

For a program named SampleProgram:

:ref:`_sample_program--a`   .. flag -a
:ref:`_sample_program--_a`  .. flag -A

If you do not need Sphinx :ref: cross-references you can leave this off to keep mixed-case anchors in the HTML output, but enabling it later will change existing anchor URLs.

Add extra content after generated docs

Any content nested inside the directive is appended after the generated CLI documentation:

.. sphinx_argparse_cli::
  :module: my_project.cli
  :func: build_parser

  Extra notes or examples rendered after the CLI reference.

Reference

Directive options

Option Type Default Description
:module: string required Python module path where the parser is defined
:func: string required Zero-argument function that returns an ArgumentParser
:prog: string parser's prog Override the displayed program name
:hook: flag off Intercept ArgumentParser instead of expecting func to return it
:title: string <prog> - CLI interface Custom title; empty string suppresses it
:description: string parser's description Custom description; empty string suppresses it
:epilog: string parser's epilog Custom epilog; empty string suppresses it
:usage_width: int 100 Character width for usage lines
:usage_first: flag off Show usage before the description
:group_title_prefix: string {prog} Heading prefix for groups; {prog} is replaced with the program name
:group_sub_title_prefix: string {prog} {subcommand} Heading prefix for subcommand groups; supports {prog} and {subcommand}
:no_default_values: flag off Suppress (default: ...) annotations
:force_refs_lower: flag off Lower-case reference anchors with _ prefix for capitals (for :ref: compat)

Configuration values (conf.py)

Name Type Default Description
sphinx_argparse_cli_prefix_document bool False Prefix reference anchors with the document name to avoid clashes

Live examples

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

sphinx_argparse_cli-1.21.2.tar.gz (14.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sphinx_argparse_cli-1.21.2-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file sphinx_argparse_cli-1.21.2.tar.gz.

File metadata

  • Download URL: sphinx_argparse_cli-1.21.2.tar.gz
  • Upload date:
  • Size: 14.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sphinx_argparse_cli-1.21.2.tar.gz
Algorithm Hash digest
SHA256 8bd51f4c605d0b6271e2803a1bc4a25cf88884b9c6204e7f8e0b5341b7f49960
MD5 988cb9f6f9054ad679a565163a53eb71
BLAKE2b-256 eee47da4b6df073898ccd0d1c1c7a7ad45bc53d37650b0650027db6f76b5e69d

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_argparse_cli-1.21.2.tar.gz:

Publisher: release.yaml on tox-dev/sphinx-argparse-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sphinx_argparse_cli-1.21.2-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_argparse_cli-1.21.2-py3-none-any.whl
Algorithm Hash digest
SHA256 11beba2f8f9a2f3ce395538edc65d33de611e7cda7202117a5781f820e62092d
MD5 f5a5a23abbf6a98207f92ab6ca4f280a
BLAKE2b-256 598ddca99a327ecde245ed08ed48a52fb5da57304fa5597fe136b16e9a900356

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_argparse_cli-1.21.2-py3-none-any.whl:

Publisher: release.yaml on tox-dev/sphinx-argparse-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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