mirror of
https://github.com/python-pillow/Pillow.git
synced 2024-11-15 22:26:55 +03:00
c9acb9b387
Co-authored-by: Andrew Murray <3112309+radarhere@users.noreply.github.com>
67 lines
1.8 KiB
Python
67 lines
1.8 KiB
Python
from __future__ import annotations
|
|
|
|
import warnings
|
|
|
|
from . import __version__
|
|
|
|
|
|
def deprecate(
|
|
deprecated: str,
|
|
when: int | None,
|
|
replacement: str | None = None,
|
|
*,
|
|
action: str | None = None,
|
|
plural: bool = False,
|
|
) -> None:
|
|
"""
|
|
Deprecations helper.
|
|
|
|
:param deprecated: Name of thing to be deprecated.
|
|
:param when: Pillow major version to be removed in.
|
|
:param replacement: Name of replacement.
|
|
:param action: Instead of "replacement", give a custom call to action
|
|
e.g. "Upgrade to new thing".
|
|
:param plural: if the deprecated thing is plural, needing "are" instead of "is".
|
|
|
|
Usually of the form:
|
|
|
|
"[deprecated] is deprecated and will be removed in Pillow [when] (yyyy-mm-dd).
|
|
Use [replacement] instead."
|
|
|
|
You can leave out the replacement sentence:
|
|
|
|
"[deprecated] is deprecated and will be removed in Pillow [when] (yyyy-mm-dd)"
|
|
|
|
Or with another call to action:
|
|
|
|
"[deprecated] is deprecated and will be removed in Pillow [when] (yyyy-mm-dd).
|
|
[action]."
|
|
"""
|
|
|
|
is_ = "are" if plural else "is"
|
|
|
|
if when is None:
|
|
removed = "a future version"
|
|
elif when <= int(__version__.split(".")[0]):
|
|
raise RuntimeError(f"{deprecated} {is_} deprecated and should be removed.")
|
|
elif when == 10:
|
|
removed = "Pillow 10 (2023-07-01)"
|
|
else:
|
|
raise ValueError(f"Unknown removal version, update {__name__}?")
|
|
|
|
if replacement and action:
|
|
raise ValueError("Use only one of 'replacement' and 'action'")
|
|
|
|
if replacement:
|
|
action = f". Use {replacement} instead."
|
|
elif action:
|
|
action = f". {action.rstrip('.')}."
|
|
else:
|
|
action = ""
|
|
|
|
warnings.warn(
|
|
f"{deprecated} {is_} deprecated and will be removed in {removed}{action}",
|
|
DeprecationWarning,
|
|
stacklevel=3,
|
|
)
|