From 93b5513cf1d6ed328bbf2e90377fee7a487b545d Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Wed, 19 May 2010 00:54:06 +0000 Subject: Issue #6697: Fix a crash if a keyword contains a surrogate --- Python/getargs.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) (limited to 'Python') diff --git a/Python/getargs.c b/Python/getargs.c index 4fa2b5bffb..e8efb3c279 100644 --- a/Python/getargs.c +++ b/Python/getargs.c @@ -1755,18 +1755,21 @@ vgetargskeywords(PyObject *args, PyObject *keywords, const char *format, "keywords must be strings"); return cleanreturn(0, freelist); } + /* check that _PyUnicode_AsString() result is not NULL */ ks = _PyUnicode_AsString(key); - for (i = 0; i < len; i++) { - if (!strcmp(ks, kwlist[i])) { - match = 1; - break; + if (ks != NULL) { + for (i = 0; i < len; i++) { + if (!strcmp(ks, kwlist[i])) { + match = 1; + break; + } } } if (!match) { PyErr_Format(PyExc_TypeError, - "'%s' is an invalid keyword " + "'%U' is an invalid keyword " "argument for this function", - ks); + key); return cleanreturn(0, freelist); } } -- cgit v1.2.1