From 2fd79c73896576540b30969bdd748a3753279dcf Mon Sep 17 00:00:00 2001 From: Hynek Schlawack Date: Sat, 16 Mar 2024 16:43:55 +0100 Subject: [PATCH 1/3] Deprecate attr.s's repr_ns It's pointless in Python 3. define et al never had it. --- src/attr/_make.py | 14 +++++++++++++- tests/test_make.py | 12 +++++++----- 2 files changed, 20 insertions(+), 6 deletions(-) diff --git a/src/attr/_make.py b/src/attr/_make.py index 8fadc64e8..79c6afd85 100644 --- a/src/attr/_make.py +++ b/src/attr/_make.py @@ -1354,7 +1354,8 @@ def attrs( :param str repr_ns: When using nested classes, there was no way in Python 2 to automatically detect that. This argument allows to set a custom - name for a more meaningful ``repr`` output. + name for a more meaningful ``repr`` output. This argument + is pointless in Python 3 and is therefore deprecated. :param bool auto_detect: Instead of setting the *init*, *repr*, *eq*, *order*, and *hash* arguments explicitly, assume they are set to ``True`` **unless any** of the involved methods for one of the @@ -1597,7 +1598,18 @@ def attrs( .. versionadded:: 21.3.0 *match_args* .. versionadded:: 22.2.0 *unsafe_hash* as an alias for *hash* (for :pep:`681` compliance). + .. deprecated:: 24.1.0 *repr_ns* """ + if repr_ns is not None: + import warnings + + warnings.warn( + DeprecationWarning( + "The `repr_ns` argument is deprecated in will be removed in or after April 2025." + ), + stacklevel=2, + ) + eq_, order_ = _determine_attrs_eq_order(cmp, eq, order, None) # unsafe_hash takes precedence due to PEP 681. diff --git a/tests/test_make.py b/tests/test_make.py index 1760964bd..e0e0aa96b 100644 --- a/tests/test_make.py +++ b/tests/test_make.py @@ -600,11 +600,13 @@ def test_repr_fake_qualname(self, slots_outer, slots_inner): Setting repr_ns overrides a potentially guessed namespace. """ - @attr.s(slots=slots_outer) - class C: - @attr.s(repr_ns="C", slots=slots_inner) - class D: - pass + with pytest.deprecated_call(match="The `repr_ns` argument"): + + @attr.s(slots=slots_outer) + class C: + @attr.s(repr_ns="C", slots=slots_inner) + class D: + pass assert "C.D()" == repr(C.D()) From b467a115c4429cc611ad04c6a772c9b2de38d8a4 Mon Sep 17 00:00:00 2001 From: Hynek Schlawack Date: Sat, 16 Mar 2024 16:45:26 +0100 Subject: [PATCH 2/3] Add news fragment --- changelog.d/1263.deprecation.md | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 changelog.d/1263.deprecation.md diff --git a/changelog.d/1263.deprecation.md b/changelog.d/1263.deprecation.md new file mode 100644 index 000000000..25939511b --- /dev/null +++ b/changelog.d/1263.deprecation.md @@ -0,0 +1,2 @@ +The *repr_ns* argument to `attr.s` is now deprecated. +It was a workaround for nested classes in Python 2 and is pointless in Python 3. From 20211706ec74f366c841c3ab7ae79891f448194e Mon Sep 17 00:00:00 2001 From: Hynek Schlawack Date: Sat, 16 Mar 2024 16:46:02 +0100 Subject: [PATCH 3/3] Fix typo --- src/attr/_make.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/attr/_make.py b/src/attr/_make.py index 79c6afd85..710c6179c 100644 --- a/src/attr/_make.py +++ b/src/attr/_make.py @@ -1605,7 +1605,7 @@ def attrs( warnings.warn( DeprecationWarning( - "The `repr_ns` argument is deprecated in will be removed in or after April 2025." + "The `repr_ns` argument is deprecated and will be removed in or after April 2025." ), stacklevel=2, )