diff options
| author | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-05-29 16:23:26 +0000 |
|---|---|---|
| committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-05-29 16:23:26 +0000 |
| commit | 441dcde7f616f7e6535f0f2b333ef84cb6847dff (patch) | |
| tree | 746625b66ed99c9c0db05d6cdc7c420fb339c761 /Python | |
| parent | 48d5c1d3077dfdb523cce7dc614a73e299cb06c8 (diff) | |
| download | cpython-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.c | 11 |
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) { |
