Fix for memory leak in PILfont _font_text_asBytes, #2629

This commit is contained in:
wiredfool 2017-07-18 02:50:40 -07:00 committed by Eric Soroos
parent a7cf91499a
commit fd0e7be55a

View File

@ -2198,26 +2198,45 @@ textwidth(ImagingFontObject* self, const unsigned char* text)
} }
void _font_text_asBytes(PyObject* encoded_string, unsigned char** text){ void _font_text_asBytes(PyObject* encoded_string, unsigned char** text){
/* Allocates *text, returns a 'new reference'. Caller is required to free */
PyObject* bytes = NULL; PyObject* bytes = NULL;
ssize_t len = 0;
char *buffer;
*text = NULL; *text = NULL;
if (PyUnicode_CheckExact(encoded_string)){ if (PyUnicode_CheckExact(encoded_string)){
bytes = PyUnicode_AsLatin1String(encoded_string); bytes = PyUnicode_AsLatin1String(encoded_string);
PyBytes_AsStringAndSize(bytes, &buffer, &len);
} else if (PyBytes_Check(encoded_string)) { } else if (PyBytes_Check(encoded_string)) {
bytes = encoded_string; PyBytes_AsStringAndSize(encoded_string, &buffer, &len);
} }
if (bytes) {
*text = (unsigned char*)PyBytes_AsString(bytes); if (len) {
*text = calloc(len,1);
if (text) {
memcpy(*text, buffer, len);
}
if(bytes) {
Py_DECREF(bytes);
}
return; return;
} }
#if PY_VERSION_HEX < 0x03000000 #if PY_VERSION_HEX < 0x03000000
/* likely case here is py2.x with an ordinary string. /* likely case here is py2.x with an ordinary string.
but this isn't defined in Py3.x */ but this isn't defined in Py3.x */
if (PyString_Check(encoded_string)) { if (PyString_Check(encoded_string)) {
*text = (unsigned char *)PyString_AsString(encoded_string); PyString_AsStringAndSize(encoded_string, &buffer, &len);
*text = calloc(len,1);
if (text) {
memcpy(*text, buffer, len);
}
return;
} }
#endif #endif
} }
@ -2249,6 +2268,7 @@ _font_getmask(ImagingFontObject* self, PyObject* args)
im = ImagingNew(self->bitmap->mode, textwidth(self, text), self->ysize); im = ImagingNew(self->bitmap->mode, textwidth(self, text), self->ysize);
if (!im) { if (!im) {
return NULL; return NULL;
free(text);
} }
b = 0; b = 0;
@ -2273,9 +2293,11 @@ _font_getmask(ImagingFontObject* self, PyObject* args)
x = x + glyph->dx; x = x + glyph->dx;
b = b + glyph->dy; b = b + glyph->dy;
} }
free(text);
return PyImagingNew(im); return PyImagingNew(im);
failed: failed:
free(text);
ImagingDelete(im); ImagingDelete(im);
return NULL; return NULL;
} }
@ -2285,6 +2307,7 @@ _font_getsize(ImagingFontObject* self, PyObject* args)
{ {
unsigned char* text; unsigned char* text;
PyObject* encoded_string; PyObject* encoded_string;
PyObject* val;
if (!PyArg_ParseTuple(args, "O:getsize", &encoded_string)) if (!PyArg_ParseTuple(args, "O:getsize", &encoded_string))
return NULL; return NULL;
@ -2294,7 +2317,9 @@ _font_getsize(ImagingFontObject* self, PyObject* args)
return NULL; return NULL;
} }
return Py_BuildValue("ii", textwidth(self, text), self->ysize); val = Py_BuildValue("ii", textwidth(self, text), self->ysize);
free(text);
return val;
} }
static struct PyMethodDef _font_methods[] = { static struct PyMethodDef _font_methods[] = {