diff options
author | Benjamin Peterson <benjamin@python.org> | 2015-05-09 04:25:18 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2015-05-09 04:25:18 (GMT) |
commit | 65bcdd7195666e20eb56a7d49b5dd0ee2278e506 (patch) | |
tree | 409692635ac463a111176be3a8cf978a5d7165cd | |
parent | 07abcf58d98f2f2ae36a4cb20331b9e72b36ad4d (diff) | |
download | cpython-65bcdd7195666e20eb56a7d49b5dd0ee2278e506.zip cpython-65bcdd7195666e20eb56a7d49b5dd0ee2278e506.tar.gz cpython-65bcdd7195666e20eb56a7d49b5dd0ee2278e506.tar.bz2 |
ensure .keywords is always a dict
-rw-r--r-- | Lib/test/test_functools.py | 2 | ||||
-rw-r--r-- | Misc/NEWS | 2 | ||||
-rw-r--r-- | Modules/_functoolsmodule.c | 14 |
3 files changed, 9 insertions, 9 deletions
diff --git a/Lib/test/test_functools.py b/Lib/test/test_functools.py index 0375601c..36f154a 100644 --- a/Lib/test/test_functools.py +++ b/Lib/test/test_functools.py @@ -77,9 +77,11 @@ class TestPartial: # exercise special code paths for no keyword args in # either the partial object or the caller p = self.partial(capture) + self.assertEqual(p.keywords, {}) self.assertEqual(p(), ((), {})) self.assertEqual(p(a=1), ((), {'a':1})) p = self.partial(capture, a=1) + self.assertEqual(p.keywords, {'a':1}) self.assertEqual(p(), ((), {'a':1})) self.assertEqual(p(b=2), ((), {'a':1, 'b':2})) # keyword args in the call override those in the partial object @@ -57,6 +57,8 @@ Library - Issue #9246: On POSIX, os.getcwd() now supports paths longer than 1025 bytes. Patch written by William Orr. +- The keywords attribute of functools.partial is now always a dictionary. + - Issues #24099, #24100, and #24101: Fix free-after-use bug in heapq's siftup and siftdown functions. diff --git a/Modules/_functoolsmodule.c b/Modules/_functoolsmodule.c index 57dfba0..24da677 100644 --- a/Modules/_functoolsmodule.c +++ b/Modules/_functoolsmodule.c @@ -54,17 +54,13 @@ partial_new(PyTypeObject *type, PyObject *args, PyObject *kw) Py_DECREF(pto); return NULL; } - if (kw != NULL) { - pto->kw = PyDict_Copy(kw); - if (pto->kw == NULL) { - Py_DECREF(pto); - return NULL; - } - } else { - pto->kw = Py_None; - Py_INCREF(Py_None); + pto->kw = (kw != NULL) ? PyDict_Copy(kw) : PyDict_New(); + if (pto->kw == NULL) { + Py_DECREF(pto); + return NULL; } + pto->weakreflist = NULL; pto->dict = NULL; |