aboutsummaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
Diffstat (limited to 'shell')
-rw-r--r--shell/ChangeLog11
-rw-r--r--shell/e-storage-set-view.c119
2 files changed, 50 insertions, 80 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog
index 0bb41da144..6973ef6a2a 100644
--- a/shell/ChangeLog
+++ b/shell/ChangeLog
@@ -1,3 +1,14 @@
+2002-09-20 Ettore Perazzoli <ettore@ximian.com>
+
+ * e-storage-set-view.c: Removed member sort_idle_id in
+ EStorageSetViewPrivate.
+ (resort): Removed.
+ (sort_traverse_callback): Removed.
+ (sort_idle_callback): Removed.
+ (queue_resort): Removed.
+ (impl_destroy): Removed.
+ (folder_name_changed_cb): Sort now instead of queueing a resort.
+
2002-09-19 Ettore Perazzoli <ettore@ximian.com>
[Fix #28495 with a lame hack that works around Bonobo sizing
diff --git a/shell/e-storage-set-view.c b/shell/e-storage-set-view.c
index 86538851d2..6979a8b080 100644
--- a/shell/e-storage-set-view.c
+++ b/shell/e-storage-set-view.c
@@ -117,9 +117,6 @@ struct _EStorageSetViewPrivate {
not, when show_checkboxes is TRUE. */
EStorageSetViewHasCheckBoxFunc has_checkbox_func;
void *has_checkbox_func_data;
-
- /* Sorting idle function. */
- int sort_idle_id;
};
@@ -155,7 +152,7 @@ typedef enum _DndTargetType DndTargetType;
#define E_SHORTCUT_TYPE "E-SHORTCUT"
-/* Sorting. */
+/* Sorting callbacks. */
static int
storage_sort_callback (ETreeMemory *etmm,
@@ -188,7 +185,7 @@ storage_sort_callback (ETreeMemory *etmm,
return -1;
if (path_2_local)
return 1;
-
+
return g_utf8_collate (e_tree_model_value_at (E_TREE_MODEL (etmm), node1, 0),
e_tree_model_value_at (E_TREE_MODEL (etmm), node2, 0));
}
@@ -224,65 +221,6 @@ folder_sort_callback (ETreeMemory *etmm,
return +1;
}
-static gboolean
-sort_traverse_callback (ETreeModel *model,
- ETreePath node,
- void *data)
-{
- EStorageSetView *storage_set_view;
- EStorageSetViewPrivate *priv;
-
- storage_set_view = E_STORAGE_SET_VIEW (data);
- priv = storage_set_view->priv;
-
- e_tree_memory_sort_node (E_TREE_MEMORY (model), node,
- folder_sort_callback, storage_set_view);
-
- return FALSE;
-}
-
-static void
-resort (EStorageSetView *storage_set_view)
-{
- EStorageSetViewPrivate *priv;
-
- priv = storage_set_view->priv;
-
- e_tree_memory_sort_node (E_TREE_MEMORY (priv->etree_model), priv->root_node,
- storage_sort_callback, storage_set_view);
-
- e_tree_model_node_traverse (priv->etree_model, priv->root_node,
- sort_traverse_callback, storage_set_view);
-}
-
-static int
-sort_idle_callback (void *data)
-{
- EStorageSetView *storage_set_view;
- EStorageSetViewPrivate *priv;
-
- storage_set_view = E_STORAGE_SET_VIEW (data);
- priv = storage_set_view->priv;
-
- resort (storage_set_view);
-
- priv->sort_idle_id = 0;
- return FALSE;
-}
-
-static void
-queue_resort (EStorageSetView *storage_set_view)
-{
- EStorageSetViewPrivate *priv;
-
- priv = storage_set_view->priv;
-
- if (priv->sort_idle_id != 0)
- return;
-
- priv->sort_idle_id = g_idle_add (sort_idle_callback, storage_set_view);
-}
-
/* Helper functions. */
@@ -954,9 +892,6 @@ impl_destroy (GtkObject *object)
/* (No unreffing for priv->ui_container since we use a weakref.) */
- if (priv->sort_idle_id != 0)
- g_source_remove (priv->sort_idle_id);
-
g_free (priv->selected_row_path);
g_free (priv->right_click_row_path);
@@ -1222,7 +1157,7 @@ impl_tree_drag_motion (ETree *tree,
return FALSE;
folder_path = e_tree_memory_node_get_data (E_TREE_MEMORY (priv->etree_model),
- e_tree_node_at_row (E_TREE (storage_set_view), row));
+ e_tree_node_at_row (E_TREE (storage_set_view), row));
if (folder_path == NULL)
return FALSE;
@@ -1715,8 +1650,8 @@ new_storage_cb (EStorageSet *storage_set,
path = g_strconcat (E_PATH_SEPARATOR_S, e_storage_get_name (storage), NULL);
node = e_tree_memory_node_insert (E_TREE_MEMORY(priv->etree_model), priv->root_node, -1, path);
-
- queue_resort (storage_set_view);
+ e_tree_memory_sort_node (E_TREE_MEMORY(priv->etree_model), priv->root_node,
+ storage_sort_callback, storage_set_view);
if (! add_node_to_hash (storage_set_view, path, node)) {
e_tree_memory_node_remove (E_TREE_MEMORY(priv->etree_model), node);
@@ -1781,8 +1716,7 @@ new_folder_cb (EStorageSet *storage_set,
copy_of_path = g_strdup (path);
new_node = e_tree_memory_node_insert (E_TREE_MEMORY(etree), parent_node, -1, copy_of_path);
-
- queue_resort (storage_set_view);
+ e_tree_memory_sort_node (E_TREE_MEMORY(etree), parent_node, folder_sort_callback, storage_set_view);
if (! add_node_to_hash (storage_set_view, path, new_node)) {
e_tree_memory_node_remove (E_TREE_MEMORY(etree), new_node);
@@ -1968,8 +1902,6 @@ init (EStorageSetView *storage_set_view)
priv->has_checkbox_func = NULL;
priv->has_checkbox_func_data = NULL;
- priv->sort_idle_id = 0;
-
storage_set_view->priv = priv;
}
@@ -2021,7 +1953,31 @@ static void
folder_name_changed_cb (EFolder *folder,
void *data)
{
- queue_resort (E_STORAGE_SET_VIEW (data));
+ EStorageSetView *storage_set_view;
+ EStorageSetViewPrivate *priv;
+ FolderChangedCallbackData *callback_data;
+ ETreePath parent_node;
+ const char *last_separator;
+ char *parent_path;
+
+ callback_data = (FolderChangedCallbackData *) data;
+
+ storage_set_view = callback_data->storage_set_view;
+ priv = storage_set_view->priv;
+
+ last_separator = strrchr (callback_data->path, E_PATH_SEPARATOR);
+
+ parent_path = g_strndup (callback_data->path, last_separator - callback_data->path);
+ parent_node = g_hash_table_lookup (priv->path_to_etree_node, parent_path);
+ g_free (parent_path);
+
+ if (parent_node == NULL) {
+ g_warning ("EStorageSetView -- EFolder::name_changed emitted for a folder whose path I don't know.");
+ return;
+ }
+
+ e_tree_memory_sort_node (E_TREE_MEMORY (priv->etree_model), parent_node,
+ folder_sort_callback, storage_set_view);
}
static void
@@ -2037,7 +1993,7 @@ setup_folder_changed_callbacks (EStorageSetView *storage_set_view,
gtk_signal_connect_while_alive (GTK_OBJECT (folder), "name_changed",
GTK_SIGNAL_FUNC (folder_name_changed_cb),
- storage_set_view,
+ folder_changed_callback_data,
GTK_OBJECT (storage_set_view));
e_gtk_signal_connect_full_while_alive (GTK_OBJECT (folder), "changed",
@@ -2083,12 +2039,14 @@ insert_folders (EStorageSetView *storage_set_view,
folder_name = e_folder_get_name (folder);
full_path = g_strconcat ("/", storage_name, folder_path, NULL);
+
+ setup_folder_changed_callbacks (storage_set_view, folder, full_path);
+
node = e_tree_memory_node_insert (E_TREE_MEMORY(etree), parent, -1, (void *) full_path);
+ e_tree_memory_sort_node(E_TREE_MEMORY(etree), parent, folder_sort_callback, storage_set_view);
add_node_to_hash (storage_set_view, full_path, node);
insert_folders (storage_set_view, node, storage, folder_path);
-
- setup_folder_changed_callbacks (storage_set_view, folder, full_path);
}
e_free_string_list (folder_path_list);
@@ -2118,6 +2076,9 @@ insert_storages (EStorageSetView *storage_set_view)
path = g_strconcat ("/", name, NULL);
parent = e_tree_memory_node_insert (E_TREE_MEMORY(priv->etree_model), priv->root_node, -1, path);
+ e_tree_memory_sort_node (E_TREE_MEMORY(priv->etree_model),
+ priv->root_node,
+ storage_sort_callback, storage_set_view);
g_hash_table_insert (priv->path_to_etree_node, path, parent);
@@ -2126,8 +2087,6 @@ insert_storages (EStorageSetView *storage_set_view)
}
e_free_object_list (storage_list);
-
- resort (storage_set_view);
}
void