aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2011-12-14 00:45:58 +0800
committerMatthew Barnes <mbarnes@redhat.com>2011-12-14 00:45:58 +0800
commitc9ba92156c91d1e96df18a42c39ec07d15bb7517 (patch)
tree4fb6300d3b81b6762985e5a26b4f081d90398882
parent1f4b2854000a9d62f9cc5a425cbb378ec3678565 (diff)
downloadgsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar.gz
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar.bz2
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar.lz
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar.xz
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.tar.zst
gsoc2013-evolution-c9ba92156c91d1e96df18a42c39ec07d15bb7517.zip
EMSubscriptionEditor cleanups.
GQueues are easier to pass around than linked lists.
-rw-r--r--mail/em-subscription-editor.c384
1 files changed, 224 insertions, 160 deletions
diff --git a/mail/em-subscription-editor.c b/mail/em-subscription-editor.c
index 01e74fee8f..0962492c8c 100644
--- a/mail/em-subscription-editor.c
+++ b/mail/em-subscription-editor.c
@@ -47,7 +47,7 @@
((obj), EM_TYPE_SUBSCRIPTION_EDITOR, EMSubscriptionEditorPrivate))
typedef struct _AsyncContext AsyncContext;
-typedef struct _AsyncData AsyncData;
+typedef struct _TreeRowData TreeRowData;
typedef struct _StoreData StoreData;
struct _EMSubscriptionEditorPrivate {
@@ -78,14 +78,14 @@ struct _EMSubscriptionEditorPrivate {
guint timeout_id;
};
-struct _AsyncData {
+struct _TreeRowData {
CamelFolderInfo *folder_info;
GtkTreeRowReference *reference;
};
struct _AsyncContext {
EMSubscriptionEditor *editor;
- GSList *async_datas; /* newly allocated AsyncData structures */
+ GQueue *tree_rows;
};
struct _StoreData {
@@ -116,21 +116,38 @@ enum {
G_DEFINE_TYPE (EMSubscriptionEditor, em_subscription_editor, GTK_TYPE_DIALOG)
static void
-async_data_free (AsyncData *data)
+tree_row_data_free (TreeRowData *tree_row_data)
{
- g_return_if_fail (data != NULL);
+ g_return_if_fail (tree_row_data != NULL);
- gtk_tree_row_reference_free (data->reference);
- g_free (data);
+ gtk_tree_row_reference_free (tree_row_data->reference);
+ g_slice_free (TreeRowData, tree_row_data);
+}
+
+static AsyncContext *
+async_context_new (EMSubscriptionEditor *editor,
+ GQueue *tree_rows)
+{
+ AsyncContext *context;
+
+ context = g_slice_new0 (AsyncContext);
+ context->editor = g_object_ref (editor);
+
+ /* Transfer GQueue contents. */
+ context->tree_rows = g_queue_copy (tree_rows);
+ g_queue_clear (tree_rows);
+
+ return context;
}
static void
async_context_free (AsyncContext *context)
{
- g_object_unref (context->editor);
+ while (!g_queue_is_empty (context->tree_rows))
+ tree_row_data_free (g_queue_pop_head (context->tree_rows));
- g_slist_foreach (context->async_datas, (GFunc) async_data_free, NULL);
- g_slist_free (context->async_datas);
+ g_object_unref (context->editor);
+ g_queue_free (context->tree_rows);
g_slice_free (AsyncContext, context);
}
@@ -164,7 +181,7 @@ static void
subscription_editor_populate (EMSubscriptionEditor *editor,
CamelFolderInfo *folder_info,
GtkTreeIter *parent,
- GSList **expand_paths)
+ GList **expand_paths)
{
GtkListStore *list_store;
GtkTreeStore *tree_store;
@@ -205,7 +222,7 @@ subscription_editor_populate (EMSubscriptionEditor *editor,
path = gtk_tree_model_get_path (
GTK_TREE_MODEL (tree_store), &iter);
- *expand_paths = g_slist_prepend (*expand_paths, path);
+ *expand_paths = g_list_prepend (*expand_paths, path);
}
g_free (casefolded);
@@ -238,7 +255,7 @@ subscription_editor_get_folder_info_done (CamelStore *store,
GtkTreeSelection *selection;
CamelFolderInfo *folder_info;
GdkWindow *window;
- GSList *expand_paths = NULL;
+ GList *expand_paths = NULL;
GError *error = NULL;
folder_info = camel_store_get_folder_info_finish (
@@ -283,9 +300,9 @@ subscription_editor_get_folder_info_done (CamelStore *store,
subscription_editor_populate (editor, folder_info, NULL, &expand_paths);
gtk_tree_view_set_model (tree_view, model);
- g_slist_foreach (expand_paths, expand_paths_cb, tree_view);
- g_slist_foreach (expand_paths, (GFunc) gtk_tree_path_free, NULL);
- g_slist_free (expand_paths);
+ g_list_foreach (expand_paths, expand_paths_cb, tree_view);
+ g_list_foreach (expand_paths, (GFunc) gtk_tree_path_free, NULL);
+ g_list_free (expand_paths);
path = gtk_tree_path_new_first ();
selection = gtk_tree_view_get_selection (tree_view);
@@ -310,7 +327,7 @@ subscription_editor_subscribe_folder_done (CamelSubscribable *subscribable,
GtkTreeIter iter;
GdkWindow *window;
GError *error = NULL;
- AsyncData *async_data;
+ TreeRowData *tree_row_data;
camel_subscribable_subscribe_folder_finish (
subscribable, result, &error);
@@ -321,41 +338,44 @@ subscription_editor_subscribe_folder_done (CamelSubscribable *subscribable,
goto exit;
}
- async_data = context->async_datas->data;
- context->async_datas = g_slist_remove (context->async_datas, async_data);
+ tree_row_data = g_queue_pop_head (context->tree_rows);
/* XXX Do something smarter with errors. */
if (error == NULL)
- async_data->folder_info->flags |= CAMEL_FOLDER_SUBSCRIBED;
+ tree_row_data->folder_info->flags |= CAMEL_FOLDER_SUBSCRIBED;
else {
g_warning ("%s", error->message);
g_error_free (error);
- async_data_free (async_data);
+ tree_row_data_free (tree_row_data);
goto exit;
}
/* Update the toggle renderer in the selected row. */
- tree_model = gtk_tree_row_reference_get_model (async_data->reference);
- path = gtk_tree_row_reference_get_path (async_data->reference);
+ tree_model = gtk_tree_row_reference_get_model (tree_row_data->reference);
+ path = gtk_tree_row_reference_get_path (tree_row_data->reference);
gtk_tree_model_get_iter (tree_model, &iter, path);
gtk_tree_model_row_changed (tree_model, path, &iter);
gtk_tree_path_free (path);
- async_data_free (async_data);
+ tree_row_data_free (tree_row_data);
+
+ if (!g_queue_is_empty (context->tree_rows)) {
+ GCancellable *cancellable;
- if (context->async_datas) {
/* continue with the next to subscribe */
- async_data = context->async_datas->data;
+ tree_row_data = g_queue_peek_head (context->tree_rows);
+ g_return_if_fail (tree_row_data != NULL);
+
+ cancellable = context->editor->priv->active->cancellable;
camel_subscribable_subscribe_folder (
- subscribable,
- async_data->folder_info->full_name, G_PRIORITY_DEFAULT,
- context->editor->priv->active->cancellable, (GAsyncReadyCallback)
+ subscribable, tree_row_data->folder_info->full_name,
+ G_PRIORITY_DEFAULT, cancellable, (GAsyncReadyCallback)
subscription_editor_subscribe_folder_done, context);
return;
}
- exit:
+exit:
gtk_widget_set_sensitive (context->editor->priv->notebook, TRUE);
gtk_widget_set_sensitive (context->editor->priv->refresh_button, TRUE);
gtk_widget_set_sensitive (context->editor->priv->stop_button, FALSE);
@@ -375,21 +395,22 @@ subscription_editor_subscribe_folder_done (CamelSubscribable *subscribable,
static void
subscription_editor_subscribe_many (EMSubscriptionEditor *editor,
- GSList *async_datas)
+ GQueue *tree_rows)
{
- AsyncData *async_data;
- AsyncContext *context;
+ TreeRowData *tree_row_data;
+ GCancellable *cancellable;
CamelStore *active_store;
+ AsyncContext *context;
GdkCursor *cursor;
GdkWindow *window;
g_return_if_fail (editor != NULL);
- if (!async_datas)
+ if (g_queue_is_empty (tree_rows))
return;
- async_data = async_datas->data;
- g_return_if_fail (async_data != NULL);
+ tree_row_data = g_queue_peek_head (tree_rows);
+ g_return_if_fail (tree_row_data != NULL);
/* Cancel any operation on this store still in progress. */
gtk_button_clicked (GTK_BUTTON (editor->priv->stop_button));
@@ -410,16 +431,15 @@ subscription_editor_subscribe_many (EMSubscriptionEditor *editor,
gdk_window_set_cursor (window, cursor);
g_object_unref (cursor);
- context = g_slice_new0 (AsyncContext);
- context->editor = g_object_ref (editor);
- context->async_datas = async_datas; /* takes ownership of the pointer */
+ context = async_context_new (editor, tree_rows);
active_store = editor->priv->active->store;
+ cancellable = editor->priv->active->cancellable;
camel_subscribable_subscribe_folder (
CAMEL_SUBSCRIBABLE (active_store),
- async_data->folder_info->full_name, G_PRIORITY_DEFAULT,
- context->editor->priv->active->cancellable, (GAsyncReadyCallback)
+ tree_row_data->folder_info->full_name,
+ G_PRIORITY_DEFAULT, cancellable, (GAsyncReadyCallback)
subscription_editor_subscribe_folder_done, context);
}
@@ -435,7 +455,7 @@ subscription_editor_unsubscribe_folder_done (CamelSubscribable *subscribable,
GtkTreeIter iter;
GdkWindow *window;
GError *error = NULL;
- AsyncData *async_data;
+ TreeRowData *tree_row_data;
camel_subscribable_unsubscribe_folder_finish (
subscribable, result, &error);
@@ -446,40 +466,44 @@ subscription_editor_unsubscribe_folder_done (CamelSubscribable *subscribable,
goto exit;
}
- async_data = context->async_datas->data;
- context->async_datas = g_slist_remove (context->async_datas, async_data);
+ tree_row_data = g_queue_pop_head (context->tree_rows);
/* XXX Do something smarter with errors. */
if (error == NULL)
- async_data->folder_info->flags &= ~CAMEL_FOLDER_SUBSCRIBED;
+ tree_row_data->folder_info->flags &= ~CAMEL_FOLDER_SUBSCRIBED;
else {
g_warning ("%s", error->message);
g_error_free (error);
- async_data_free (async_data);
+ tree_row_data_free (tree_row_data);
goto exit;
}
/* Update the toggle renderer in the selected row. */
- tree_model = gtk_tree_row_reference_get_model (async_data->reference);
- path = gtk_tree_row_reference_get_path (async_data->reference);
+ tree_model = gtk_tree_row_reference_get_model (tree_row_data->reference);
+ path = gtk_tree_row_reference_get_path (tree_row_data->reference);
gtk_tree_model_get_iter (tree_model, &iter, path);
gtk_tree_model_row_changed (tree_model, path, &iter);
gtk_tree_path_free (path);
- async_data_free (async_data);
+ tree_row_data_free (tree_row_data);
+
+ if (!g_queue_is_empty (context->tree_rows)) {
+ GCancellable *cancellable;
- if (context->async_datas) {
/* continue with the next to unsubscribe */
- async_data = context->async_datas->data;
+ tree_row_data = g_queue_peek_head (context->tree_rows);
+ g_return_if_fail (tree_row_data != NULL);
+
+ cancellable = context->editor->priv->active->cancellable;
camel_subscribable_unsubscribe_folder (
- subscribable,
- async_data->folder_info->full_name, G_PRIORITY_DEFAULT,
- context->editor->priv->active->cancellable, (GAsyncReadyCallback)
+ subscribable, tree_row_data->folder_info->full_name,
+ G_PRIORITY_DEFAULT, cancellable, (GAsyncReadyCallback)
subscription_editor_unsubscribe_folder_done, context);
return;
}
- exit:
+
+exit:
gtk_widget_set_sensitive (context->editor->priv->notebook, TRUE);
gtk_widget_set_sensitive (context->editor->priv->refresh_button, TRUE);
gtk_widget_set_sensitive (context->editor->priv->stop_button, FALSE);
@@ -499,9 +523,9 @@ subscription_editor_unsubscribe_folder_done (CamelSubscribable *subscribable,
static void
subscription_editor_unsubscribe_many (EMSubscriptionEditor *editor,
- GSList *async_datas)
+ GQueue *tree_rows)
{
- AsyncData *async_data;
+ TreeRowData *tree_row_data;
AsyncContext *context;
CamelStore *active_store;
GdkCursor *cursor;
@@ -509,11 +533,11 @@ subscription_editor_unsubscribe_many (EMSubscriptionEditor *editor,
g_return_if_fail (editor != NULL);
- if (!async_datas)
+ if (g_queue_is_empty (tree_rows))
return;
- async_data = async_datas->data;
- g_return_if_fail (async_data != NULL);
+ tree_row_data = g_queue_peek_head (tree_rows);
+ g_return_if_fail (tree_row_data != NULL);
/* Cancel any operation on this store still in progress. */
gtk_button_clicked (GTK_BUTTON (editor->priv->stop_button));
@@ -534,15 +558,13 @@ subscription_editor_unsubscribe_many (EMSubscriptionEditor *editor,
gdk_window_set_cursor (window, cursor);
g_object_unref (cursor);
- context = g_slice_new0 (AsyncContext);
- context->editor = g_object_ref (editor);
- context->async_datas = async_datas; /* takes ownership of the pointer */
+ context = async_context_new (editor, tree_rows);
active_store = editor->priv->active->store;
camel_subscribable_unsubscribe_folder (
CAMEL_SUBSCRIBABLE (active_store),
- async_data->folder_info->full_name, G_PRIORITY_DEFAULT,
+ tree_row_data->folder_info->full_name, G_PRIORITY_DEFAULT,
editor->priv->active->cancellable, (GAsyncReadyCallback)
subscription_editor_unsubscribe_folder_done, context);
}
@@ -606,21 +628,17 @@ position_below_widget_cb (GtkMenu *menu,
*push_in = FALSE;
}
-static AsyncData *
-subscription_editor_async_data_from_iter (GtkTreeView *tree_view,
- GtkTreeModel *model,
- GtkTreeIter *iter,
- gboolean *is_expanded)
+static TreeRowData *
+subscription_editor_tree_row_data_from_iter (GtkTreeView *tree_view,
+ GtkTreeModel *model,
+ GtkTreeIter *iter,
+ gboolean *is_expanded)
{
- AsyncData *data;
+ TreeRowData *tree_row_data;
CamelFolderInfo *folder_info = NULL;
GtkTreeRowReference *reference;
GtkTreePath *path;
- g_return_val_if_fail (tree_view != NULL, NULL);
- g_return_val_if_fail (model != NULL, NULL);
- g_return_val_if_fail (iter != NULL, NULL);
-
gtk_tree_model_get (
model, iter, COL_FOLDER_INFO, &folder_info, -1);
@@ -633,11 +651,11 @@ subscription_editor_async_data_from_iter (GtkTreeView *tree_view,
*is_expanded = gtk_tree_view_row_expanded (tree_view, path);
gtk_tree_path_free (path);
- data = g_new0 (AsyncData, 1);
- data->folder_info = folder_info;
- data->reference = reference;
+ tree_row_data = g_slice_new0 (TreeRowData);
+ tree_row_data->folder_info = folder_info;
+ tree_row_data->reference = reference;
- return data;
+ return tree_row_data;
}
typedef enum {
@@ -663,7 +681,7 @@ struct PickAllData {
GtkTreeView *tree_view;
EPickMode mode;
GHashTable *skip_folder_infos;
- GSList *async_datas;
+ GQueue *out_tree_rows;
};
static gboolean
@@ -673,22 +691,19 @@ pick_all_cb (GtkTreeModel *model,
gpointer user_data)
{
struct PickAllData *data = user_data;
- AsyncData *async_data;
-
- g_return_val_if_fail (model != NULL, TRUE);
- g_return_val_if_fail (data != NULL, TRUE);
- g_return_val_if_fail (data->tree_view != NULL, TRUE);
+ TreeRowData *tree_row_data;
- async_data = subscription_editor_async_data_from_iter (data->tree_view, model, iter, NULL);
- if (!async_data)
+ tree_row_data = subscription_editor_tree_row_data_from_iter (
+ data->tree_view, model, iter, NULL);
+ if (tree_row_data == NULL)
return FALSE;
- if (can_pick_folder_info (async_data->folder_info, data->mode) &&
+ if (can_pick_folder_info (tree_row_data->folder_info, data->mode) &&
(data->skip_folder_infos == NULL ||
- !g_hash_table_lookup_extended (data->skip_folder_infos, async_data->folder_info, NULL, NULL))) {
- data->async_datas = g_slist_prepend (data->async_datas, async_data);
+ !g_hash_table_lookup_extended (data->skip_folder_infos, tree_row_data->folder_info, NULL, NULL))) {
+ g_queue_push_tail (data->out_tree_rows, tree_row_data);
} else
- async_data_free (async_data);
+ tree_row_data_free (tree_row_data);
return FALSE;
}
@@ -697,10 +712,11 @@ pick_all_cb (GtkTreeModel *model,
* these should come from the tree view; can be NULL
* to include everything.
*/
-static GSList *
+static void
subscription_editor_pick_all (EMSubscriptionEditor *editor,
EPickMode mode,
- GHashTable *skip_folder_infos)
+ GHashTable *skip_folder_infos,
+ GQueue *out_tree_rows)
{
GtkTreeView *tree_view;
GtkTreeModel *tree_model;
@@ -712,41 +728,40 @@ subscription_editor_pick_all (EMSubscriptionEditor *editor,
data.tree_view = tree_view;
data.mode = mode;
data.skip_folder_infos = skip_folder_infos;
- data.async_datas = NULL;
+ data.out_tree_rows = out_tree_rows;
gtk_tree_model_foreach (tree_model, pick_all_cb, &data);
-
- return data.async_datas;
}
-static GSList *
+static void
subscription_editor_pick_shown (EMSubscriptionEditor *editor,
- EPickMode mode)
+ EPickMode mode,
+ GQueue *out_tree_rows)
{
GtkTreeView *tree_view;
GtkTreeModel *tree_model;
GtkTreeIter iter, iter2;
- GSList *async_datas = NULL;
- gboolean found;
+ gboolean found = TRUE;
tree_view = editor->priv->active->tree_view;
tree_model = gtk_tree_view_get_model (tree_view);
if (!gtk_tree_model_get_iter_first (tree_model, &iter))
- return NULL;
+ return;
- found = TRUE;
while (found) {
- AsyncData *async_data;
+ TreeRowData *tree_row_data;
gboolean is_expanded = FALSE;
found = FALSE;
- async_data = subscription_editor_async_data_from_iter (tree_view, tree_model, &iter, &is_expanded);
-
- if (async_data && can_pick_folder_info (async_data->folder_info, mode)) {
- async_datas = g_slist_prepend (async_datas, async_data);
- } else if (async_data) {
- async_data_free (async_data);
+ tree_row_data = subscription_editor_tree_row_data_from_iter (
+ tree_view, tree_model, &iter, &is_expanded);
+
+ if (tree_row_data != NULL) {
+ if (can_pick_folder_info (tree_row_data->folder_info, mode))
+ g_queue_push_tail (out_tree_rows, tree_row_data);
+ else
+ tree_row_data_free (tree_row_data);
}
if (is_expanded && gtk_tree_model_iter_children (tree_model, &iter2, &iter)) {
@@ -768,8 +783,6 @@ subscription_editor_pick_shown (EMSubscriptionEditor *editor,
}
}
}
-
- return async_datas;
}
static void
@@ -780,7 +793,8 @@ subscription_editor_subscribe (EMSubscriptionEditor *editor)
GtkTreeView *tree_view;
GtkTreeIter iter;
gboolean have_selection;
- GSList *async_datas;
+ GQueue tree_rows = G_QUEUE_INIT;
+ TreeRowData *tree_row_data;
tree_view = editor->priv->active->tree_view;
selection = gtk_tree_view_get_selection (tree_view);
@@ -789,24 +803,32 @@ subscription_editor_subscribe (EMSubscriptionEditor *editor)
selection, &tree_model, &iter);
g_return_if_fail (have_selection);
- async_datas = g_slist_append (NULL,
- subscription_editor_async_data_from_iter (tree_view, tree_model, &iter, NULL));
+ tree_row_data = subscription_editor_tree_row_data_from_iter (
+ tree_view, tree_model, &iter, NULL);
- subscription_editor_subscribe_many (editor, async_datas);
+ g_queue_push_tail (&tree_rows, tree_row_data);
+ subscription_editor_subscribe_many (editor, &tree_rows);
+ g_warn_if_fail (g_queue_is_empty (&tree_rows));
}
static void
subscription_editor_subscribe_shown (EMSubscriptionEditor *editor)
{
- subscription_editor_subscribe_many (editor,
- subscription_editor_pick_shown (editor, PICK_UNSUBSCRIBED));
+ GQueue tree_rows = G_QUEUE_INIT;
+
+ subscription_editor_pick_shown (
+ editor, PICK_UNSUBSCRIBED, &tree_rows);
+ subscription_editor_subscribe_many (editor, &tree_rows);
}
static void
subscription_editor_subscribe_all (EMSubscriptionEditor *editor)
{
- subscription_editor_subscribe_many (editor,
- subscription_editor_pick_all (editor, PICK_UNSUBSCRIBED, NULL));
+ GQueue tree_rows = G_QUEUE_INIT;
+
+ subscription_editor_pick_all (
+ editor, PICK_UNSUBSCRIBED, NULL, &tree_rows);
+ subscription_editor_subscribe_many (editor, &tree_rows);
}
static void
@@ -825,57 +847,68 @@ subscription_editor_subscribe_popup_cb (EMSubscriptionEditor *editor)
menu = gtk_menu_new ();
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
_("_Subscribe"),
- gtk_widget_get_sensitive (editor->priv->subscribe_button),
+ gtk_widget_get_sensitive (
+ editor->priv->subscribe_button),
G_CALLBACK (subscription_editor_subscribe),
editor));
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
- _("Su_bscribe to shown"),
+ _("Su_bscribe To Shown"),
tree_filled,
G_CALLBACK (subscription_editor_subscribe_shown),
editor));
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
- _("Subscribe to _all"),
+ _("Subscribe To _All"),
tree_filled,
G_CALLBACK (subscription_editor_subscribe_all),
editor));
gtk_menu_popup (
- GTK_MENU (menu), NULL, NULL, position_below_widget_cb, editor->priv->subscribe_button,
+ GTK_MENU (menu), NULL, NULL,
+ position_below_widget_cb,
+ editor->priv->subscribe_button,
0, gtk_get_current_event_time ());
}
static void
subscription_editor_unsubscribe_hidden (EMSubscriptionEditor *editor)
{
- GSList *all_shown, *ll;
+ GQueue tree_rows = G_QUEUE_INIT;
GHashTable *skip_shown;
- all_shown = subscription_editor_pick_shown (editor, PICK_ALL);
- g_return_if_fail (all_shown != NULL);
+ subscription_editor_pick_shown (editor, PICK_ALL, &tree_rows);
+ g_return_if_fail (!g_queue_is_empty (&tree_rows));
skip_shown = g_hash_table_new (g_direct_hash, g_direct_equal);
- for (ll = all_shown; ll; ll = ll->next) {
- AsyncData *data = ll->data;
+ while (!g_queue_is_empty (&tree_rows)) {
+ TreeRowData *tree_row_data;
+
+ tree_row_data = g_queue_pop_head (&tree_rows);
- if (!data)
+ if (tree_row_data == NULL)
continue;
- g_hash_table_insert (skip_shown, data->folder_info, GINT_TO_POINTER (1));
- async_data_free (data);
- }
+ g_hash_table_insert (
+ skip_shown,
+ tree_row_data->folder_info,
+ GINT_TO_POINTER (1));
- g_slist_free (all_shown);
+ tree_row_data_free (tree_row_data);
+ }
- subscription_editor_unsubscribe_many (editor,
- subscription_editor_pick_all (editor, PICK_SUBSCRIBED, skip_shown));
+ subscription_editor_pick_all (
+ editor, PICK_SUBSCRIBED, skip_shown, &tree_rows);
+ subscription_editor_unsubscribe_many (editor, &tree_rows);
g_hash_table_destroy (skip_shown);
}
@@ -883,8 +916,11 @@ subscription_editor_unsubscribe_hidden (EMSubscriptionEditor *editor)
static void
subscription_editor_unsubscribe_all (EMSubscriptionEditor *editor)
{
- subscription_editor_unsubscribe_many (editor,
- subscription_editor_pick_all (editor, PICK_SUBSCRIBED, NULL));
+ GQueue tree_rows = G_QUEUE_INIT;
+
+ subscription_editor_pick_all (
+ editor, PICK_SUBSCRIBED, NULL, &tree_rows);
+ subscription_editor_unsubscribe_many (editor, &tree_rows);
}
static void
@@ -895,7 +931,8 @@ subscription_editor_unsubscribe (EMSubscriptionEditor *editor)
GtkTreeView *tree_view;
GtkTreeIter iter;
gboolean have_selection;
- GSList *async_datas;
+ GQueue tree_rows = G_QUEUE_INIT;
+ TreeRowData *tree_row_data;
tree_view = editor->priv->active->tree_view;
selection = gtk_tree_view_get_selection (tree_view);
@@ -904,10 +941,11 @@ subscription_editor_unsubscribe (EMSubscriptionEditor *editor)
selection, &tree_model, &iter);
g_return_if_fail (have_selection);
- async_datas = g_slist_append (NULL,
- subscription_editor_async_data_from_iter (tree_view, tree_model, &iter, NULL));
+ tree_row_data = subscription_editor_tree_row_data_from_iter (
+ tree_view, tree_model, &iter, NULL);
- subscription_editor_unsubscribe_many (editor, async_datas);
+ g_queue_push_tail (&tree_rows, tree_row_data);
+ subscription_editor_unsubscribe_many (editor, &tree_rows);
}
static void
@@ -926,29 +964,35 @@ subscription_editor_unsubscribe_popup_cb (EMSubscriptionEditor *editor)
menu = gtk_menu_new ();
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
_("_Unsubscribe"),
- gtk_widget_get_sensitive (editor->priv->unsubscribe_button),
+ gtk_widget_get_sensitive (
+ editor->priv->unsubscribe_button),
G_CALLBACK (subscription_editor_unsubscribe),
editor));
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
- _("Unsu_bscribe from hidden"),
+ _("Unsu_bscribe From Hidden"),
tree_filled,
G_CALLBACK (subscription_editor_unsubscribe_hidden),
editor));
- gtk_menu_shell_append (GTK_MENU_SHELL (menu),
+ gtk_menu_shell_append (
+ GTK_MENU_SHELL (menu),
subscription_editor_create_menu_item (
- _("Unsubscribe from _all"),
+ _("Unsubscribe From _All"),
tree_filled,
G_CALLBACK (subscription_editor_unsubscribe_all),
editor));
gtk_menu_popup (
- GTK_MENU (menu), NULL, NULL, position_below_widget_cb, editor->priv->unsubscribe_button,
+ GTK_MENU (menu), NULL, NULL,
+ position_below_widget_cb,
+ editor->priv->unsubscribe_button,
0, gtk_get_current_event_time ());
}
@@ -1743,7 +1787,9 @@ em_subscription_editor_init (EMSubscriptionEditor *editor)
G_CALLBACK (subscription_editor_subscribe), editor);
widget = gtk_button_new ();
- gtk_button_set_image (GTK_BUTTON (widget), gtk_arrow_new (GTK_ARROW_DOWN, GTK_SHADOW_NONE));
+ gtk_button_set_image (
+ GTK_BUTTON (widget),
+ gtk_arrow_new (GTK_ARROW_DOWN, GTK_SHADOW_NONE));
editor->priv->subscribe_arrow = widget;
gtk_widget_show (widget);
@@ -1752,11 +1798,19 @@ em_subscription_editor_init (EMSubscriptionEditor *editor)
G_CALLBACK (subscription_editor_subscribe_popup_cb), editor);
if (gtk_widget_get_direction (container) == GTK_TEXT_DIR_LTR) {
- gtk_box_pack_start (GTK_BOX (container), editor->priv->subscribe_button, TRUE, TRUE, 0);
- gtk_box_pack_start (GTK_BOX (container), editor->priv->subscribe_arrow, FALSE, FALSE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->subscribe_button, TRUE, TRUE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->subscribe_arrow, FALSE, FALSE, 0);
} else {
- gtk_box_pack_start (GTK_BOX (container), editor->priv->subscribe_arrow, FALSE, FALSE, 0);
- gtk_box_pack_start (GTK_BOX (container), editor->priv->subscribe_button, TRUE, TRUE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->subscribe_arrow, FALSE, FALSE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->subscribe_button, TRUE, TRUE, 0);
}
container = box;
@@ -1779,7 +1833,9 @@ em_subscription_editor_init (EMSubscriptionEditor *editor)
G_CALLBACK (subscription_editor_unsubscribe), editor);
widget = gtk_button_new ();
- gtk_button_set_image (GTK_BUTTON (widget), gtk_arrow_new (GTK_ARROW_DOWN, GTK_SHADOW_NONE));
+ gtk_button_set_image (
+ GTK_BUTTON (widget),
+ gtk_arrow_new (GTK_ARROW_DOWN, GTK_SHADOW_NONE));
editor->priv->unsubscribe_arrow = widget;
gtk_widget_show (widget);
@@ -1788,11 +1844,19 @@ em_subscription_editor_init (EMSubscriptionEditor *editor)
G_CALLBACK (subscription_editor_unsubscribe_popup_cb), editor);
if (gtk_widget_get_direction (container) == GTK_TEXT_DIR_LTR) {
- gtk_box_pack_start (GTK_BOX (container), editor->priv->unsubscribe_button, TRUE, TRUE, 0);
- gtk_box_pack_start (GTK_BOX (container), editor->priv->unsubscribe_arrow, FALSE, FALSE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->unsubscribe_button, TRUE, TRUE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->unsubscribe_arrow, FALSE, FALSE, 0);
} else {
- gtk_box_pack_start (GTK_BOX (container), editor->priv->unsubscribe_arrow, FALSE, FALSE, 0);
- gtk_box_pack_start (GTK_BOX (container), editor->priv->unsubscribe_button, TRUE, TRUE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->unsubscribe_arrow, FALSE, FALSE, 0);
+ gtk_box_pack_start (
+ GTK_BOX (container),
+ editor->priv->unsubscribe_button, TRUE, TRUE, 0);
}
container = box;