diff options
author | Sylvain <sylvain.desodt+github@gmail.com> | 2017-07-09 03:45:06 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2017-07-09 03:45:06 (GMT) |
commit | 9648088e6ccd6d0cc04f450f55628fd8eda3784c (patch) | |
tree | 8e2e1d797604ea31db5f30070f38a955f213def3 | |
parent | aa6a4d6ed881f79c51fb91dd928ed9496737b420 (diff) | |
download | cpython-9648088e6ccd6d0cc04f450f55628fd8eda3784c.zip cpython-9648088e6ccd6d0cc04f450f55628fd8eda3784c.tar.gz cpython-9648088e6ccd6d0cc04f450f55628fd8eda3784c.tar.bz2 |
bpo-30878: Fix error message when keyword arguments are passed (#2635)
to staticmethod() and classmethod().
-rw-r--r-- | Lib/test/test_call.py | 8 | ||||
-rw-r--r-- | Objects/funcobject.c | 8 |
2 files changed, 12 insertions, 4 deletions
diff --git a/Lib/test/test_call.py b/Lib/test/test_call.py index ca678b9..b004b58 100644 --- a/Lib/test/test_call.py +++ b/Lib/test/test_call.py @@ -186,6 +186,14 @@ class CFunctionCallsErrorMessages(unittest.TestCase): msg = r"^pack\(\) takes no keyword arguments$" self.assertRaisesRegex(TypeError, msg, struct.Struct.pack, struct.Struct(""), x=2) + def test_varargs12_kw(self): + msg = r"^staticmethod\(\) takes no keyword arguments$" + self.assertRaisesRegex(TypeError, msg, staticmethod, func=id) + + def test_varargs13_kw(self): + msg = r"^classmethod\(\) takes no keyword arguments$" + self.assertRaisesRegex(TypeError, msg, classmethod, func=id) + def test_oldargs0_1(self): msg = r"keys\(\) takes no arguments \(1 given\)" self.assertRaisesRegex(TypeError, msg, {}.keys, 0) diff --git a/Objects/funcobject.c b/Objects/funcobject.c index 8410001..e440258 100644 --- a/Objects/funcobject.c +++ b/Objects/funcobject.c @@ -702,10 +702,10 @@ cm_init(PyObject *self, PyObject *args, PyObject *kwds) classmethod *cm = (classmethod *)self; PyObject *callable; - if (!PyArg_UnpackTuple(args, "classmethod", 1, 1, &callable)) - return -1; if (!_PyArg_NoKeywords("classmethod", kwds)) return -1; + if (!PyArg_UnpackTuple(args, "classmethod", 1, 1, &callable)) + return -1; Py_INCREF(callable); cm->cm_callable = callable; return 0; @@ -883,10 +883,10 @@ sm_init(PyObject *self, PyObject *args, PyObject *kwds) staticmethod *sm = (staticmethod *)self; PyObject *callable; - if (!PyArg_UnpackTuple(args, "staticmethod", 1, 1, &callable)) - return -1; if (!_PyArg_NoKeywords("staticmethod", kwds)) return -1; + if (!PyArg_UnpackTuple(args, "staticmethod", 1, 1, &callable)) + return -1; Py_INCREF(callable); sm->sm_callable = callable; return 0; |