furrymyad pushed a commit to branch master.

http://git.enlightenment.org/core/efl.git/commit/?id=c0a88e5e97327cfa363e8d06f5c85d95306cdca8

commit c0a88e5e97327cfa363e8d06f5c85d95306cdca8
Author: Vitalii Vorobiov <[email protected]>
Date:   Wed Jun 15 12:53:15 2016 +0300

    edje_edit: save referenced groups when image id's are changed
    
    @fix
---
 src/lib/edje/edje_edit.c | 37 +++++++++++++++++++++++++++++++++++++
 1 file changed, 37 insertions(+)

diff --git a/src/lib/edje/edje_edit.c b/src/lib/edje/edje_edit.c
index 134a15c..c10d1eb 100644
--- a/src/lib/edje/edje_edit.c
+++ b/src/lib/edje/edje_edit.c
@@ -9217,6 +9217,7 @@ edje_edit_image_set_del(Evas_Object *obj, const char 
*name)
 {
    Edje_Image_Directory_Set *de = NULL, *de_last = NULL;
    Edje_Image_Directory_Set_Entry *dim = NULL;
+   Eet_File *eetf;
    unsigned int i, j, k;
    Eina_List *used;
    Eina_Iterator *it;
@@ -9252,6 +9253,14 @@ edje_edit_image_set_del(Evas_Object *obj, const char 
*name)
 
    --ed->file->image_dir->sets_count;
 
+   /* open the eet file */
+   eetf = eet_open(ed->path, EET_FILE_MODE_READ_WRITE);
+   if (!eetf)
+     {
+        ERR("Unable to open \"%s\" for writing output", ed->path);
+        return EINA_FALSE;
+     }
+
    if (de_last->id != de->id)
      {
         Edje_Part *part;
@@ -9286,6 +9295,11 @@ edje_edit_image_set_del(Evas_Object *obj, const char 
*name)
                          }
                     }
                }
+             if (!_edje_edit_collection_save(eetf, pce->ref))
+               {
+                  eet_close(eetf);
+                  return EINA_FALSE;
+               }
           }
         eina_iterator_free(it);
      }
@@ -9293,6 +9307,8 @@ edje_edit_image_set_del(Evas_Object *obj, const char 
*name)
                                           
sizeof(Edje_Image_Directory_Set_Entry) *
                                           ed->file->image_dir->sets_count);
 
+   eet_close(eetf);
+
    return EINA_TRUE;
 }
 
@@ -9651,6 +9667,7 @@ edje_edit_image_replace(Evas_Object *obj, const char 
*name, const char *new_name
    Eina_Iterator *it;
    Edje_Part_Collection_Directory_Entry *pce;
    Edje_Part *part;
+   Eet_File *eetf;
    Edje_Part_Description_Image *part_desc_image;
    unsigned int i, j, k;
    int image_id, new_image_id;
@@ -9664,6 +9681,14 @@ edje_edit_image_replace(Evas_Object *obj, const char 
*name, const char *new_name
 
    it = eina_hash_iterator_data_new(ed->file->collection);
 
+   /* open the eet file */
+   eetf = eet_open(ed->path, EET_FILE_MODE_READ_WRITE);
+   if (!eetf)
+     {
+        ERR("Unable to open \"%s\" for writing output", ed->path);
+        return EINA_FALSE;
+     }
+
    EINA_ITERATOR_FOREACH(it, pce)
      {
         for (i = 0; i < pce->ref->parts_count; i++)
@@ -9687,10 +9712,17 @@ edje_edit_image_replace(Evas_Object *obj, const char 
*name, const char *new_name
                            part_desc_image->image.id = new_image_id;
                     }
                }
+             if (!_edje_edit_collection_save(eetf, pce->ref))
+               {
+                  eet_close(eetf);
+                  return EINA_FALSE;
+               }
           }
      }
    eina_iterator_free(it);
 
+   eet_close(eetf);
+
    return EINA_TRUE;
 }
 
@@ -9946,6 +9978,11 @@ edje_edit_image_del(Evas_Object *obj, const char *name)
                             }
                        }
                   }
+                if (!_edje_edit_collection_save(eetf, pce->ref))
+                  {
+                     eet_close(eetf);
+                     return EINA_FALSE;
+                  }
              }
            eina_iterator_free(it);
         }

-- 


Reply via email to