Skip to main content

A Sphinx extension for rendering terminal input and output.

Project description

sphinx-terminal

sphinx-terminal allows you to display terminal input and output in your Sphinx documentation.

Basic usage

To display terminal input and output in your Sphinx document, use the terminal directive, providing input and output as follows:

.. terminal::

    input

    output

Input can span multiple lines, as long as the lines are in the same paragraph. Everything after the first blank line in the directive's body is rendered as output.

The prompt defaults to user@host:~$. To customize this, use the :user:, :host:, and :dir: options.

.. terminal::
    :user: author
    :host: canonical
    :dir: ~/path

    echo 'hello'

    hello

To render only the output of a command, include the :output-only: flag in the directive's options.

.. terminal::
    :output-only:

    This is rendered as output.

To enable a copy button for users, include the :copy: flag as a directive option. Only the input can be copied.

.. terminal::
    :copy:

    echo 'hello'

    hello

Similarly, to make the output scrollable, include the :scroll: flag as a directive option.

.. terminal::
    :scroll:

    echo 'hello'

    hello

Project setup

sphinx-terminal is published on PyPI and can be installed with:

pip install sphinx-terminal

After adding sphinx-terminal to your Python project, update Sphinx's conf.py file to include sphinx-terminal as one of its extensions:

extensions = [
    "sphinx_terminal"
]

The copy button functionality depends on sphinx-copybutton. sphinx-terminal automatically adds this extension to your Sphinx project and configures it to copy terminal input and ignore the multiline prompt.

copybutton_selector = "span.copybutton, div:not(.terminal-code) > div.highlight > pre"
copybutton_prompt_text = "> |"
copybutton_prompt_is_regexp = True

Customizing these configurations in your conf.py file overrides the defaults assigned by sphinx-terminal.

Community and support

You can report any issues or bugs on the project's GitHub repository.

If you're interested in contributing, start with the contribution guide.

sphinx-terminal is covered by the Ubuntu Code of Conduct.

License and copyright

sphinx-terminal is released under the GPL-3.0 license.

© 2025 Canonical Ltd.

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_terminal-1.0.1.tar.gz (95.4 kB view details)

Uploaded Source

Built Distribution

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

sphinx_terminal-1.0.1-py3-none-any.whl (20.1 kB view details)

Uploaded Python 3

File details

Details for the file sphinx_terminal-1.0.1.tar.gz.

File metadata

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

File hashes

Hashes for sphinx_terminal-1.0.1.tar.gz
Algorithm Hash digest
SHA256 3ad300675eca34488e0170cbc863ae1f3ff17e289779075eba7942d06dfb6f52
MD5 11a6243031a7a99c1a6769bb726802a7
BLAKE2b-256 264165cea3d6b69fea87f338facea775a106d857da762c8a34f0f85f1faa3220

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_terminal-1.0.1.tar.gz:

Publisher: release-publish.yaml on canonical/sphinx-terminal

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_terminal-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_terminal-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 71cee75c1da8fecc5cbef1473275122ebca8ec5a7bc8c2fee9373653f09afd6f
MD5 1ba07978d3813bf66c8fb54fdcae88aa
BLAKE2b-256 650984ad176912ec2212ab0a056a1320dbdd55446d3e17d874a42312ba52afb8

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_terminal-1.0.1-py3-none-any.whl:

Publisher: release-publish.yaml on canonical/sphinx-terminal

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