-
-
Notifications
You must be signed in to change notification settings - Fork 783
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added deprecation workflow in CPython.
- Loading branch information
1 parent
b37e007
commit f2fd360
Showing
2 changed files
with
81 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
Workflow for Deprecating Features in CPython | ||
============================================== | ||
|
||
Deprecation in CPython is a multi-step process that involves notifying users about deprecated functionality, planning its eventual removal, and providing adequate guidance for migration. | ||
This document outlines the practical steps required for deprecating a feature, supplementing the policy guidelines defined in :pep:`387`. | ||
|
||
1. Identify Features for Deprecation | ||
------------------------------------ | ||
Before proposing deprecation: | ||
|
||
* **Assess Usage**: Use tools like GitHub search, `grep`, or PyPI statistics to determine the extent and context of usage. | ||
* **Consider Alternatives**: Ensure there are suitable replacements or upgrades available. | ||
|
||
2. Open an Issue | ||
---------------- | ||
Start by creating a GitHub issue to propose the deprecation: | ||
|
||
* Clearly describe the feature and why deprecation is needed. | ||
* Encourage community feedback and suggestions. | ||
|
||
3. Deprecation Implementation | ||
----------------------------- | ||
Once approved: | ||
|
||
* **Raise a Warning**: Use :func:`warnings.warn` with :exc:`DeprecationWarning` for typical cases. | ||
If the feature is in its early deprecation phase: | ||
|
||
* Use :exc:`PendingDeprecationWarning` initially, which transitions to :exc:`DeprecationWarning` after a suitable period. | ||
|
||
Example: | ||
|
||
.. code-block:: python | ||
import warnings | ||
warnings.warn( | ||
"Feature X is deprecated and will be removed in Python 3.Y", | ||
DeprecationWarning, | ||
stacklevel=2 | ||
) | ||
* **Update Documentation**: | ||
|
||
* Add a deprecation note in the relevant docstrings. | ||
* Include details in the "Porting" section of the "What's New" documentation. | ||
* Update the ``pending-removal-in-{version}.rst`` file with the deprecation timeline. | ||
|
||
4. Track Deprecations | ||
--------------------- | ||
* **Monitor Usage**: After the release, observe community feedback. Deprecations may remain longer than the minimum period if low maintenance overhead is expected or usage is widespread. | ||
* **Timeline Review**: Use GitHub milestones or specific deprecation tracking issues to manage timelines. | ||
|
||
5. Plan Removal | ||
--------------- | ||
After the deprecation period (typically 2+ releases): | ||
|
||
* Open a new issue for removal. | ||
* Follow removal steps: | ||
|
||
* Remove the deprecated code and warnings. | ||
* Update documentation, removing references to the deprecated feature. | ||
* Include the removal in the "What's New" for the release. | ||
|
||
6. PendingDeprecationWarning Workflow | ||
------------------------------------- | ||
For gradual deprecations: | ||
|
||
* **Use Case**: When you want to signal future deprecation but not yet alert end-users. | ||
* **Transition Timeline**: | ||
|
||
* Move from :exc:`PendingDeprecationWarning` to :exc:`DeprecationWarning` after one or more releases. | ||
|
||
* **Documentation**: | ||
|
||
* Mention the pending deprecation in “What’s New.” | ||
* No ``pending-removal-in`` entry is needed during this stage. | ||
|
||
7. References and Templates | ||
--------------------------- | ||
* Use ``.. deprecated::`` and ``.. removed::`` Sphinx roles for documentation. | ||
* Add ``See Also`` links to :pep:`387` and DevGuide for policy and process details. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters