Enlightenment CVS committal

Author  : raster
Project : e17
Module  : libs/edje

Dir     : e17/libs/edje/src/lib


Modified Files:
        Edje.h edje_main.c edje_private.h 


Log Message:


the edje test program displays an edje .eet file now! build it all then:
cd data
./e_logo.sh
cd ..
./src/bin/edje

you can resize the window to watch the edje "bit" resize. this is just held
togetehr with sitckytape right now... its not done right.. it's only a
bootstrap - but it works. it needs to be cleaned up. definitely. will be
working on that.

===================================================================
RCS file: /cvsroot/enlightenment/e17/libs/edje/src/lib/Edje.h,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -3 -r1.1 -r1.2
--- Edje.h      2 Jun 2003 23:49:56 -0000       1.1
+++ Edje.h      17 Jun 2003 08:15:06 -0000      1.2
@@ -10,7 +10,8 @@
 /***************************************************************************/
 /* API here                                                                */
 /***************************************************************************/
-
+   
+   void         edje_init(void);
    Evas_Object *edje_add(Evas *evas);
    void         edje_file_set(Evas_Object *o, const char *file, const char *part);
        
===================================================================
RCS file: /cvsroot/enlightenment/e17/libs/edje/src/lib/edje_main.c,v
retrieving revision 1.4
retrieving revision 1.5
diff -u -3 -r1.4 -r1.5
--- edje_main.c 14 Jun 2003 03:06:35 -0000      1.4
+++ edje_main.c 17 Jun 2003 08:15:06 -0000      1.5
@@ -3,6 +3,8 @@
 
 Edje *_edje_fetch(Evas_Object *obj);
 
+static void _edje_edd_setup(void);
+
 static void _edje_smart_add(Evas_Object * obj);
 static void _edje_smart_del(Evas_Object * obj);
 static void _edje_smart_layer_set(Evas_Object * obj, int layer);
@@ -18,28 +20,53 @@
 static void _edje_smart_clip_set(Evas_Object * obj, Evas_Object * clip);
 static void _edje_smart_clip_unset(Evas_Object * obj);
 
+Eet_Data_Descriptor *_edje_edd_edje_file = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_image_directory = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_image_directory_entry = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_program = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_program_target = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part_collection_directory = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part_collection_directory_entry = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part_collection = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part_description = NULL;
+Eet_Data_Descriptor *_edje_edd_edje_part_image_id = NULL;
+
 static Evas_Smart *_edje_smart = NULL;
 
+void
+edje_init(void)
+{
+   static int initted = 0;
+   
+   if (initted) return;
+   initted = 1;
+   _edje_edd_setup();
+}
+
 Evas_Object *
 edje_add(Evas *evas)
 {
    if (!_edje_smart)
-     _edje_smart = evas_smart_new("edje",
-                                 _edje_smart_add,
-                                 _edje_smart_del,
-                                 _edje_smart_layer_set,
-                                 _edje_smart_raise,
-                                 _edje_smart_lower,
-                                 _edje_smart_stack_above,
-                                 _edje_smart_stack_below,
-                                 _edje_smart_move,
-                                 _edje_smart_resize,
-                                 _edje_smart_show,
-                                 _edje_smart_hide,
-                                 _edje_smart_color_set,
-                                 _edje_smart_clip_set, 
-                                 _edje_smart_clip_unset, 
-                                 NULL);
+     {
+       edje_init();
+       _edje_smart = evas_smart_new("edje",
+                                    _edje_smart_add,
+                                    _edje_smart_del,
+                                    _edje_smart_layer_set,
+                                    _edje_smart_raise,
+                                    _edje_smart_lower,
+                                    _edje_smart_stack_above,
+                                    _edje_smart_stack_below,
+                                    _edje_smart_move,
+                                    _edje_smart_resize,
+                                    _edje_smart_show,
+                                    _edje_smart_hide,
+                                    _edje_smart_color_set,
+                                    _edje_smart_clip_set, 
+                                    _edje_smart_clip_unset, 
+                                    NULL);
+     }
    return evas_object_smart_add(evas, _edje_smart);
 }
 
@@ -50,6 +77,96 @@
    
    ed = _edje_fetch(obj);
    if (!ed) return;
+   
+   /* FIXME: THIS IS A MESS! this nmeeds to be done properly. I've only done */
+   /* a quick hack here to "bootstrap" edje to display at all.. anything! */
+   /* as a matter of fact it does quite well so far! :) */
+   if (ed->collection)
+     {
+       printf("FIXME: leak!\n");
+     }
+   if (ed->file)
+     {
+       printf("FIXME: leak!\n");
+     }
+   /*****/
+     {
+       Eet_File *ef;   
+       Edje_Part_Collection *pc;
+       
+       ef = eet_open(file, EET_FILE_MODE_READ);
+       if (!ef) return;
+       ed->file = eet_data_read(ef, _edje_edd_edje_file, "edje_file");
+       if (ed->file)
+         {
+            Evas_List *l;
+            int id;
+            
+            ed->file->path = strdup(file);
+            printf("images...!\n");
+            for (l = ed->file->image_dir->entries; l; l = l->next)
+              {
+                 Edje_Image_Directory_Entry *ie;
+                 
+                 ie = l->data;
+                 printf("img: \"%s\" type=%i param=%i id=%i\n", 
+                        ie->entry, ie->source_type, ie->source_param, ie->id);
+              }
+            id = -1;
+            for (l = ed->file->collection_dir->entries; l; l = l->next)
+              {
+                 Edje_Part_Collection_Directory_Entry *ce;
+                 
+                 ce = l->data;
+                 if ((ce->entry) && (!strcmp(ce->entry, part)))
+                   {
+                      id = ce->id;
+                      break;
+                   }
+              }
+            if (id >= 0)
+              {
+                 char buf[256];
+                 
+                 snprintf(buf, sizeof(buf), "collections/%i", id);
+                 printf("need %s\n", buf);
+                 ed->collection = eet_data_read(ef, _edje_edd_edje_part_collection, 
buf);
+              }
+         }
+       eet_close(ef);
+     }
+   if (ed->collection)
+     {
+       Evas_List *l;
+       
+       printf("LOAD done... build\n");
+       for (l = ed->collection->parts; l; l = l->next)
+         {
+            Edje_Part *ep;
+            Edje_Real_Part *rp;
+            char buf[256];
+            
+            ep = l->data;
+            rp = calloc(1, sizeof(Edje_Real_Part));
+            if (!rp)
+              {
+                 /* FIXME: memory error! */
+                 return;
+              }
+            ed->parts = evas_list_append(ed->parts, rp);
+            rp->part = ep;
+            printf("part %s\n", rp->part->name);
+            rp->param1.description =  rp->part->default_desc;
+            rp->object = evas_object_image_add(ed->evas);
+            evas_object_clip_set(rp->object, ed->clipper);
+            evas_object_show(rp->object);
+            snprintf(buf, sizeof(buf), "images/%i", rp->part->default_desc->image.id);
+            evas_object_image_file_set(rp->object, ed->file->path, buf);
+         }
+       for (l = ed->parts; l; l = l->next)
+         {
+         }
+     }
 }
 
 /*** internal calls ***/
@@ -89,7 +206,7 @@
                         Edje_Calc_Params *params)
 {
    int minw, minh;
-   
+
    /* relative coords of top left & bottom right */
    if (rel1_to)
      {
@@ -116,45 +233,68 @@
      }
    else
      {
-       params->w = desc->rel2.offset_x +
-         (desc->rel2.relative_x * ed->w) -
-         params->x;
-       params->h = desc->rel2.offset_y +
-         (desc->rel2.relative_y * ed->h) -
-         params->y;
+       params->w = (double)desc->rel2.offset_x +
+         (desc->rel2.relative_x * (double)ed->w) -
+         params->x + 1;
+       params->h = (double)desc->rel2.offset_y +
+         (desc->rel2.relative_y * (double)ed->h) -
+         params->y + 1;
      }   
+
    /* aspect */
    if (params->h > 0)
      {
        double aspect;
-       int new_h;
+       double new_w, new_h;
    
        new_h = params->h;
+       new_w = params->w;
        aspect = (double)params->w / (double)params->h;
        /* adjust for max aspect (width / height) */
        if ((desc->aspect.max > 0.0) && (aspect > desc->aspect.max))
          {
-            new_h = (int)((double)params->w / desc->aspect.max);
+            new_h = (params->w / desc->aspect.max);
+            new_w = (params->h * desc->aspect.max);
          }
        /* adjust for min aspect (width / height) */
        if ((desc->aspect.min > 0.0) && (aspect < desc->aspect.min))
          {
-            new_h = (int)((double)params->w / desc->aspect.min);
+            new_h = (params->w / desc->aspect.min);
+            new_w = (params->w * desc->aspect.min);
          }
        /* do real adjustment */
-       if (params->h < new_h)
+       if ((params->h - new_h) > (params->w - new_w))
          {
-            params->y = params->y +
-              ((params->h - new_h) * (1.0 - desc->align.y));
-            params->h = new_h;
+            if (params->h < new_h)
+              {
+                 params->y = params->y +
+                   ((params->h - new_h) * (1.0 - desc->align.y));
+                 params->h = new_h;
+              }
+            else if (params->h > new_h)
+              {
+                 params->y = params->y +
+                   ((params->h - new_h) * desc->align.y);
+                 params->h = new_h;
+              }
          }
-       else if (params->h > new_h)
+       else
          {
-            params->y = params->y +
-              ((params->h - new_h) * desc->align.y);
-            params->h = new_h;
-         }       
+            if (params->w < new_w)
+              {
+                 params->x = params->x +
+                   ((params->w - new_w) * (1.0 - desc->align.x));
+                 params->w = new_w;
+              }
+            else if (params->w > new_w)
+              {
+                 params->x = params->x +
+                   ((params->w - new_w) * desc->align.x);
+                 params->w = new_w;
+              }
+         }
      }
+
    /* size step */
    if (desc->step.x > 0)
      {
@@ -346,7 +486,7 @@
 {
    Edje_Calc_Params p1, p2, p3;
    Edje_Part_Description *chosen_desc;
-   double pos;
+   double pos = 0.0;
    
    if (ep->calculated) return;
    if (ep->param1.rel1_to)    _edje_part_recalc(ed, ep->param1.rel1_to);
@@ -436,10 +576,13 @@
        char buf[4096];
        int image_id;
        int image_count, image_num;
-       
+
+//     printf("loc %3.3f %3.3f %3.3fx%3.3f\n", p3.x, p3.y, p3.w, p3.h);
        evas_object_move(ep->object, ed->x + p3.x, ed->y + p3.y);
        evas_object_resize(ep->object, p3.w, p3.h);
        evas_object_image_fill_set(ep->object, p3.fill.x, p3.fill.y, p3.fill.w, 
p3.fill.h);
+//     printf("fill %3.3f %3.3f %3.3fx%3.3f\n", p3.fill.x, p3.fill.y, p3.fill.w, 
p3.fill.h);
+
        evas_object_image_border_set(ep->object, p3.border.l, p3.border.r, 
p3.border.t, p3.border.b);
        image_id = ep->param1.description->image.id;
        image_count = 2;
@@ -459,13 +602,19 @@
             imid = evas_list_nth(ep->param2.description->image.tween_list, image_num 
- 1);
             if (imid) image_id = imid->id;
          }
-       
-       snprintf(buf, sizeof(buf), "/images/%i", image_id);
+
+       snprintf(buf, sizeof(buf), "images/%i", image_id);
        evas_object_image_file_set(ep->object, ed->file->path, buf);
      }
    if (p3.visible) evas_object_show(ep->object);
    else evas_object_hide(ep->object);
    evas_object_color_set(ep->object, p3.color.r, p3.color.g, p3.color.b, p3.color.a);
+   
+   ep->x = p3.x;
+   ep->y = p3.y;
+   ep->w = p3.w;
+   ep->h = p3.h;
+   
    ep->calculated = 1;
    ep->dirty = 0;
 }
@@ -508,6 +657,204 @@
    return ed;
 }
 
+static void
+_edje_edd_setup(void)
+{
+   /* image directory */
+   _edje_edd_edje_image_directory_entry = 
eet_data_descriptor_new("Edje_Image_Directory_Entry",
+                                                                 
sizeof(Edje_Image_Directory_Entry),
+                                                                 evas_list_next,
+                                                                 evas_list_append,
+                                                                 evas_list_data,
+                                                                 evas_hash_foreach,
+                                                                 evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_image_directory_entry, 
Edje_Image_Directory_Entry, "entry", entry, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_image_directory_entry, 
Edje_Image_Directory_Entry, "source_type", source_type, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_image_directory_entry, 
Edje_Image_Directory_Entry, "source_param", source_param, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_image_directory_entry, 
Edje_Image_Directory_Entry, "id", id, EET_T_INT);
+   
+   _edje_edd_edje_image_directory = eet_data_descriptor_new("Edje_Image_Directory", 
+                                                           
sizeof(Edje_Image_Directory),
+                                                           evas_list_next,
+                                                           evas_list_append,
+                                                           evas_list_data,
+                                                           evas_hash_foreach,
+                                                           evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_image_directory, Edje_Image_Directory, 
"entries", entries, _edje_edd_edje_image_directory_entry);
+
+   /* collection directory */
+   _edje_edd_edje_part_collection_directory_entry = 
eet_data_descriptor_new("Edje_Part_Collection_Directory_Entry",
+                                                                           
sizeof(Edje_Part_Collection_Directory_Entry),
+                                                                           
evas_list_next,
+                                                                           
evas_list_append,
+                                                                           
evas_list_data,
+                                                                           
evas_hash_foreach,
+                                                                           
evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_collection_directory_entry, 
Edje_Part_Collection_Directory_Entry, "entry", entry, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_collection_directory_entry, 
Edje_Part_Collection_Directory_Entry, "id", id, EET_T_INT);
+   
+   _edje_edd_edje_part_collection_directory = 
eet_data_descriptor_new("Edje_Part_Collection_Directory",
+                                                                     
sizeof(Edje_Part_Collection_Directory),
+                                                                     evas_list_next,
+                                                                     evas_list_append,
+                                                                     evas_list_data,
+                                                                     
evas_hash_foreach,
+                                                                     evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_part_collection_directory, 
Edje_Part_Collection_Directory, "entries", entries, 
_edje_edd_edje_part_collection_directory_entry);
+   
+   /* the main file directory */
+   _edje_edd_edje_file = eet_data_descriptor_new("Edje_File", 
+                                                sizeof(Edje_File),
+                                                evas_list_next,
+                                                evas_list_append,
+                                                evas_list_data,
+                                                evas_hash_foreach,
+                                                evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_SUB(_edje_edd_edje_file, Edje_File, "image_dir", 
image_dir, _edje_edd_edje_image_directory);
+   EET_DATA_DESCRIPTOR_ADD_SUB(_edje_edd_edje_file, Edje_File, "collection_dir", 
collection_dir, _edje_edd_edje_part_collection_directory);   
+
+   /* parts & programs - loaded induvidually */
+   _edje_edd_edje_program_target = eet_data_descriptor_new("Edje_Program_Target",
+                                                          sizeof(Edje_Program_Target),
+                                                          evas_list_next,
+                                                          evas_list_append,
+                                                          evas_list_data,
+                                                          evas_hash_foreach,
+                                                          evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program_target, Edje_Program_Target, 
"id", id, EET_T_INT);
+   
+   _edje_edd_edje_program = eet_data_descriptor_new("Edje_Program",
+                                                   sizeof(Edje_Program),
+                                                   evas_list_next,
+                                                   evas_list_append,
+                                                   evas_list_data,
+                                                   evas_hash_foreach,
+                                                   evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "id", id, 
EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "name", name, 
EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "signal", 
signal, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "source", 
source, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "action", 
action, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "state", 
state, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "value", 
value, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "tween.mode", 
tween.mode, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "tween.time", 
tween.time, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_program, Edje_Program, "targets", 
targets, _edje_edd_edje_program_target);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_program, Edje_Program, "after", 
after, EET_T_INT);
+   
+   _edje_edd_edje_part_image_id = eet_data_descriptor_new("Edje_Part_Image_Id",
+                                                         sizeof(Edje_Part_Image_Id),
+                                                         evas_list_next,
+                                                         evas_list_append,
+                                                         evas_list_data,
+                                                         evas_hash_foreach,
+                                                         evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_image_id, Edje_Part_Image_Id, 
"id", id, EET_T_INT);
+   
+   _edje_edd_edje_part_description = eet_data_descriptor_new("Edje_Part_Description",
+                                                            
sizeof(Edje_Part_Description),
+                                                            evas_list_next,
+                                                            evas_list_append,
+                                                            evas_list_data,
+                                                            evas_hash_foreach,
+                                                            evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "state.name", state.name, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "state.value", state.value, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "visible", visible, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.x", dragable.x, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.step_x", dragable.step_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.count_x", dragable.count_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.y", dragable.y, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.step_y", dragable.step_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.count_y", dragable.count_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "dragable.counfine_id", dragable.confine_id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "clip_to_id", clip_to_id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "align.x", align.x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "align.y", align.y, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "min.w", min.w, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "min.h", min.h, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "max.w", max.w, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "max.h", max.h, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "step.x", step.x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "step.y", step.y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "aspect.min", aspect.min, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "aspect.max", aspect.max, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel1.relative_x", rel1.relative_x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel1.relative_y", rel1.relative_y, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel1.offset_x", rel1.offset_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel1.offset_y", rel1.offset_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel1.id", rel1.id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel2.relative_x", rel2.relative_x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel2.relative_y", rel2.relative_y, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel2.offset_x", rel2.offset_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel2.offset_y", rel2.offset_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "rel2.id", rel2.id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "image.id", image.id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_part_description, 
Edje_Part_Description, "image.tween_list", image.tween_list, 
_edje_edd_edje_part_image_id);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "border.l", border.l, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "border.r", border.r, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "border.t", border.t, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "border.b", border.b, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.pos_rel_x", fill.pos_rel_x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.pos_abs_x", fill.pos_abs_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.rel_x", fill.rel_x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.abs_x", fill.abs_x, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.pos_rel_y", fill.pos_rel_y, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.pos_abs_y", fill.pos_abs_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.rel_y", fill.rel_y, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "fill.abs_y", fill.abs_y, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color.r", color.r, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color.g", color.g, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color.b", color.b, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color.a", color.a, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color2.r", color2.r, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color2.g", color2.g, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color2.b", color2.b, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color2.a", color2.a, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color3.r", color3.r, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color3.g", color3.g, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color3.b", color3.b, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "color3.a", color3.a, EET_T_INT);
+
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.text", text.text, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.font", text.font, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.size", text.size, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.effect", text.effect, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.fit_x", text.fit_x, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.fit_y", text.fit_y, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.min_x", text.min_x, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.min_y", text.min_y, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.align.x", text.align.x, EET_T_DOUBLE);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_description, 
Edje_Part_Description, "text.align.y", text.align.y, EET_T_DOUBLE);
+   
+   _edje_edd_edje_part = eet_data_descriptor_new("Edje_Part",
+                                                sizeof(Edje_Part),
+                                                evas_list_next,
+                                                evas_list_append,
+                                                evas_list_data,
+                                                evas_hash_foreach,
+                                                evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "name", name, 
EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "id", id, EET_T_INT);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "type", type, 
EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "mouse_events", 
mouse_events, EET_T_CHAR);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "color_class", 
color_class, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part, Edje_Part, "text_class", 
text_class, EET_T_STRING);
+   EET_DATA_DESCRIPTOR_ADD_SUB(_edje_edd_edje_part, Edje_Part, "default_desc", 
default_desc, _edje_edd_edje_part_description);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_part, Edje_Part, "other_desc", 
other_desc, _edje_edd_edje_part_description);
+   
+   _edje_edd_edje_part_collection  = eet_data_descriptor_new("Edje_Part_Collection", 
+                                                            
sizeof(Edje_Part_Collection),
+                                                            evas_list_next,
+                                                            evas_list_append,
+                                                            evas_list_data,
+                                                            evas_hash_foreach,
+                                                            evas_hash_add);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_part_collection, Edje_Part_Collection, 
"programs", programs, _edje_edd_edje_program);
+   EET_DATA_DESCRIPTOR_ADD_LIST(_edje_edd_edje_part_collection, Edje_Part_Collection, 
"parts", parts, _edje_edd_edje_part);
+   EET_DATA_DESCRIPTOR_ADD_BASIC(_edje_edd_edje_part_collection, 
Edje_Part_Collection, "id", id, EET_T_INT);
+}
+
 /*
 Edje_File *
 _edje_add(Evas (evas)
@@ -673,11 +1020,11 @@
 
    ed = evas_object_smart_data_get(obj);
    if (!ed) return;
-   nw = w;
-   nh = h;
+   nw = ed->w;
+   nh = ed->h;
    ed->w = w;
    ed->h = h;
-   if ((nw == ed->w) || (nh == ed->h)) return;
+   if ((nw == ed->w) && (nh == ed->h)) return;
    evas_object_resize(ed->clipper, ed->w, ed->h);
    ed->dirty = 1;
    _edje_recalc(ed);
===================================================================
RCS file: /cvsroot/enlightenment/e17/libs/edje/src/lib/edje_private.h,v
retrieving revision 1.6
retrieving revision 1.7
diff -u -3 -r1.6 -r1.7
--- edje_private.h      16 Jun 2003 13:55:13 -0000      1.6
+++ edje_private.h      17 Jun 2003 08:15:06 -0000      1.7
@@ -105,7 +105,6 @@
 struct _Edje_Image_Directory
 {
    Evas_List *entries; /* a list of Edje_Image_Directory_Entry */
-   int        references;
 };
 
 struct _Edje_Image_Directory_Entry
@@ -344,4 +343,15 @@
    } border;
 };
 
+extern Eet_Data_Descriptor *_edje_edd_edje_file;
+extern Eet_Data_Descriptor *_edje_edd_edje_image_directory;
+extern Eet_Data_Descriptor *_edje_edd_edje_image_directory_entry;
+extern Eet_Data_Descriptor *_edje_edd_edje_program;
+extern Eet_Data_Descriptor *_edje_edd_edje_program_target;
+extern Eet_Data_Descriptor *_edje_edd_edje_part_collection_directory;
+extern Eet_Data_Descriptor *_edje_edd_edje_part_collection_directory_entry;
+extern Eet_Data_Descriptor *_edje_edd_edje_part_collection;
+extern Eet_Data_Descriptor *_edje_edd_edje_part;
+extern Eet_Data_Descriptor *_edje_edd_edje_part_description;
+extern Eet_Data_Descriptor *_edje_edd_edje_part_image_id;
 #endif




-------------------------------------------------------
This SF.Net email is sponsored by: INetU
Attention Web Developers & Consultants: Become An INetU Hosting Partner.
Refer Dedicated Servers. We Manage Them. You Get 10% Monthly Commission!
INetU Dedicated Managed Hosting http://www.inetu.net/partner/index.php
_______________________________________________
enlightenment-cvs mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs

Reply via email to