aboutsummaryrefslogtreecommitdiffstats
path: root/mail/message-list.c
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2004-01-29 14:26:30 +0800
committerMichael Zucci <zucchi@src.gnome.org>2004-01-29 14:26:30 +0800
commita59ee4cd30692aa5d653ad9f3deccb306c583a7d (patch)
tree68137535a21f81ab5724a42dea0a097aa452b9a3 /mail/message-list.c
parent3629f67f594ac7d21a777f01317cf2cb95774588 (diff)
downloadgsoc2013-evolution-a59ee4cd30692aa5d653ad9f3deccb306c583a7d.tar.gz
gsoc2013-evolution-a59ee4cd30692aa5d653ad9f3deccb306c583a7d.tar.zst
gsoc2013-evolution-a59ee4cd30692aa5d653ad9f3deccb306c583a7d.zip
** See bug #53320 and probably others
2004-01-29 Not Zed <NotZed@Ximian.com> ** See bug #53320 and probably others * message-list.c (message_list_set_folder): NULL out message_list->folder when we clear it so it isn't left for another free when we switch again. 2004-01-29 Not Zed <NotZed@Ximian.com> ** See bug #52190. * message-list.c: Added folder/folder uri to the data stored for primary/secondary selection, uses a struct to store the data now. This is needed so when you cut/copy messages, and paste them, it doesn't end up 'pasting' the messages from the current folder, but from the one where the copy/cut took place. (clear_selection): helper to free data inside selection struct. 2004-01-29 Not Zed <NotZed@Ximian.com> ** See bug #53506. * mail-tools.c (mail_tools_folder_to_url): use a camelurl to do this properly, and handle fragment folder-paths. * em-composer-utils.c (em_utils_composer_send_cb): removed outbox_folder local, not necessary. svn path=/trunk/; revision=24511
Diffstat (limited to 'mail/message-list.c')
-rw-r--r--mail/message-list.c80
1 files changed, 46 insertions, 34 deletions
diff --git a/mail/message-list.c b/mail/message-list.c
index 745b637fd8..fe3147f70e 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -88,11 +88,17 @@
#define d(x)
#define t(x)
+struct _MLSelection {
+ GPtrArray *uids;
+ CamelFolder *folder;
+ char *folder_uri;
+};
+
struct _MessageListPrivate {
GtkWidget *invisible; /* 4 selection */
- GPtrArray *primary_uids; /* uids in primary selection */
- GPtrArray *clipboard_uids; /* uids in clipboard selection */
+ struct _MLSelection primary;
+ struct _MLSelection clipboard;
};
/*
@@ -462,6 +468,20 @@ search_func (ETreeModel *model, ETreePath path, struct search_func_data *data)
return FALSE;
}
+static void
+clear_selection(MessageList *ml, struct _MLSelection *selection)
+{
+ if (selection->uids) {
+ message_list_free_uids(ml, selection->uids);
+ selection->uids = NULL;
+ }
+ if (selection->folder) {
+ camel_object_unref(selection->folder);
+ selection->folder = NULL;
+ }
+ g_free(selection->folder_uri);
+ selection->folder_uri = NULL;
+}
/**
* message_list_select:
@@ -686,10 +706,7 @@ message_list_copy(MessageList *ml, gboolean cut)
struct _MessageListPrivate *p = ml->priv;
GPtrArray *uids;
- if (p->clipboard_uids) {
- message_list_free_uids(ml, p->clipboard_uids);
- p->clipboard_uids = NULL;
- }
+ clear_selection(ml, &p->clipboard);
uids = message_list_get_selected(ml);
@@ -706,7 +723,10 @@ message_list_copy(MessageList *ml, gboolean cut)
camel_folder_thaw(ml->folder);
}
- p->clipboard_uids = uids;
+ p->clipboard.uids = uids;
+ p->clipboard.folder = ml->folder;
+ camel_object_ref(p->clipboard.folder);
+ p->clipboard.folder_uri = g_strdup(ml->folder_uri);
gtk_selection_owner_set(p->invisible, GDK_SELECTION_CLIPBOARD, gtk_get_current_event_time());
} else {
message_list_free_uids(ml, uids);
@@ -717,7 +737,7 @@ message_list_copy(MessageList *ml, gboolean cut)
gboolean
message_list_has_primary_selection(MessageList *ml)
{
- return ml->priv->primary_uids != NULL;
+ return ml->priv->primary.uids != NULL;
}
void
@@ -1426,24 +1446,24 @@ message_list_setup_etree (MessageList *message_list, gboolean outgoing)
static void
ml_selection_get(GtkWidget *widget, GtkSelectionData *data, guint info, guint time_stamp, MessageList *ml)
{
- GPtrArray *uids;
+ struct _MLSelection *selection;
if (info & 1)
- uids = ml->priv->primary_uids;
+ selection = &ml->priv->primary;
else
- uids = ml->priv->clipboard_uids;
+ selection = &ml->priv->clipboard;
- if (uids == NULL)
+ if (selection->uids == NULL)
return;
if (info & 2) {
/* text/plain */
printf("setting text/plain selection for uids\n");
- em_utils_selection_set_mailbox(data, ml->folder, uids);
+ em_utils_selection_set_mailbox(data, selection->folder, selection->uids);
} else {
/* x-uid-list */
printf("setting x-uid-list selection for uids\n");
- em_utils_selection_set_uidlist(data, ml->folder_uri, uids);
+ em_utils_selection_set_uidlist(data, selection->folder_uri, selection->uids);
}
}
@@ -1452,17 +1472,10 @@ ml_selection_clear_event(GtkWidget *widget, GdkEventSelection *event, MessageLis
{
struct _MessageListPrivate *p = ml->priv;
- if (event->selection == GDK_SELECTION_PRIMARY) {
- if (p->primary_uids) {
- message_list_free_uids(ml, p->primary_uids);
- p->primary_uids = NULL;
- }
- } else if (event->selection == GDK_SELECTION_CLIPBOARD) {
- if (p->clipboard_uids) {
- message_list_free_uids(ml, p->clipboard_uids);
- p->clipboard_uids = NULL;
- }
- }
+ if (event->selection == GDK_SELECTION_PRIMARY)
+ clear_selection(ml, &p->primary);
+ else if (event->selection == GDK_SELECTION_CLIPBOARD)
+ clear_selection(ml, &p->clipboard);
}
static void
@@ -1690,10 +1703,8 @@ message_list_finalise (GObject *object)
g_free(message_list->folder_uri);
message_list->folder_uri = NULL;
- if (p->primary_uids)
- message_list_free_uids(message_list, p->primary_uids);
- if (p->clipboard_uids)
- message_list_free_uids(message_list, p->clipboard_uids);
+ clear_selection(message_list, &p->primary);
+ clear_selection(message_list, &p->clipboard);
g_free(p);
@@ -2553,6 +2564,7 @@ message_list_set_folder (MessageList *message_list, CamelFolder *folder, const c
camel_object_unhook_event((CamelObject *)message_list->folder, "message_changed",
message_changed, message_list);
camel_object_unref (message_list->folder);
+ message_list->folder = NULL;
}
if (message_list->thread_tree) {
@@ -2675,13 +2687,13 @@ on_selection_changed_cmd(ETree *tree, MessageList *ml)
if (!ml->idle_id)
ml->idle_id = g_idle_add_full (G_PRIORITY_LOW, on_cursor_activated_idle, ml, NULL);
- if (ml->priv->primary_uids) {
- message_list_free_uids(ml, ml->priv->primary_uids);
- ml->priv->primary_uids = NULL;
- }
+ clear_selection(ml, &ml->priv->primary);
if (uids->len > 0) {
- ml->priv->primary_uids = uids;
+ ml->priv->primary.uids = uids;
+ ml->priv->primary.folder = ml->folder;
+ camel_object_ref(ml->priv->primary.folder);
+ ml->priv->primary.folder_uri = g_strdup(ml->folder_uri);
gtk_selection_owner_set(ml->priv->invisible, GDK_SELECTION_PRIMARY, gtk_get_current_event_time());
} else {
message_list_free_uids(ml, uids);