jpeg pushed a commit to branch master.

http://git.enlightenment.org/core/elementary.git/commit/?id=c51ea956cd37fd8258490a849389c43a4d01e427

commit c51ea956cd37fd8258490a849389c43a4d01e427
Author: Jean-Philippe Andre <[email protected]>
Date:   Mon Sep 1 16:36:36 2014 +0900

    GLView: Clean up the native surface during deletion
---
 src/lib/elm_glview.c | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/src/lib/elm_glview.c b/src/lib/elm_glview.c
index 0e10f25..20216c8 100644
--- a/src/lib/elm_glview.c
+++ b/src/lib/elm_glview.c
@@ -239,6 +239,8 @@ _elm_glview_evas_object_smart_add(Eo *obj, Elm_Glview_Data 
*priv)
 EOLIAN static void
 _elm_glview_evas_object_smart_del(Eo *obj, Elm_Glview_Data *sd)
 {
+   ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
+
    // Call delete func if it's registered
    if (sd->del_func)
      {
@@ -248,7 +250,11 @@ _elm_glview_evas_object_smart_del(Eo *obj, Elm_Glview_Data 
*sd)
 
    ecore_idle_enterer_del(sd->render_idle_enterer);
 
-   if (sd->surface) evas_gl_surface_destroy(sd->evasgl, sd->surface);
+   if (sd->surface)
+     {
+        evas_object_image_native_surface_set(wd->resize_obj, NULL);
+        evas_gl_surface_destroy(sd->evasgl, sd->surface);
+     }
    if (sd->context) evas_gl_context_destroy(sd->evasgl, sd->context);
    if (sd->config) evas_gl_config_free(sd->config);
    if (sd->evasgl) evas_gl_free(sd->evasgl);

-- 


Reply via email to