The Sphinx documentation generator
Go to file
Jeremy Maitin-Shepard ac1b0d490c [C++] Support requires-clause in more places
Previously a C++20 requires-clause was only supported on `function`
declarations.  However, the C++ standard allows a require-clause on
class/union templates, alias templates, and variable templates, and
also allows a requires clause after each template parameter list, not
just the final one.

This moves the requiresClause to be a property of `ASTTemplateParams`
rather than `ASTDeclaration` to better match the C++ grammar and
allows requires clauses in many places that are supported by C++20 but
were not previously allowed by Sphinx, namely:

- On class templates, alias templates, and variable templates

- After each template parameter list, not just the last one.

- After the template parameter list in template template parameters.

When encoding the id, the requires clause of the last template
parameter list is treated specially in order to preserve compatibility
with existing v4 ids.
2022-07-24 21:37:56 +02:00
.circleci CircleCI: Test with python 3.8 2021-05-23 02:21:32 +09:00
.github Use released Docutils 0.19 on CI 2022-07-06 19:18:10 +01:00
doc Update include_patterns implementation (#10680) 2022-07-23 21:19:35 +01:00
sphinx [C++] Support requires-clause in more places 2022-07-24 21:37:56 +02:00
tests [C++] Support requires-clause in more places 2022-07-24 21:37:56 +02:00
utils Replace doclinter with sphinx-lint (#10389) 2022-06-16 19:32:09 +01:00
.codecov.yml Revert "Enable patch status check for Codecov" 2020-03-15 11:09:06 +09:00
.gitignore C++, add support for parameterized noexcept specifier in function declarations 2020-04-24 23:59:41 +02:00
.readthedocs.yml doc: Build PDF document on readthedocs 2021-02-17 00:32:47 +09:00
AUTHORS Tweak headings 2022-07-18 23:05:34 +01:00
babel.cfg doc: Upgraded babel.pocoo.org links to HTTPS 2021-05-16 16:37:51 +03:00
bindep.txt Update bindep.txt for LaTeX pict2e.sty optional dependency 2022-07-18 19:26:08 +02:00
CHANGES Bump version 2022-07-24 13:20:14 +01:00
CHANGES.old changelog: split off older changes (pre-1.0) to a CHANGES.old file 2013-03-29 13:05:49 +01:00
CODE_OF_CONDUCT docs: Tweaks to code of conduct 2020-06-02 12:10:24 +01:00
CONTRIBUTING.rst Minor typo in the contributing info 2020-12-16 12:09:17 -05:00
EXAMPLES Merge branch '4.x' into 5.0.x 2022-05-28 23:17:46 +09:00
karma.conf.js Drop JavaScript Frameworks (#10028) 2022-01-30 20:27:12 +01:00
LICENSE Add catch-all text to LICENSE 2022-02-20 03:31:33 +00:00
Makefile Replace doclinter with sphinx-lint (#10389) 2022-06-16 19:32:09 +01:00
MANIFEST.in Fix py.typed file not being included in source archive 2021-03-05 14:19:22 +03:00
package-lock.json Merge branch '4.x' into 5.x 2022-04-03 00:33:25 +09:00
package.json Merge branch '4.x' 2022-03-19 22:58:15 +09:00
README.rst Add GPG key for Adam Turner 2022-07-17 23:03:38 +01:00
setup.cfg Lint with flake8-bugbear (#10602) 2022-07-12 22:55:57 +01:00
setup.py Merge branch '5.0.x' into 5.x 2022-07-23 15:17:08 +09:00
tox.ini Update documentation structure and theming (#10677) 2022-07-18 22:48:28 +01:00

========
 Sphinx
========

.. image:: https://img.shields.io/pypi/v/sphinx.svg
   :target: https://pypi.org/project/Sphinx/
   :alt: Package on PyPI

.. image:: https://github.com/sphinx-doc/sphinx/actions/workflows/main.yml/badge.svg
   :target: https://github.com/sphinx-doc/sphinx/actions/workflows/main.yml
   :alt: Build Status

.. image:: https://readthedocs.org/projects/sphinx/badge/?version=master
   :target: https://www.sphinx-doc.org/
   :alt: Documentation Status

.. image:: https://img.shields.io/badge/License-BSD%202--Clause-blue.svg
   :target: https://opensource.org/licenses/BSD-2-Clause
   :alt: BSD 2 Clause

**Sphinx makes it easy to create intelligent and beautiful documentation.**

Sphinx uses reStructuredText as its markup language, and many of its strengths
come from the power and straightforwardness of reStructuredText and its parsing
and translating suite, the Docutils.

Features
========

* **Output formats**: HTML, PDF, plain text, EPUB, TeX, manual pages, and more
* **Extensive cross-references**: semantic markup and automatic links
  for functions, classes, glossary terms and similar pieces of information
* **Hierarchical structure**: easy definition of a document tree, with automatic
  links to siblings, parents and children
* **Automatic indices**: general index as well as a module index
* **Code highlighting**: automatic highlighting using the Pygments highlighter
* **Templating**: Flexible HTML output using the Jinja 2 templating engine
* **Extension ecosystem**: Many extensions are available, for example for
  automatic function documentation or working with Jupyter notebooks.
* **Language Support**: Python, C, C++, JavaScript, mathematics, and many other
  languages through extensions.

For more information, refer to the `the documentation`_.

Installation
============

The following command installs Sphinx from the `Python Package Index`_. You will
need a working installation of Python and pip.

.. code-block:: sh

   pip install -U sphinx

Contributing
============

We appreciate all contributions! Refer to `the contributors guide`_ for
information.

Release signatures
==================

Releases are signed with following keys:

* `498D6B9E <https://pgp.mit.edu/pks/lookup?op=vindex&search=0x102C2C17498D6B9E>`_
* `5EBA0E07 <https://pgp.mit.edu/pks/lookup?op=vindex&search=0x1425F8CE5EBA0E07>`_
* `61F0FB52 <https://pgp.mit.edu/pks/lookup?op=vindex&search=0x52C8F72A61F0FB52>`_

.. _the documentation: https://www.sphinx-doc.org/
.. _the contributors guide: https://www.sphinx-doc.org/en/master/internals/contributing.html
.. _Python Package Index: https://pypi.org/project/Sphinx/