Merge pull request #1663 from wiredfool/uninitialized-variable

Fixes uninitialized variable warning in _imaging.c:getink
This commit is contained in:
wiredfool 2016-03-14 09:41:12 -07:00
commit b1f6cecd70
2 changed files with 37 additions and 28 deletions

View File

@ -879,6 +879,12 @@ class Image(object):
trns_im = Image()._new(core.new(self.mode, (1, 1))) trns_im = Image()._new(core.new(self.mode, (1, 1)))
if self.mode == 'P': if self.mode == 'P':
trns_im.putpalette(self.palette) trns_im.putpalette(self.palette)
if type(t) == tuple:
try:
t = trns_im.palette.getcolor(t)
except:
raise ValueError("Couldn't allocate a palette "+
"color for transparency")
trns_im.putpixel((0, 0), t) trns_im.putpixel((0, 0), t)
if mode in ('L', 'RGB'): if mode in ('L', 'RGB'):

View File

@ -471,29 +471,36 @@ getpixel(Imaging im, ImagingAccess access, int x, int y)
static char* static char*
getink(PyObject* color, Imaging im, char* ink) getink(PyObject* color, Imaging im, char* ink)
{ {
int r, g, b, a; int g=0, b=0, a=0;
double f; double f=0;
/* Windows 64 bit longs are 32 bits, and 0xFFFFFFFF (white) is a
python long (not int) that raises an overflow error when trying
to return it into a 32 bit C long
*/
PY_LONG_LONG r = 0;
/* fill ink buffer (four bytes) with something that can /* fill ink buffer (four bytes) with something that can
be cast to either UINT8 or INT32 */ be cast to either UINT8 or INT32 */
int rIsInt = 1; int rIsInt = 0;
if (im->type == IMAGING_TYPE_UINT8 || if (im->type == IMAGING_TYPE_UINT8 ||
im->type == IMAGING_TYPE_INT32 || im->type == IMAGING_TYPE_INT32 ||
im->type == IMAGING_TYPE_SPECIAL) { im->type == IMAGING_TYPE_SPECIAL) {
#if PY_VERSION_HEX >= 0x03000000 #if PY_VERSION_HEX >= 0x03000000
if (PyLong_Check(color)) { if (PyLong_Check(color)) {
r = (int) PyLong_AsLong(color); r = PyLong_AsLongLong(color);
#else #else
if (PyInt_Check(color) || PyLong_Check(color)) { if (PyInt_Check(color) || PyLong_Check(color)) {
if (PyInt_Check(color)) if (PyInt_Check(color))
r = PyInt_AS_LONG(color); r = PyInt_AS_LONG(color);
else else
r = (int) PyLong_AsLong(color); r = PyLong_AsLongLong(color);
#endif #endif
} rIsInt = 1;
if (r == -1 && PyErr_Occurred()) }
rIsInt = 0; if (r == -1 && PyErr_Occurred()) {
rIsInt = 0;
}
} }
switch (im->type) { switch (im->type) {
@ -501,23 +508,16 @@ getink(PyObject* color, Imaging im, char* ink)
/* unsigned integer */ /* unsigned integer */
if (im->bands == 1) { if (im->bands == 1) {
/* unsigned integer, single layer */ /* unsigned integer, single layer */
if (rIsInt != 1) if (rIsInt != 1) {
return NULL; if (!PyArg_ParseTuple(color, "i", &r)) {
return NULL;
}
}
ink[0] = CLIP(r); ink[0] = CLIP(r);
ink[1] = ink[2] = ink[3] = 0; ink[1] = ink[2] = ink[3] = 0;
} else { } else {
a = 255; a = 255;
#if PY_VERSION_HEX >= 0x03000000 if (rIsInt) {
if (PyLong_Check(color)) {
r = (int) PyLong_AsLong(color);
#else
if (PyInt_Check(color) || PyLong_Check(color)) {
if (PyInt_Check(color))
r = PyInt_AS_LONG(color);
else
r = (int) PyLong_AsLong(color);
#endif
/* compatibility: ABGR */ /* compatibility: ABGR */
a = (UINT8) (r >> 24); a = (UINT8) (r >> 24);
b = (UINT8) (r >> 16); b = (UINT8) (r >> 16);
@ -590,13 +590,14 @@ _fill(PyObject* self, PyObject* args)
if (!im) if (!im)
return NULL; return NULL;
buffer[0] = buffer[1] = buffer[2] = buffer[3] = 0;
if (color) { if (color) {
if (!getink(color, im, buffer)) { if (!getink(color, im, buffer)) {
ImagingDelete(im); ImagingDelete(im);
return NULL; return NULL;
} }
} else }
buffer[0] = buffer[1] = buffer[2] = buffer[3] = 0;
(void) ImagingFill(im, buffer); (void) ImagingFill(im, buffer);
@ -1342,6 +1343,8 @@ _putdata(ImagingObject* self, PyObject* args)
INT32 inkint; INT32 inkint;
} u; } u;
u.inkint = 0;
op = PySequence_Fast_GET_ITEM(seq, i); op = PySequence_Fast_GET_ITEM(seq, i);
if (!op || !getink(op, image, u.ink)) { if (!op || !getink(op, image, u.ink)) {
Py_DECREF(seq); Py_DECREF(seq);