eo: use unref instead of del when constructor fails without parent
authorCedric BAIL <cedric@osg.samsung.com>
Tue, 20 Mar 2018 17:20:26 +0000 (13:20 -0400)
committerWonki Kim <wonki_.kim@samsung.com>
Tue, 10 Apr 2018 11:22:01 +0000 (20:22 +0900)
Signed-off-by: Mike Blumenkrantz <zmike@osg.samsung.com>
src/lib/eo/eo.c

index 4e6b091..0fb5891 100644 (file)
@@ -927,7 +927,8 @@ ok_nomatch:
         EO_OBJ_POINTER_GOTO_PROXY(eo_id, new_obj, err_newid);
         /* We have two refs at this point. */
         _efl_unref(obj);
-        efl_del((Eo *)obj->header.id);
+        if (parent_id) efl_del((Eo *) obj->header.id);
+        else _efl_unref(obj);
         _efl_ref(new_obj);
         EO_OBJ_DONE(eo_id);
      }
@@ -938,7 +939,8 @@ err_noid:
        file, line, klass->desc->name);
    /* We have two refs at this point. */
    _efl_unref(obj);
-   efl_del((Eo *) obj->header.id);
+   if (parent_id) efl_del((Eo *) obj->header.id);
+   else _efl_unref(obj);
 err_newid:
    if (parent_id) EO_OBJ_DONE(parent_id);
    return NULL;
@@ -989,7 +991,8 @@ err_condtor:
      }
 cleanup:
    _efl_unref(obj);
-   efl_del((Eo *) obj->header.id);
+   if (efl_parent_get(eo_id)) efl_del((Eo *) obj->header.id);
+   else _efl_unref(obj);
    EO_OBJ_DONE(eo_id);
    return NULL;
 }