From 07ea8ad49bdee8a6a2c68c70c25ebe8e3249e7e0 Mon Sep 17 00:00:00 2001 From: Devashish Sharma Date: Thu, 3 Aug 2006 11:35:23 +0000 Subject: Fix for some bugs in gaim synchronization and automatic contacts. svn path=/trunk/; revision=32467 --- plugins/bbdb/ChangeLog | 6 ++++++ plugins/bbdb/bbdb.c | 15 ++++++++++++++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/plugins/bbdb/ChangeLog b/plugins/bbdb/ChangeLog index 92a5b377e7..621d19c631 100644 --- a/plugins/bbdb/ChangeLog +++ b/plugins/bbdb/ChangeLog @@ -1,3 +1,9 @@ +2006-08-03 Devashish Sharma + + * bbdb.c: Gaim and automatic contacts were not seen until + evolution is restarted. + Fix for Bug #346180, 349371, 346353 + 2006-07-18 Ross Burton * gaimbuddies.c: diff --git a/plugins/bbdb/bbdb.c b/plugins/bbdb/bbdb.c index 4faa43604c..64a00ad9f5 100644 --- a/plugins/bbdb/bbdb.c +++ b/plugins/bbdb/bbdb.c @@ -261,7 +261,10 @@ bbdb_open_addressbook (int type) gconf = gconf_client_get_default (); /* Check to see if we're supposed to be running */ - enable = gconf_client_get_bool (gconf, GCONF_KEY_ENABLE, NULL); + if (type == GAIM_ADDRESSBOOK) + enable = gconf_client_get_bool (gconf, GCONF_KEY_ENABLE_GAIM, NULL); + else + enable = gconf_client_get_bool (gconf, GCONF_KEY_ENABLE, NULL); if (! enable) { g_object_unref (G_OBJECT (gconf)); return NULL; @@ -326,6 +329,7 @@ enable_toggled_cb (GtkWidget *widget, gpointer data) { struct bbdb_stuff *stuff = (struct bbdb_stuff *) data; gboolean active; + ESource *selected_source; active = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)); @@ -333,6 +337,10 @@ enable_toggled_cb (GtkWidget *widget, gpointer data) gconf_client_set_bool (stuff->target->gconf, GCONF_KEY_ENABLE, active, NULL); gtk_widget_set_sensitive (stuff->option_menu, active); + if (active && !gconf_client_get_string (stuff->target->gconf, GCONF_KEY_WHICH_ADDRESSBOOK, NULL)) { + selected_source = e_source_option_menu_peek_selected (E_SOURCE_OPTION_MENU (stuff->option_menu)); + gconf_client_set_string (stuff->target->gconf, GCONF_KEY_WHICH_ADDRESSBOOK, e_source_get_uri (selected_source), NULL); + } } static void @@ -340,6 +348,7 @@ enable_gaim_toggled_cb (GtkWidget *widget, gpointer data) { struct bbdb_stuff *stuff = (struct bbdb_stuff *) data; gboolean active; + ESource *selected_source; active = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)); @@ -347,6 +356,10 @@ enable_gaim_toggled_cb (GtkWidget *widget, gpointer data) gconf_client_set_bool (stuff->target->gconf, GCONF_KEY_ENABLE_GAIM, active, NULL); gtk_widget_set_sensitive (stuff->gaim_option_menu, active); + if (active && !gconf_client_get_string (stuff->target->gconf, GCONF_KEY_WHICH_ADDRESSBOOK_GAIM, NULL)) { + selected_source = e_source_option_menu_peek_selected (E_SOURCE_OPTION_MENU (stuff->gaim_option_menu)); + gconf_client_set_string (stuff->target->gconf, GCONF_KEY_WHICH_ADDRESSBOOK_GAIM, e_source_get_uri (selected_source), NULL); + } } static void -- cgit v1.2.3