Enlightenment CVS committal

Author  : devilhorns
Project : e17
Module  : apps/e

Dir     : e17/apps/e/src/bin


Modified Files:
        e_int_config_mime_edit.c 


Log Message:
Added edj and img (png, jpeg, etc) handling code is working now.

===================================================================
RCS file: /cvs/e/e17/apps/e/src/bin/e_int_config_mime_edit.c,v
retrieving revision 1.8
retrieving revision 1.9
diff -u -3 -r1.8 -r1.9
--- e_int_config_mime_edit.c    11 Nov 2006 14:28:25 -0000      1.8
+++ e_int_config_mime_edit.c    11 Nov 2006 20:02:20 -0000      1.9
@@ -32,7 +32,8 @@
    char *file;
    struct 
      {
-       Evas_Object *icon, *fsel_wid;
+       Evas_Object *icon;
+       Evas_Object *icon_wid, *fsel_wid;
        E_Dialog *fsel;
      } gui;
 };
@@ -82,6 +83,7 @@
 
    IFDUP(mi->mime, cfdata->mime);
    IFDUP(mi->icon, cfdata->icon);
+   IFDUP(mi->icon, cfdata->file);
    
    if (!cfdata->icon)
      cfdata->type = DEFAULT;
@@ -144,22 +146,20 @@
    e_widget_frametable_object_append(of, ob, 0, 1, 3, 1, 1, 1, 1, 1);
    ob = e_widget_radio_add(evas, _("Use Edje File"), 2, rg);
    evas_object_smart_callback_add(ob, "changed", _cb_type, cfdata);
-   e_widget_disabled_set(ob, 1);
    e_widget_frametable_object_append(of, ob, 0, 2, 3, 1, 1, 1, 1, 1);
    ob = e_widget_radio_add(evas, _("Use Image"), 3, rg);
    evas_object_smart_callback_add(ob, "changed", _cb_type, cfdata);
-   e_widget_disabled_set(ob, 1);
    e_widget_frametable_object_append(of, ob, 0, 3, 3, 1, 1, 1, 1, 1);
    ob = e_widget_radio_add(evas, _("Use Default"), 4, rg);
    evas_object_smart_callback_add(ob, "changed", _cb_type, cfdata);
    e_widget_frametable_object_append(of, ob, 0, 4, 3, 1, 1, 1, 1, 1);
 
    oi = e_widget_button_add(evas, "", NULL, _cb_icon_sel, cfdata, cfd);
-   cfdata->gui.icon = oi;
+   cfdata->gui.icon_wid = oi;
    if (cfdata->icon) 
      {
        icon = _get_icon(cfdata);
-       if (icon)
+       if (icon) 
          e_widget_button_icon_set(oi, icon);
      }
    e_widget_min_size_set(oi, 48, 48);
@@ -170,10 +170,10 @@
      {
       case EDJ:
       case IMG:
-       e_widget_disabled_set(cfdata->gui.icon, 0);
+       e_widget_disabled_set(cfdata->gui.icon_wid, 0);
        break;
       default:
-       e_widget_disabled_set(cfdata->gui.icon, 1);
+       e_widget_disabled_set(cfdata->gui.icon_wid, 1);
        break;
      }
    
@@ -220,6 +220,7 @@
        break;
       case EDJ:
       case IMG:
+       mi->icon = evas_stringshare_add(cfdata->file);
        break;
       case DEFAULT:
        if (found)
@@ -231,6 +232,8 @@
      e_config->mime_icons = evas_list_append(e_config->mime_icons, mi);
    
    e_config_save_queue();
+   e_fm_mime_icon_cache_flush();
+   e_fm2_all_icons_update();
    return 1;
 }
 
@@ -285,32 +288,42 @@
    char buf[4096];
    
    cfdata = data;
-   if (!cfdata) return icon;
+   if (!cfdata) return NULL;
 
    e_widget_disabled_set(cfdata->gui.icon, 1);
-   if (cfdata->type == DEFAULT) return NULL;
+   if (cfdata->gui.icon)
+     evas_object_del(cfdata->gui.icon);
+   cfdata->gui.icon = NULL;
    
-   icon = edje_object_add(evas_object_evas_get(cfdata->gui.icon));
+   if (cfdata->type == DEFAULT) return NULL;
+
    switch (cfdata->type) 
      {
       case THUMB:
+       icon = edje_object_add(evas_object_evas_get(cfdata->gui.icon_wid));
        e_theme_edje_object_set(icon, "base/theme/fileman", 
"e/icons/fileman/file");
        break;
       case THEME:
+       icon = edje_object_add(evas_object_evas_get(cfdata->gui.icon_wid));
        snprintf(buf, sizeof(buf), "e/icons/fileman/mime/%s", cfdata->mime);
        if (!e_theme_edje_object_set(icon, "base/theme/fileman", buf))
          e_theme_edje_object_set(icon, "base/theme/fileman", 
"e/icons/fileman/file");
        break;
       case EDJ:
-       e_widget_disabled_set(cfdata->gui.icon, 0);
+       icon = edje_object_add(evas_object_evas_get(cfdata->gui.icon_wid));
+       edje_object_file_set(icon, cfdata->file, "icon");
+       e_widget_disabled_set(cfdata->gui.icon_wid, 0);
        break;
       case IMG:
-       e_widget_disabled_set(cfdata->gui.icon, 0);
+       icon = 
e_widget_image_add_from_file(evas_object_evas_get(cfdata->gui.icon_wid),
+                                           cfdata->file, 48, 48);
+       e_widget_disabled_set(cfdata->gui.icon_wid, 0);
        break;
       default:
        break;
      }
    
+   cfdata->gui.icon = icon;
    return icon;
 }
 
@@ -325,10 +338,10 @@
      {
       case EDJ:
       case IMG:
-       e_widget_disabled_set(cfdata->gui.icon, 0);
+       e_widget_disabled_set(cfdata->gui.icon_wid, 0);
        break;
       default:
-       e_widget_disabled_set(cfdata->gui.icon, 1);
+       e_widget_disabled_set(cfdata->gui.icon_wid, 1);
        break;
      }
 }
@@ -352,6 +365,7 @@
    if (!cfdata) return;
    
    file = e_widget_fsel_selection_path_get(cfdata->gui.fsel_wid);
+   IFFREE(cfdata->file);
    IFDUP(file, cfdata->file);
    _cb_fsel_cancel(data, dia);
    if (cfdata->file)
@@ -381,10 +395,18 @@
      {
       case EDJ:
        if (!strstr(cfdata->file, ".edj")) return;
+       break;
       default:
-       return;
        break;
      }
-   
-   printf("File: %s\n", cfdata->file);
+
+   IFFREE(cfdata->icon);
+   IFDUP(cfdata->file, cfdata->icon);
+
+   if (cfdata->icon) 
+     {
+       icon = _get_icon(cfdata);
+       if (icon) 
+         e_widget_button_icon_set(cfdata->gui.icon_wid, icon);
+     }
 }



-------------------------------------------------------------------------
Using Tomcat but need to do more? Need to support web services, security?
Get stuff done quickly with pre-integrated technology to make your job easier
Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo
http://sel.as-us.falkag.net/sel?cmd=lnk&kid=120709&bid=263057&dat=121642
_______________________________________________
enlightenment-cvs mailing list
enlightenment-cvs@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs

Reply via email to