Commit 32151f87 authored by scoder's avatar scoder

Merge pull request #444 from Nikratio/master

__Pyx_decode_c_string: check for overflow when calling strlen.
parents 6018c0db cad0d9f8
...@@ -395,14 +395,23 @@ static CYTHON_INLINE PyObject* __Pyx_decode_c_string( ...@@ -395,14 +395,23 @@ static CYTHON_INLINE PyObject* __Pyx_decode_c_string(
//@requires: IncludeStringH //@requires: IncludeStringH
/* duplicate code to avoid calling strlen() if start >= 0 and stop >= 0 */ /* duplicate code to avoid calling strlen() if start >= 0 and stop >= 0 */
/* Casting to Py_ssize_t and checking for negative values to determine
* if overflow occured should be safe in practice (it's undefined
* behavior by C99, but common behavior for systems with
* two-complement representation).
*/
static CYTHON_INLINE PyObject* __Pyx_decode_c_string( static CYTHON_INLINE PyObject* __Pyx_decode_c_string(
const char* cstring, Py_ssize_t start, Py_ssize_t stop, const char* cstring, Py_ssize_t start, Py_ssize_t stop,
const char* encoding, const char* errors, const char* encoding, const char* errors,
PyObject* (*decode_func)(const char *s, Py_ssize_t size, const char *errors)) { PyObject* (*decode_func)(const char *s, Py_ssize_t size, const char *errors)) {
Py_ssize_t length; Py_ssize_t length;
if (unlikely((start < 0) | (stop < 0))) { if (unlikely((start < 0) | (stop < 0))) {
length = strlen(cstring); length = (Py_ssize_t) strlen(cstring);
if(length < 0) {
PyErr_SetString(PyExc_OverflowError,
"c-string too long to convert to Python");
return NULL;
}
if (start < 0) { if (start < 0) {
start += length; start += length;
if (start < 0) if (start < 0)
......
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