[Pkg-e-commits] [SCM] Enlightenment 17 branch, upstream-vcs, updated. a4f99cdaf59e45e3fa16746e0ae90039333bb158

englebass englebass at alioth.debian.org
Fri Mar 21 14:51:34 UTC 2008


The following commit has been merged in the upstream-vcs branch:
commit 3584819a47ac01c6165d52fcac961ff727b94bf6
Author: englebass <englebass>
Date:   Wed Mar 12 21:13:21 2008 +0000

    Clean up and remove some leaks.

diff --git a/src/modules/conf_wallpaper/e_int_config_wallpaper_web.c b/src/modules/conf_wallpaper/e_int_config_wallpaper_web.c
index 7d53701..1c725b9 100644
--- a/src/modules/conf_wallpaper/e_int_config_wallpaper_web.c
+++ b/src/modules/conf_wallpaper/e_int_config_wallpaper_web.c
@@ -112,7 +112,9 @@ e_int_config_wallpaper_web(E_Config_Dialog *parent)
    o = e_widget_list_add(evas, 0, 1);
    cfdata->o = o;
    cfdata->thumbs = ecore_list_new();
+   ecore_list_free_cb_set(cfdata->thumbs, free);
    cfdata->medias = ecore_list_new();
+   ecore_list_free_cb_set(cfdata->medias, free);
    of = e_widget_framelist_add(evas, "Sources", 1);
    ol = e_widget_ilist_add(evas, 24, 24, &cfdata->ol_val);
    cfdata->ol = ol;
@@ -218,7 +220,10 @@ e_int_config_wallpaper_web_del(E_Dialog *dia)
 	     ecore_file_recursive_rm(cfdata->tmpdir);
 	     ecore_file_rmdir(cfdata->tmpdir);
 	  }
+	free(cfdata->tmpdir);
      }
+   ecore_list_destroy(cfdata->thumbs);
+   ecore_list_destroy(cfdata->medias);
 
    e_int_config_wallpaper_web_done(import->parent);
    E_FREE(import->cfdata);
@@ -308,13 +313,9 @@ _parse_feed(void *data)
    Import *import;
    E_Config_Dialog_Data *cfdata;
    FILE *fh;
-   char instr[255];
+   char instr[1024];
    char *edj;
    char *img;
-   char *tmpstr;
-   char *tinstr;
-   char *timg;
-   char *title;
 
    int state = -1;
 
@@ -323,7 +324,7 @@ _parse_feed(void *data)
 
    cfdata->pending_downloads = 0;
    fh = fopen("/tmp/feed.xml", "r");
-   while (fgets(instr, 255, fh) != NULL)
+   while (fgets(instr, sizeof(instr), fh) != NULL)
      {
 	if (strstr(instr, "<rss version") != NULL)
 	  state = 0;
@@ -337,40 +338,42 @@ _parse_feed(void *data)
 
 	if ((strstr(instr, "<link>") !=  NULL) && (state == 1))
 	  {
-	     tinstr = strdup(instr); 
-	     edj = strtok(tinstr, ">");
-	     edj = strtok(NULL, "<");
-	     tmpstr = strrchr(ecore_file_file_get(edj), '.');
-	     if (strstr(tmpstr, "edj") != NULL)
-	       state = 2;
+	     char *p;
+
+	     edj = strchr(instr, ">");
+	     edj++;
+	     p = strchr(edj, "<");
+	     *p = 0;
+	     p = strrchr(ecore_file_file_get(edj), '.');
+	     if (!strcmp(p, ".edj"))
+	       {
+		  edj = strdup(edj);
+		  state = 2;
+	       }
 	  }
 
 	if ((strstr(instr, "<enclosure") != NULL) && (state == 2))
 	  {
-	     tinstr = strdup(instr); 
-	     img = strtok(tinstr, "\"");
-	     img = strtok(NULL, "\"");
-	     strcat(img, "\n");
+	     char *p;
+
+	     img = strstr(instr, "url=");
+	     img += 5;
+	     p = strchr(img, '"');
+	     p = 0;
+	     img = strdup(img);
 	     state = 3;
 	  }
 
 	if ((strstr(instr, "</item>") != NULL) && (state == 3))
 	  {
-	     timg = strdup(img);
-	     timg[strlen(timg) - 1] = 0;
-	     ecore_list_append(cfdata->thumbs, strdup(timg));
-	     ecore_list_append(cfdata->medias, strdup(edj));
+	     ecore_list_append(cfdata->thumbs, img);
+	     ecore_list_append(cfdata->medias, edj);
 	     state = 0;
 	  }
-   }
-
-   if (timg)
-     free(timg);
-   if (tinstr)
-     free(tinstr);
+     }
    fclose(fh);
 
-   if ((state != -1) && (state == 0))
+   if (state == 0)
      {
 	asprintf(&title, _("[%s] Parsing feed... DONE!"), cfdata->source);
 	e_dialog_title_set(import->dia, title);
@@ -454,10 +457,7 @@ _file_click_cb(void *data, Evas_Object *obj, void *ev_info)
 static int
 _list_find(const char *str1, const char *str2)
 {
-   char *tmp;
-
-   tmp = strdup(str1);
-   return strcmp(ecore_file_file_get(tmp), str2);
+   return strcmp(ecore_file_file_get(str1), str2);
 }
 
 static void 
@@ -477,9 +477,7 @@ _dia_ok_cb(void *data, E_Dialog *dia)
    cfdata = import->cfdata;
    sels = e_fm2_selected_list_get(cfdata->ofm);
    if (sels)
-     {
-	_download_media(import);
-     }
+     _download_media(import);
    else
      e_int_config_wallpaper_web_del(dia);
 }
@@ -491,7 +489,6 @@ _download_media(Import *import)
    E_Config_Dialog_Data *cfdata;
    int num = 0;
    const char *file;
-   const char *homedir;
    char *buf;
    char *title;
 
@@ -500,8 +497,7 @@ _download_media(Import *import)
    
    cfdata->pending_downloads = 1;
    file = ecore_file_file_get(cfdata->edj);
-   homedir = e_user_homedir_get();
-   asprintf(&buf, "%s/.e/e/backgrounds/%s", homedir, file);
+   asprintf(&buf, "%s/.e/e/backgrounds/%s", e_user_homedir_get(), file);
    asprintf(&title, _("[%s] Downloading of edje file..."), cfdata->source);
    e_dialog_title_set(i->dia, title);
    ecore_file_download(cfdata->edj, buf,
@@ -597,9 +593,7 @@ _get_feed(char *url, void *data)
    import = data;
    cfdata = import->cfdata;
 
-   tpl = strdup(TEMPLATE);
-   cfdata->tmpdir = mkdtemp(tpl);
-   free(tpl);
+   cfdata->tmpdir = mkdtemp(strdup(TEMPLATE));
 
    ecore_con_url_url_set(cfdata->ecu, url);
    ecore_file_download_abort_all();

-- 
Enlightenment 17



More information about the Pkg-e-commits mailing list