]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.13] gh-151955: Allow more ParamSpec bounds (#152122)
authorJelle Zijlstra <jelle.zijlstra@gmail.com>
Wed, 24 Jun 2026 20:08:56 +0000 (13:08 -0700)
committerGitHub <noreply@github.com>
Wed, 24 Jun 2026 20:08:56 +0000 (20:08 +0000)
gh-151955: Allow more ParamSpec and TypeVarTuple bounds (#151956)

(cherry picked from commit 0fb82b46df7bc95c2ba816afba56ff6a6c51caaf)

Lib/test/test_typing.py
Misc/NEWS.d/next/Library/2026-06-22-18-01-00.gh-issue-151955.6u5iwm.rst [new file with mode: 0644]
Objects/typevarobject.c

index b3ef0ff4af94f3de8b7684e10565d66a811158bb..5e7f40c42b52e9dbf14c5aabc9ae2bacc5f59638 100644 (file)
@@ -10046,6 +10046,17 @@ class ParamSpecTests(BaseTestCase):
         self.assertEqual(G2[[int, str], float], list[C])
         self.assertEqual(G3[[int, str], float], list[C] | int)
 
+    def test_paramspec_bound(self):
+        P = ParamSpec('P', bound=[int, str])
+        self.assertEqual(P.__bound__, [int, str])
+        P2 = ParamSpec('P2', bound=(int, str))
+        self.assertEqual(P2.__bound__, (int, str))
+        obj = object()
+        P3 = ParamSpec('P3', bound=obj)
+        self.assertIs(P3.__bound__, obj)
+        P4 = ParamSpec('P4')
+        self.assertIs(P4.__bound__, None)
+
     def test_paramspec_gets_copied(self):
         # bpo-46581
         P = ParamSpec('P')
diff --git a/Misc/NEWS.d/next/Library/2026-06-22-18-01-00.gh-issue-151955.6u5iwm.rst b/Misc/NEWS.d/next/Library/2026-06-22-18-01-00.gh-issue-151955.6u5iwm.rst
new file mode 100644 (file)
index 0000000..243b330
--- /dev/null
@@ -0,0 +1,2 @@
+Allow more types to be used in the ``bound`` argument to
+:class:`typing.ParamSpec`.
index cc8de45587260400ec79dce7283a9ebb91beec2d..239911ab528a894e6a00b33fe753e5e5326b5a1b 100644 (file)
@@ -1061,20 +1061,12 @@ paramspec_new_impl(PyTypeObject *type, PyObject *name, PyObject *bound,
         PyErr_SetString(PyExc_ValueError, "Variance cannot be specified with infer_variance.");
         return NULL;
     }
-    if (bound != NULL) {
-        bound = type_check(bound, "Bound must be a type.");
-        if (bound == NULL) {
-            return NULL;
-        }
-    }
     PyObject *module = caller();
     if (module == NULL) {
-        Py_XDECREF(bound);
         return NULL;
     }
     PyObject *ps = (PyObject *)paramspec_alloc(
         name, bound, default_value, covariant, contravariant, infer_variance, module);
-    Py_XDECREF(bound);
     Py_DECREF(module);
     return ps;
 }