aboutsummaryrefslogtreecommitdiffstats
path: root/mail/subscribe-dialog.c
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2003-03-26 04:33:25 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2003-03-26 04:33:25 +0800
commit2792bf9ffe58ffe07f67293056350a015a12b908 (patch)
tree0772d3da05a7398b16dd04439be12d13a1f1994a /mail/subscribe-dialog.c
parentb6b70c0bf9114a65f68d22d8f017e463713e680a (diff)
downloadgsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar.gz
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar.bz2
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar.lz
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar.xz
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.tar.zst
gsoc2013-evolution-2792bf9ffe58ffe07f67293056350a015a12b908.zip
Remove search entry which never worked right (and can't work as users
2003-03-25 Jeffrey Stedfast <fejj@ximian.com> * subscribe-dialog.c: Remove search entry which never worked right (and can't work as users expect anyway, since we don't do namespace stripping). Fixes bug #40083. (ftree_node_new): Ignore \NoSelect as far as marking it "subscribable". Fixes bug #40124. svn path=/trunk/; revision=20509
Diffstat (limited to 'mail/subscribe-dialog.c')
-rw-r--r--mail/subscribe-dialog.c123
1 files changed, 15 insertions, 108 deletions
diff --git a/mail/subscribe-dialog.c b/mail/subscribe-dialog.c
index 173c8f9581..bf263b501a 100644
--- a/mail/subscribe-dialog.c
+++ b/mail/subscribe-dialog.c
@@ -143,8 +143,7 @@ struct _FolderETree {
CamelStore *store;
EvolutionStorage *e_storage;
char *service_name;
- char *search;
-
+
FolderETreeActivityCallback activity_cb;
gpointer activity_data;
int activity_level;
@@ -486,7 +485,7 @@ subscribe_get_global_extras (void)
typedef struct _ftree_node ftree_node;
struct _ftree_node {
- guint8 flags;
+ guint8 flags;
char *cache;
int uri_offset;
int full_name_offset;
@@ -502,22 +501,15 @@ struct _ftree_node {
#define FTREE_NODE_ROOT (1 << 3)
static ftree_node *
-ftree_node_new_root (const char *prefix)
+ftree_node_new_root (void)
{
ftree_node *node;
- size_t size;
-
- if (prefix == NULL)
- prefix = "";
-
- size = sizeof (ftree_node) + strlen (prefix) + 1;
-
- node = g_malloc (size);
+
+ node = g_malloc (sizeof (ftree_node));
node->flags = FTREE_NODE_ROOT;
node->uri_offset = 0;
- node->full_name_offset = 1;
+ node->full_name_offset = 0;
node->data[0] = '\0';
- strcpy (node->data + 1, prefix);
return node;
}
@@ -528,8 +520,7 @@ ftree_node_new (CamelStore *store, CamelFolderInfo *fi)
ftree_node *node;
int uri_offset, full_name_offset;
size_t size;
- CamelURL *url;
-
+
uri_offset = strlen (fi->name) + 1;
full_name_offset = uri_offset + strlen (fi->url) + 1;
size = full_name_offset + strlen (fi->full_name);
@@ -539,15 +530,8 @@ ftree_node_new (CamelStore *store, CamelFolderInfo *fi)
node->cache = NULL;
- /* Noselect? */
-
- url = camel_url_new (fi->url, NULL);
- if (camel_url_get_param (url, "noselect"))
- node->flags = 0;
- else
- node->flags = FTREE_NODE_SUBSCRIBABLE;
- camel_url_free (url);
-
+ node->flags = FTREE_NODE_SUBSCRIBABLE;
+
/* subscribed? */
if (camel_store_folder_subscribed (store, fi->full_name))
@@ -760,7 +744,7 @@ fe_check_for_children (FolderETree *ftree, ETreePath path)
/* figure out our search prefix */
if (path == ftree->root)
- prefix = ftree->search;
+ prefix = "";
else
prefix = ftree_node_get_full_name (node);
@@ -782,7 +766,7 @@ fe_create_root_node (FolderETree *ftree)
{
ftree_node *node;
- node = ftree_node_new_root (ftree->search);
+ node = ftree_node_new_root ();
ftree->root = e_tree_memory_node_insert (E_TREE_MEMORY(ftree), NULL, 0, node);
fe_check_for_children (ftree, ftree->root);
}
@@ -870,8 +854,7 @@ fe_finalise (GObject *obj)
camel_object_unref (ftree->store);
bonobo_object_unref (BONOBO_OBJECT (ftree->e_storage));
-
- g_free (ftree->search);
+
g_free (ftree->service_name);
((GObjectClass *)folder_etree_parent_class)->finalize(obj);
@@ -913,9 +896,7 @@ folder_etree_init (GtkObject *object)
ftree->scan_ops = g_hash_table_new (g_direct_hash, g_direct_equal);
ftree->subscribe_ops = g_hash_table_new (g_direct_hash, g_direct_equal);
-
- ftree->search = g_strdup ("");
-
+
ftree->activity_level = 0;
ftree->node_full_name = g_hash_table_new(g_str_hash, g_str_equal);
}
@@ -971,19 +952,6 @@ folder_etree_clear_tree (FolderETree *ftree)
e_tree_memory_thaw (E_TREE_MEMORY (ftree));
}
-static void
-folder_etree_set_search (FolderETree *ftree, const char *search)
-{
- if (!strcmp (search, ftree->search))
- return;
-
- g_free (ftree->search);
- ftree->search = g_strdup (search);
-
- folder_etree_clear_tree (ftree);
-}
-
-
static int
folder_etree_path_set_subscription (FolderETree *ftree, ETreePath path, gboolean subscribe)
{
@@ -1305,18 +1273,6 @@ sc_refresh_pressed (GtkWidget *widget, gpointer user_data)
}
static void
-sc_search_activated (GtkWidget *widget, gpointer user_data)
-{
- SubscribeDialog *sc = SUBSCRIBE_DIALOG (user_data);
- StoreData *store = sc->priv->current_store;
-
- if (!store)
- return;
-
- folder_etree_set_search (store->ftree, gtk_entry_get_text (GTK_ENTRY (widget)));
-}
-
-static void
sc_close_pressed (GtkWidget *widget, gpointer user_data)
{
SubscribeDialog *sc = SUBSCRIBE_DIALOG (user_data);
@@ -1349,45 +1305,10 @@ sc_unsubscribe_pressed (GtkWidget *widget, gpointer user_data)
}
static void
-sc_all_toggled (GtkWidget *widget, gpointer user_data)
-{
- SubscribeDialog *sc = SUBSCRIBE_DIALOG (user_data);
- StoreData *store = sc->priv->current_store;
-
- if (!store)
- return;
-
- if (GTK_TOGGLE_BUTTON (widget)->active) {
- gtk_widget_set_sensitive (sc->priv->search_entry, FALSE);
- folder_etree_set_search (store->ftree, "");
- }
-}
-
-static void
-sc_filter_toggled (GtkWidget *widget, gpointer user_data)
-{
- SubscribeDialog *sc = SUBSCRIBE_DIALOG (user_data);
- StoreData *store = sc->priv->current_store;
-
- if (!store)
- return;
-
- if (GTK_TOGGLE_BUTTON (widget)->active) {
- gtk_widget_set_sensitive (sc->priv->search_entry, TRUE);
- sc_search_activated (sc->priv->search_entry, sc);
- }
-}
-
-static void
kill_default_view (SubscribeDialog *sc)
{
gtk_widget_hide (sc->priv->none_item);
-
- /* the entry will be set sensitive when one of the
- * radio buttons is activated, if necessary. */
-
- gtk_widget_set_sensitive (sc->priv->all_radio, TRUE);
- gtk_widget_set_sensitive (sc->priv->filter_radio, TRUE);
+
gtk_widget_set_sensitive (sc->priv->sub_button, TRUE);
gtk_widget_set_sensitive (sc->priv->unsub_button, TRUE);
gtk_widget_set_sensitive (sc->priv->refresh_button, TRUE);
@@ -1466,14 +1387,6 @@ menu_item_selected (GtkMenuItem *item, gpointer user_data)
gtk_widget_show (sd->widget);
sc->priv->current_widget = sd->widget;
sc->priv->current_store = sd;
-
- if (*sd->ftree->search) {
- gtk_entry_set_text (GTK_ENTRY (sc->priv->search_entry), sd->ftree->search);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sc->priv->filter_radio), TRUE);
- } else {
- gtk_entry_set_text (GTK_ENTRY (sc->priv->search_entry), "");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sc->priv->all_radio), TRUE);
- }
}
static void
@@ -1660,22 +1573,16 @@ subscribe_dialog_construct (GtkObject *object)
gtk_box_pack_start (GTK_BOX (sc->priv->hbox), sc->priv->default_widget, TRUE, TRUE, 0);
gtk_widget_show (sc->priv->default_widget);
- gtk_widget_set_sensitive (sc->priv->all_radio, FALSE);
- gtk_widget_set_sensitive (sc->priv->filter_radio, FALSE);
- gtk_widget_set_sensitive (sc->priv->search_entry, FALSE);
gtk_widget_set_sensitive (sc->priv->sub_button, FALSE);
gtk_widget_set_sensitive (sc->priv->unsub_button, FALSE);
gtk_widget_set_sensitive (sc->priv->refresh_button, FALSE);
/* hook up some signals */
- g_signal_connect(sc->priv->search_entry, "activate", G_CALLBACK(sc_search_activated), sc);
g_signal_connect(sc->priv->close_button, "clicked", G_CALLBACK(sc_close_pressed), sc);
g_signal_connect(sc->priv->sub_button, "clicked", G_CALLBACK(sc_subscribe_pressed), sc);
g_signal_connect(sc->priv->unsub_button, "clicked", G_CALLBACK(sc_unsubscribe_pressed), sc);
g_signal_connect(sc->priv->refresh_button, "clicked", G_CALLBACK(sc_refresh_pressed), sc);
- g_signal_connect(sc->priv->all_radio, "toggled", G_CALLBACK(sc_all_toggled), sc);
- g_signal_connect(sc->priv->filter_radio, "toggled", G_CALLBACK(sc_filter_toggled), sc);
-
+
/* progress */
gtk_progress_bar_set_pulse_step(GTK_PROGRESS_BAR(sc->priv->progress), 0.1);