Docutils | Overview | Enhancement Proposals

EP 10 — Public API and Backwards Compatibility Policy

Authors:

Günter Milde

Adam Turner

Discussions-To:

https://sourceforge.net/p/docutils/feature-requests/89/

Status:
Draft
Type:

Process

Created:

2025-04-22

Docutils-Version:

0.23

Abstract

This document suggests a definition of the public API provided by the Docutils project and the backwards compatibility policy.

Motivation

Docutils has a large user base and is used in production at several places (Python documentation, Linux kernel documentation, CMake documentation, readthedocs, ...). OTOH, Docutils has a version number below 1.0 (widely seen as an indicator of "beta" status of a project).

The current Docutils Project Policies section on version identification concentrates on the formal definition of the version specifier but leaves open what consists a "major change in the design or API".

The current backwards compatibility policy is a stub referencing PEP 387.

Rationale

Clearly defining how we will balance evolution with stability is important to both users and project developers.

People affected by changes in Docutils include:

Authors

writing or maintaining reStructuredText documents.

End-Users

of the Docutils front-end tools (optionally with 3rd-party drop-in extensions) or alternative tools using Docutils either as a library (Sphinx, …) or via the command line interface (build systems, Makefiles, scripts in other languages).

Developers

i.e. authors and maintainers of

A person may belong to more than one of these categories.

Public API

Docutils' public API includes:

Exemptions:

Backwards Compatibility

Beginning with version 1.0, Docutils will follow the rules of Semantic Versioning. All incompatible changes to the public APIs require increasing the major part of the version specifier. Backwards compatible changes can be done in minor releases.

Security Implications

If required, critical bug fixes may change the public API without advance warning.

How to Teach This

Rejected Ideas

Use type annotations as an indication of status in the public API.

Use Calendar Versioning (CalVer).

Allow breaking API changes in minor versions after prior announcement and a deprecation period.

Mark all internal objects with a prefix underscore.

Use the __all__ attribute to declare modules, classes, and functions that form the public API.

Open Issues

References