summaryrefslogtreecommitdiff
path: root/Python
diff options
context:
space:
mode:
authorJeremy Hylton <jeremy@alum.mit.edu>2001-05-29 16:23:26 +0000
committerJeremy Hylton <jeremy@alum.mit.edu>2001-05-29 16:23:26 +0000
commit441dcde7f616f7e6535f0f2b333ef84cb6847dff (patch)
tree746625b66ed99c9c0db05d6cdc7c420fb339c761 /Python
parent48d5c1d3077dfdb523cce7dc614a73e299cb06c8 (diff)
downloadcpython-441dcde7f616f7e6535f0f2b333ef84cb6847dff.tar.gz
Fix bug reported by Tim Peters on python-dev:
Keyword arguments passed to builtin functions that don't take them are ignored. >>> {}.clear(x=2) >>> instead of >>> {}.clear(x=2) Traceback (most recent call last): File "<stdin>", line 1, in ? TypeError: clear() takes no keyword arguments
Diffstat (limited to 'Python')
-rw-r--r--Python/ceval.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index e407de49a9..902d52918b 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -1970,18 +1970,17 @@ eval_code2(PyCodeObject *co, PyObject *globals, PyObject *locals,
*/
if (PyCFunction_Check(func)) {
int flags = PyCFunction_GET_FLAGS(func);
- if (flags == METH_VARARGS) {
+ if (flags > 1 || nk != 0)
+ x = do_call(func, &stack_pointer,
+ na, nk);
+ else if (flags == METH_VARARGS) {
PyObject *callargs;
callargs = load_args(&stack_pointer, na);
x = call_cfunction(func, callargs, NULL);
Py_XDECREF(callargs);
- } else if (flags == 0) {
+ } else if (flags == 0)
x = fast_cfunction(func,
&stack_pointer, na);
- } else {
- x = do_call(func, &stack_pointer,
- na, nk);
- }
} else {
if (PyMethod_Check(func)
&& PyMethod_GET_SELF(func) != NULL) {