From: Srivardhan Hebbar Date: Mon, 19 Oct 2015 18:21:22 +0000 (-0700) Subject: ecore_x: handling realloc failure. X-Git-Tag: v1.16.0-beta3~53 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c406cf79e1d2ab3ee2f28828d14fda3c513d1814;p=platform%2Fupstream%2Fefl.git ecore_x: handling realloc failure. Summary: If realloc fails, lst would be NULL. So handling it. Signed-off-by: Srivardhan Hebbar Reviewers: cedric Differential Revision: https://phab.enlightenment.org/D3182 Signed-off-by: Cedric BAIL --- diff --git a/src/lib/ecore_x/xlib/ecore_x_window_prop.c b/src/lib/ecore_x/xlib/ecore_x_window_prop.c index 151f65a..043e50e 100644 --- a/src/lib/ecore_x/xlib/ecore_x_window_prop.c +++ b/src/lib/ecore_x/xlib/ecore_x_window_prop.c @@ -285,7 +285,7 @@ ecore_x_window_prop_xid_list_change(Ecore_X_Window win, Ecore_X_ID item, int op) { - Ecore_X_ID *lst; + Ecore_X_ID *lst, *temp; int i, num; LOGFN(__FILE__, __LINE__, __FUNCTION__); @@ -319,8 +319,18 @@ ecore_x_window_prop_xid_list_change(Ecore_X_Window win, goto done; /* Add it */ num++; + + temp = lst; lst = realloc(lst, num * sizeof(Ecore_X_ID)); - lst[i] = item; + if (lst) + { + lst[i] = item; + } + else + { + lst = temp; + num--; + } } ecore_x_window_prop_xid_set(win, atom, type, lst, num);