summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrii Kroitor <an.kroitor@samsung.com>2016-04-22 16:12:26 -0700
committerCedric Bail <cedric@osg.samsung.com>2016-04-22 16:12:29 -0700
commit0e9cf93c3069f68d906a8b706fa1169ad1fd2073 (patch)
tree113c4e7e17f4d285aebbc4cadca0585959398add
parent076037bd55a9d9f4ffe66200f2f30e264e32eb10 (diff)
downloadefl-0e9cf93c3069f68d906a8b706fa1169ad1fd2073.tar.gz
edje_edit: fix mempools in group/alias add
Summary: moved mempools adding to separate method to avoid this problem in future Reviewers: cedric, reutskiy.v.v Subscribers: jpeg Differential Revision: https://phab.enlightenment.org/D3903 Signed-off-by: Cedric Bail <cedric@osg.samsung.com>
-rw-r--r--src/lib/edje/edje_edit.c106
1 files changed, 45 insertions, 61 deletions
diff --git a/src/lib/edje/edje_edit.c b/src/lib/edje/edje_edit.c
index 7c4c5e1980..cfd06cebc1 100644
--- a/src/lib/edje/edje_edit.c
+++ b/src/lib/edje/edje_edit.c
@@ -1555,6 +1555,48 @@ edje_edit_sound_samplesource_get(Evas_Object *obj, const char *sample_name)
/* GROUPS API */
/****************/
+static void
+_mempools_add(Edje_Part_Collection_Directory_Entry *de)
+{
+#define EDIT_EMN(Tp, Sz, Ce) \
+ Ce->mp.Tp = eina_mempool_add("chained_mempool", #Tp, NULL, sizeof (Sz), 8);
+#define EDIT_EMNP(Tp, Sz, Ce) \
+ Ce->mp_rtl.Tp = eina_mempool_add("chained_mempool", #Tp, NULL, sizeof (Sz), 8);
+
+ EDIT_EMN(RECTANGLE, Edje_Part_Description_Common, de);
+ EDIT_EMN(TEXT, Edje_Part_Description_Text, de);
+ EDIT_EMN(IMAGE, Edje_Part_Description_Image, de);
+ EDIT_EMN(PROXY, Edje_Part_Description_Proxy, de);
+ EDIT_EMN(SWALLOW, Edje_Part_Description_Common, de);
+ EDIT_EMN(TEXTBLOCK, Edje_Part_Description_Text, de);
+ EDIT_EMN(GROUP, Edje_Part_Description_Common, de);
+ EDIT_EMN(BOX, Edje_Part_Description_Box, de);
+ EDIT_EMN(TABLE, Edje_Part_Description_Table, de);
+ EDIT_EMN(EXTERNAL, Edje_Part_Description_External, de);
+ EDIT_EMN(SPACER, Edje_Part_Description_Common, de);
+ EDIT_EMN(SNAPSHOT, Edje_Part_Description_Snapshot, de);
+ EDIT_EMN(MESH_NODE, Edje_Part_Description_Mesh_Node, de);
+ EDIT_EMN(LIGHT, Edje_Part_Description_Light, de);
+ EDIT_EMN(CAMERA, Edje_Part_Description_Camera, de);
+ EDIT_EMN(part, Edje_Part, de);
+
+ EDIT_EMNP(RECTANGLE, Edje_Part_Description_Common, de);
+ EDIT_EMNP(TEXT, Edje_Part_Description_Text, de);
+ EDIT_EMNP(IMAGE, Edje_Part_Description_Image, de);
+ EDIT_EMNP(PROXY, Edje_Part_Description_Proxy, de);
+ EDIT_EMNP(SWALLOW, Edje_Part_Description_Common, de);
+ EDIT_EMNP(TEXTBLOCK, Edje_Part_Description_Text, de);
+ EDIT_EMNP(GROUP, Edje_Part_Description_Common, de);
+ EDIT_EMNP(BOX, Edje_Part_Description_Box, de);
+ EDIT_EMNP(TABLE, Edje_Part_Description_Table, de);
+ EDIT_EMNP(EXTERNAL, Edje_Part_Description_External, de);
+ EDIT_EMNP(SPACER, Edje_Part_Description_Common, de);
+ EDIT_EMNP(SNAPSHOT, Edje_Part_Description_Snapshot, de);
+ EDIT_EMNP(MESH_NODE, Edje_Part_Description_Mesh_Node, de);
+ EDIT_EMNP(LIGHT, Edje_Part_Description_Light, de);
+ EDIT_EMNP(CAMERA, Edje_Part_Description_Camera, de);
+}
+
EAPI Eina_Bool
edje_edit_group_copy(Evas_Object *obj, const char *group_name, const char *copy_name)
{
@@ -1623,45 +1665,9 @@ edje_edit_group_copy(Evas_Object *obj, const char *group_name, const char *copy_
de->entry = eina_stringshare_add(copy_name);
memcpy(&de->count, &e->count, sizeof (de->count));
-#define EDIT_EMN(Tp, Sz, Ce) \
- Ce->mp.Tp = eina_mempool_add("chained_mempool", #Tp, NULL, sizeof (Sz), 8);
-#define EDIT_EMNP(Tp, Sz, Ce) \
- Ce->mp_rtl.Tp = eina_mempool_add("chained_mempool", #Tp, NULL, sizeof (Sz), 8);
-
eina_hash_direct_add(ed->file->collection, de->entry, de);
- EDIT_EMN(RECTANGLE, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXT, Edje_Part_Description_Text, de);
- EDIT_EMN(IMAGE, Edje_Part_Description_Image, de);
- EDIT_EMN(PROXY, Edje_Part_Description_Proxy, de);
- EDIT_EMN(SWALLOW, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXTBLOCK, Edje_Part_Description_Text, de);
- EDIT_EMN(GROUP, Edje_Part_Description_Common, de);
- EDIT_EMN(BOX, Edje_Part_Description_Box, de);
- EDIT_EMN(TABLE, Edje_Part_Description_Table, de);
- EDIT_EMN(EXTERNAL, Edje_Part_Description_External, de);
- EDIT_EMN(SPACER, Edje_Part_Description_Common, de);
- EDIT_EMN(SNAPSHOT, Edje_Part_Description_Snapshot, de);
- EDIT_EMN(MESH_NODE, Edje_Part_Description_Mesh_Node, de);
- EDIT_EMN(LIGHT, Edje_Part_Description_Light, de);
- EDIT_EMN(CAMERA, Edje_Part_Description_Camera, de);
- EDIT_EMN(part, Edje_Part, de);
-
- EDIT_EMNP(RECTANGLE, Edje_Part_Description_Common, de);
- EDIT_EMNP(TEXT, Edje_Part_Description_Text, de);
- EDIT_EMNP(IMAGE, Edje_Part_Description_Image, de);
- EDIT_EMNP(PROXY, Edje_Part_Description_Proxy, de);
- EDIT_EMNP(SWALLOW, Edje_Part_Description_Common, de);
- EDIT_EMNP(TEXTBLOCK, Edje_Part_Description_Text, de);
- EDIT_EMNP(GROUP, Edje_Part_Description_Common, de);
- EDIT_EMNP(BOX, Edje_Part_Description_Box, de);
- EDIT_EMNP(TABLE, Edje_Part_Description_Table, de);
- EDIT_EMNP(EXTERNAL, Edje_Part_Description_External, de);
- EDIT_EMNP(SPACER, Edje_Part_Description_Common, de);
- EDIT_EMNP(SNAPSHOT, Edje_Part_Description_Snapshot, de);
- EDIT_EMNP(MESH_NODE, Edje_Part_Description_Mesh_Node, de);
- EDIT_EMNP(LIGHT, Edje_Part_Description_Light, de);
- EDIT_EMNP(CAMERA, Edje_Part_Description_Camera, de);
+ _mempools_add(de);
epc->id = id;
epc->part = eina_stringshare_add(copy_name);
@@ -1774,18 +1780,7 @@ edje_edit_group_add(Evas_Object *obj, const char *name)
//cd = _alloc(sizeof(Code));
//codes = eina_list_append(codes, cd);
- EDIT_EMN(RECTANGLE, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXT, Edje_Part_Description_Text, de);
- EDIT_EMN(IMAGE, Edje_Part_Description_Image, de);
- EDIT_EMN(PROXY, Edje_Part_Description_Proxy, de);
- EDIT_EMN(SWALLOW, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXTBLOCK, Edje_Part_Description_Text, de);
- EDIT_EMN(GROUP, Edje_Part_Description_Common, de);
- EDIT_EMN(BOX, Edje_Part_Description_Box, de);
- EDIT_EMN(TABLE, Edje_Part_Description_Table, de);
- EDIT_EMN(EXTERNAL, Edje_Part_Description_External, de);
- EDIT_EMN(SPACER, Edje_Part_Description_Common, de);
- EDIT_EMN(part, Edje_Part, de);
+ _mempools_add(de);
ed->file->collection_cache = eina_list_prepend(ed->file->collection_cache, pc);
_edje_cache_coll_clean(ed->file);
@@ -2178,18 +2173,7 @@ edje_edit_group_alias_add(Evas_Object *obj, const char *group_name, const char *
memcpy(&de->count, &e->count, sizeof (de->count));
eina_hash_direct_add(ed->file->collection, de->entry, de);
- EDIT_EMN(RECTANGLE, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXT, Edje_Part_Description_Text, de);
- EDIT_EMN(IMAGE, Edje_Part_Description_Image, de);
- EDIT_EMN(PROXY, Edje_Part_Description_Proxy, de);
- EDIT_EMN(SWALLOW, Edje_Part_Description_Common, de);
- EDIT_EMN(TEXTBLOCK, Edje_Part_Description_Text, de);
- EDIT_EMN(GROUP, Edje_Part_Description_Common, de);
- EDIT_EMN(BOX, Edje_Part_Description_Box, de);
- EDIT_EMN(TABLE, Edje_Part_Description_Table, de);
- EDIT_EMN(EXTERNAL, Edje_Part_Description_External, de);
- EDIT_EMN(SPACER, Edje_Part_Description_Common, de);
- EDIT_EMN(part, Edje_Part, de);
+ _mempools_add(de);
return EINA_TRUE;
}