aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2001-08-10 12:23:32 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2001-08-10 12:23:32 +0800
commit5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a (patch)
tree545719eb4f5d13a9a824173e57b4a49c07454911 /mail
parent8907111d47ab7c750a7e99636c21ceab51255243 (diff)
downloadgsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar.gz
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar.bz2
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar.lz
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar.xz
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.tar.zst
gsoc2013-evolution-5cfa31ba114380fa2a731ed1b2a55f6ef835dc5a.zip
Added a comment about leaking memory here, but we seem to not even use the
2001-08-10 Jeffrey Stedfast <fejj@ximian.com> * folder-browser.c (on_right_click): Added a comment about leaking memory here, but we seem to not even use the 2 strings we strdup...is this code still under construction? * mail-ops.c (mail_send_message): Free the sent_folder_uri at the bottom of the function (ironically enough we were freeing it if we encountered an error but never free'd it on success :-) (get_folderinfo_got): Fixed a memory leak...this one would have gone away once we got rid of the debug g_warning though. svn path=/trunk/; revision=11868
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog12
-rw-r--r--mail/folder-browser.c57
-rw-r--r--mail/mail-ops.c21
3 files changed, 54 insertions, 36 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index d6c766f980..8724f3f6d8 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,15 @@
+2001-08-10 Jeffrey Stedfast <fejj@ximian.com>
+
+ * folder-browser.c (on_right_click): Added a comment about leaking
+ memory here, but we seem to not even use the 2 strings we
+ strdup...is this code still under construction?
+
+ * mail-ops.c (mail_send_message): Free the sent_folder_uri at the
+ bottom of the function (ironically enough we were freeing it if we
+ encountered an error but never free'd it on success :-)
+ (get_folderinfo_got): Fixed a memory leak...this one would have
+ gone away once we got rid of the debug g_warning though.
+
2001-08-10 Not Zed <NotZed@Ximian.com>
* mail-ops.c (mail_transfer_messages): Dont want it to keep on
diff --git a/mail/folder-browser.c b/mail/folder-browser.c
index 08e465aa66..8d94f74d41 100644
--- a/mail/folder-browser.c
+++ b/mail/folder-browser.c
@@ -1380,21 +1380,20 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
enable_mask |= SELECTION_SET;
mailing_list_name = NULL;
} else {
+ /* FIXME: we are leaking subject_match and from_match...what do we use them for anyway??? */
const char *subject, *real, *addr;
const CamelInternetAddress *from;
-
+
mailing_list_name = header_raw_check_mailing_list(
&((CamelMimePart *)fb->mail_display->current_message)->headers);
-
- if ((subject = camel_mime_message_get_subject(fb->mail_display->current_message))
- && (subject = strip_re(subject))
- && subject[0])
- subject_match = g_strdup(subject);
-
- if ((from = camel_mime_message_get_from(fb->mail_display->current_message))
- && camel_internet_address_get(from, 0, &real, &addr)
- && addr && addr[0])
- from_match = g_strdup(addr);
+
+ subject = camel_mime_message_get_subject (fb->mail_display->current_message);
+ if (subject && (subject = strip_re (subject)) && subject[0])
+ subject_match = g_strdup (subject);
+
+ from = camel_mime_message_get_from (fb->mail_display->current_message);
+ if (from && camel_internet_address_get (from, 0, &real, &addr) && addr && addr[0])
+ from_match = g_strdup (addr);
}
/* get a list of uids */
@@ -1408,12 +1407,12 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
gboolean have_unseen = FALSE;
gboolean have_important = FALSE;
gboolean have_unimportant = FALSE;
-
+
for (i = 0; i < uids->len; i++) {
info = camel_folder_get_message_info (fb->folder, uids->pdata[i]);
if (info == NULL)
continue;
-
+
if (info->flags & CAMEL_MESSAGE_SEEN)
have_seen = TRUE;
else
@@ -1423,18 +1422,18 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
have_deleted = TRUE;
else
have_undeleted = TRUE;
-
+
if (info->flags & CAMEL_MESSAGE_FLAGGED)
have_important = TRUE;
else
have_unimportant = TRUE;
- camel_folder_free_message_info(fb->folder, info);
-
+ camel_folder_free_message_info (fb->folder, info);
+
if (have_seen && have_unseen && have_deleted && have_undeleted)
break;
}
-
+
if (!have_unseen)
enable_mask |= CAN_MARK_READ;
if (!have_seen)
@@ -1444,12 +1443,12 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
enable_mask |= CAN_DELETE;
if (!have_deleted)
enable_mask |= CAN_UNDELETE;
-
+
if (!have_unimportant)
enable_mask |= CAN_MARK_IMPORTANT;
if (!have_important)
enable_mask |= CAN_MARK_UNIMPORTANT;
-
+
/*
* Hide items that wont get used.
*/
@@ -1459,12 +1458,14 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
else
hide_mask |= CAN_MARK_UNREAD;
}
+
if (!(have_undeleted && have_deleted)){
if (have_deleted)
hide_mask |= CAN_DELETE;
else
hide_mask |= CAN_UNDELETE;
}
+
if (!(have_important && have_unimportant)){
if (have_important)
hide_mask |= CAN_MARK_IMPORTANT;
@@ -1472,12 +1473,12 @@ on_right_click (ETree *tree, gint row, ETreePath path, gint col, GdkEvent *event
hide_mask |= CAN_MARK_UNIMPORTANT;
}
}
-
+
/* free uids */
for (i = 0; i < uids->len; i++)
g_free (uids->pdata[i]);
g_ptr_array_free (uids, TRUE);
-
+
display_menu:
/* generate the "Filter on Mailing List menu item name */
@@ -1490,13 +1491,13 @@ display_menu:
filter_menu[MLIST_VFOLDER].name = g_strdup_printf (_("VFolder on Mailing List (%s)"), mailing_list_name);
g_free(mailing_list_name);
}
-
+
menu = e_popup_menu_create (context_menu, enable_mask, hide_mask, fb);
e_auto_kill_popup_menu_on_hide (menu);
-
+
if (event->type == GDK_KEY_PRESS) {
struct cmpf_data closure;
-
+
closure.tree = tree;
closure.row = row;
closure.col = col;
@@ -1506,10 +1507,10 @@ display_menu:
gtk_menu_popup (menu, NULL, NULL, NULL, NULL,
event->button.button, event->button.time);
}
-
- g_free(filter_menu[MLIST_FILTER].name);
- g_free(filter_menu[MLIST_VFOLDER].name);
-
+
+ g_free (filter_menu[MLIST_FILTER].name);
+ g_free (filter_menu[MLIST_VFOLDER].name);
+
return TRUE;
}
diff --git a/mail/mail-ops.c b/mail/mail-ops.c
index c06069dddc..6a7564cba9 100644
--- a/mail/mail-ops.c
+++ b/mail/mail-ops.c
@@ -222,7 +222,7 @@ uid_cachename_hack (CamelStore *store)
}
static char *
-fetch_mail_describe (struct _mail_msg *mm)
+fetch_mail_describe (struct _mail_msg *mm, int complete)
{
return g_strdup (_("Fetching Mail"));
}
@@ -542,6 +542,7 @@ mail_send_message(CamelMimeMessage *message, const char *destination, CamelFilte
if (sent_folder_uri) {
folder = mail_tool_uri_to_folder (sent_folder_uri, NULL);
+ g_free (sent_folder_uri);
if (!folder) {
/* FIXME */
camel_object_ref (CAMEL_OBJECT (sent_folder));
@@ -1095,16 +1096,20 @@ static void
get_folderinfo_got (struct _mail_msg *mm)
{
struct _get_folderinfo_msg *m = (struct _get_folderinfo_msg *)mm;
-
- if (camel_exception_is_set (&(mm->ex)))
+
+ if (camel_exception_is_set (&mm->ex)) {
+ char *url;
+
+ url = camel_service_get_url (CAMEL_SERVICE (m->store));
g_warning ("Error getting folder info from store at %s: %s",
- camel_service_get_url (CAMEL_SERVICE (m->store)),
- camel_exception_get_description (&(mm->ex)));
-
+ url, camel_exception_get_description (&mm->ex));
+ g_free (url);
+ }
+
/* 'done' is probably guaranteed to fail, but... */
-
+
if (m->done)
- m->done(m->store, m->info, m->data);
+ m->done (m->store, m->info, m->data);
}
static void