Commit 349297f7 authored by Stefan Behnel's avatar Stefan Behnel

disable string type checking for keyword arguments on PyPy because it does...

disable string type checking for keyword arguments on PyPy because it does this at call time automatically

--HG--
extra : rebase_source : 1c3761bdab3fd0fed980dd9e44e5fdc4d22553b0
parent 3e8d0d35
...@@ -121,6 +121,12 @@ static CYTHON_INLINE int __Pyx_CheckKeywordStrings( ...@@ -121,6 +121,12 @@ static CYTHON_INLINE int __Pyx_CheckKeywordStrings(
{ {
PyObject* key = 0; PyObject* key = 0;
Py_ssize_t pos = 0; Py_ssize_t pos = 0;
#if CPYTHON_COMPILING_IN_PYPY
/* PyPy appears to check keywords at call time, not at unpacking time => not much to do here */
if (!kw_allowed && PyDict_Next(kwdict, &pos, &key, 0))
goto invalid_keyword;
return 1;
#else
while (PyDict_Next(kwdict, &pos, &key, 0)) { while (PyDict_Next(kwdict, &pos, &key, 0)) {
#if PY_MAJOR_VERSION < 3 #if PY_MAJOR_VERSION < 3
if (unlikely(!PyString_CheckExact(key)) && unlikely(!PyString_Check(key))) if (unlikely(!PyString_CheckExact(key)) && unlikely(!PyString_Check(key)))
...@@ -136,6 +142,7 @@ invalid_keyword_type: ...@@ -136,6 +142,7 @@ invalid_keyword_type:
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
"%s() keywords must be strings", function_name); "%s() keywords must be strings", function_name);
return 0; return 0;
#endif
invalid_keyword: invalid_keyword:
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
#if PY_MAJOR_VERSION < 3 #if PY_MAJOR_VERSION < 3
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment