diff options
Diffstat (limited to 'addressbook/gui/component')
3 files changed, 134 insertions, 90 deletions
diff --git a/addressbook/gui/component/select-names/e-select-names-completion.c b/addressbook/gui/component/select-names/e-select-names-completion.c index 2e2cd03be1..1899662dda 100644 --- a/addressbook/gui/component/select-names/e-select-names-completion.c +++ b/addressbook/gui/component/select-names/e-select-names-completion.c @@ -43,18 +43,23 @@ #include <addressbook/backend/ebook/e-card-simple.h> #include <addressbook/backend/ebook/e-card-compare.h> - -struct _ESelectNamesCompletionPrivate { - - ESelectNamesModel *model; - +typedef struct { EBook *book; - gboolean book_ready; - guint book_view_tag; EBookView *book_view; + ESelectNamesCompletion *comp; guint card_added_tag; guint seq_complete_tag; + gboolean sequence_complete_received; +} ESelectNamesCompletionBookData; + +struct _ESelectNamesCompletionPrivate { + + ESelectNamesModel *model; + + GList *book_data; + gint books_not_ready; + gint pending_completion_seq; gchar *waiting_query; gint waiting_pos, waiting_limit; @@ -725,26 +730,28 @@ static void e_select_names_completion_destroy (GtkObject *object) { ESelectNamesCompletion *comp = E_SELECT_NAMES_COMPLETION (object); + GList *l; if (comp->priv->model) gtk_object_unref (GTK_OBJECT (comp->priv->model)); - if (comp->priv->book) - gtk_object_unref (GTK_OBJECT (comp->priv->book)); - - if (comp->priv->card_added_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->card_added_tag); - comp->priv->card_added_tag = 0; - } - - if (comp->priv->seq_complete_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->seq_complete_tag); - comp->priv->seq_complete_tag = 0; + for (l = comp->priv->book_data; l; l = l->next) { + ESelectNamesCompletionBookData *book_data = l->data; + gtk_object_unref (GTK_OBJECT (book_data->book)); + if (book_data->book_view) + gtk_object_unref (GTK_OBJECT (book_data->book_view)); + if (book_data->card_added_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->card_added_tag); + book_data->card_added_tag = 0; + } + if (book_data->seq_complete_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->seq_complete_tag); + book_data->seq_complete_tag = 0; + } + g_free (book_data); } + g_list_free (comp->priv->book_data); - if (comp->priv->book_view) - gtk_object_unref (GTK_OBJECT (comp->priv->book_view)); - g_free (comp->priv->waiting_query); g_free (comp->priv->query_text); @@ -800,46 +807,50 @@ static void e_select_names_completion_got_book_view_cb (EBook *book, EBookStatus status, EBookView *view, gpointer user_data) { ESelectNamesCompletion *comp; + ESelectNamesCompletionBookData *book_data; if (status != E_BOOK_STATUS_SUCCESS) return; - comp = E_SELECT_NAMES_COMPLETION (user_data); + book_data = (ESelectNamesCompletionBookData*)user_data; + comp = book_data->comp; - comp->priv->book_view_tag = 0; + book_data->book_view_tag = 0; - if (comp->priv->card_added_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->card_added_tag); - comp->priv->card_added_tag = 0; + if (book_data->card_added_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->card_added_tag); + book_data->card_added_tag = 0; } - if (comp->priv->seq_complete_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->seq_complete_tag); - comp->priv->seq_complete_tag = 0; + if (book_data->seq_complete_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->seq_complete_tag); + book_data->seq_complete_tag = 0; } gtk_object_ref (GTK_OBJECT (view)); - if (comp->priv->book_view) - gtk_object_unref (GTK_OBJECT (comp->priv->book_view)); - comp->priv->book_view = view; + if (book_data->book_view) + gtk_object_unref (GTK_OBJECT (book_data->book_view)); + book_data->book_view = view; - comp->priv->card_added_tag = + book_data->card_added_tag = gtk_signal_connect (GTK_OBJECT (view), "card_added", GTK_SIGNAL_FUNC (e_select_names_completion_card_added_cb), - comp); + book_data); - comp->priv->seq_complete_tag = + book_data->seq_complete_tag = gtk_signal_connect (GTK_OBJECT (view), "sequence_complete", GTK_SIGNAL_FUNC (e_select_names_completion_seq_complete_cb), - comp); + book_data); + book_data->sequence_complete_received = FALSE; + comp->priv->pending_completion_seq++; } static void e_select_names_completion_card_added_cb (EBookView *book_view, const GList *cards, gpointer user_data) { - ESelectNamesCompletion *comp = E_SELECT_NAMES_COMPLETION (user_data); - + ESelectNamesCompletionBookData *book_data = user_data; + ESelectNamesCompletion *comp = book_data->comp; if (e_completion_searching (E_COMPLETION (comp))) { book_query_process_card_list (comp, cards); @@ -856,7 +867,8 @@ e_select_names_completion_card_added_cb (EBookView *book_view, const GList *card static void e_select_names_completion_seq_complete_cb (EBookView *book_view, gpointer user_data) { - ESelectNamesCompletion *comp = E_SELECT_NAMES_COMPLETION (user_data); + ESelectNamesCompletionBookData *book_data = user_data; + ESelectNamesCompletion *comp = E_SELECT_NAMES_COMPLETION(book_data->comp); /* * We aren't searching, but the addressbook has changed -- clear our card cache so that @@ -867,6 +879,13 @@ e_select_names_completion_seq_complete_cb (EBookView *book_view, gpointer user_d return; } + if (!book_data->sequence_complete_received) { + book_data->sequence_complete_received = TRUE; + comp->priv->pending_completion_seq --; + if (comp->priv->pending_completion_seq > 0) + return; + } + g_free (comp->priv->query_text); comp->priv->query_text = NULL; @@ -887,6 +906,8 @@ e_select_names_completion_seq_complete_cb (EBookView *book_view, gpointer user_d static void e_select_names_completion_stop_query (ESelectNamesCompletion *comp) { + GList *l; + g_return_if_fail (comp && E_IS_SELECT_NAMES_COMPLETION (comp)); if (out) @@ -902,31 +923,32 @@ e_select_names_completion_stop_query (ESelectNamesCompletion *comp) g_free (comp->priv->query_text); comp->priv->query_text = NULL; - if (comp->priv->book_view_tag) { - if (out) - fprintf (out, "cancelled book view creation\n"); - e_book_cancel (comp->priv->book, comp->priv->book_view_tag); - comp->priv->book_view_tag = 0; - } - - if (comp->priv->book_view) { - - if (out) - fprintf (out, "disconnecting book view signals\n"); - - if (comp->priv->card_added_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->card_added_tag); - comp->priv->card_added_tag = 0; - } - if (comp->priv->seq_complete_tag) { - gtk_signal_disconnect (GTK_OBJECT (comp->priv->book_view), comp->priv->seq_complete_tag); - comp->priv->seq_complete_tag = 0; + for (l = comp->priv->book_data; l; l = l->next) { + ESelectNamesCompletionBookData *book_data = l->data; + if (book_data->book_view_tag) { + if (out) + fprintf (out, "cancelled book view creation\n"); + e_book_cancel (book_data->book, book_data->book_view_tag); + book_data->book_view_tag = 0; } + if (book_data->book_view) { + if (out) + fprintf (out, "disconnecting book view signals\n"); + + if (book_data->card_added_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->card_added_tag); + book_data->card_added_tag = 0; + } + if (book_data->seq_complete_tag) { + gtk_signal_disconnect (GTK_OBJECT (book_data->book_view), book_data->seq_complete_tag); + book_data->seq_complete_tag = 0; + } - if (out) - fprintf (out, "unrefed book view\n"); - gtk_object_unref (GTK_OBJECT (comp->priv->book_view)); - comp->priv->book_view = NULL; + if (out) + fprintf (out, "unrefed book view\n"); + gtk_object_unref (GTK_OBJECT (book_data->book_view)); + book_data->book_view = NULL; + } } /* Clear the cache, which may contain partial results. */ @@ -942,7 +964,7 @@ e_select_names_completion_start_query (ESelectNamesCompletion *comp, const gchar e_select_names_completion_stop_query (comp); /* Stop any prior queries. */ - if (comp->priv->book_ready) { + if (comp->priv->books_not_ready == 0) { gchar *sexp; g_free (comp->priv->query_text); @@ -953,15 +975,18 @@ e_select_names_completion_start_query (ESelectNamesCompletion *comp, const gchar sexp = book_query_sexp (comp); if (sexp && *sexp) { + GList *l; if (out) fprintf (out, "\n\n**** starting query: \"%s\"\n", comp->priv->query_text); - comp->priv->book_view_tag = e_book_get_book_view (comp->priv->book, sexp, - e_select_names_completion_got_book_view_cb, comp); - - if (! comp->priv->book_view_tag) - g_warning ("Exception calling e_book_get_book_view"); + for (l = comp->priv->book_data; l; l = l->next) { + ESelectNamesCompletionBookData *book_data = l->data; + book_data->book_view_tag = e_book_get_book_view (book_data->book, sexp, + e_select_names_completion_got_book_view_cb, book_data); + if (! book_data->book_view_tag) + g_warning ("Exception calling e_book_get_book_view"); + } } else { g_free (comp->priv->query_text); @@ -981,6 +1006,7 @@ e_select_names_completion_do_query (ESelectNamesCompletion *comp, const gchar *q { gchar *clean; gboolean query_is_still_running, can_reuse_cached_cards; + GList *l; g_return_if_fail (comp != NULL); g_return_if_fail (E_IS_SELECT_NAMES_COMPLETION (comp)); @@ -992,7 +1018,13 @@ e_select_names_completion_do_query (ESelectNamesCompletion *comp, const gchar *q return; } - query_is_still_running = comp->priv->book_view_tag; + query_is_still_running = FALSE; + for (l = comp->priv->book_data; l; l = l->next) { + ESelectNamesCompletionBookData *book_data = l->data; + query_is_still_running = book_data->book_view_tag; + if (query_is_still_running) + break; + } if (out) { fprintf (out, "do_query: %s => %s\n", query_text, clean); @@ -1148,7 +1180,7 @@ check_capabilities (ESelectNamesCompletion *comp, EBook *book) static void e_select_names_completion_book_ready (EBook *book, EBookStatus status, ESelectNamesCompletion *comp) { - comp->priv->book_ready = TRUE; + comp->priv->books_not_ready--; g_return_if_fail (E_IS_BOOK (book)); g_return_if_fail (E_IS_SELECT_NAMES_COMPLETION (comp)); @@ -1157,7 +1189,7 @@ e_select_names_completion_book_ready (EBook *book, EBookStatus status, ESelectNa /* If waiting_query is non-NULL, someone tried to start a query before the book was ready. Now that it is, get started. */ - if (comp->priv->waiting_query) { + if (comp->priv->books_not_ready == 0 && comp->priv->waiting_query) { e_select_names_completion_start_query (comp, comp->priv->waiting_query); g_free (comp->priv->waiting_query); comp->priv->waiting_query = NULL; @@ -1185,23 +1217,21 @@ e_select_names_completion_new (EBook *book, ESelectNamesModel *model) comp = (ESelectNamesCompletion *) gtk_type_new (e_select_names_completion_get_type ()); if (book == NULL) { + ESelectNamesCompletionBookData *book_data = g_new0 (ESelectNamesCompletionBookData, 1); - comp->priv->book = e_book_new (); - gtk_object_ref (GTK_OBJECT (comp->priv->book)); - gtk_object_sink (GTK_OBJECT (comp->priv->book)); + book_data->book = e_book_new (); + book_data->comp = comp; + gtk_object_ref (GTK_OBJECT (book_data->book)); + gtk_object_sink (GTK_OBJECT (book_data->book)); + + comp->priv->book_data = g_list_append (comp->priv->book_data, book_data); + comp->priv->books_not_ready++; - comp->priv->book_ready = FALSE; gtk_object_ref (GTK_OBJECT (comp)); /* ref ourself before our async call */ - e_book_load_local_address_book (comp->priv->book, (EBookCallback) e_select_names_completion_book_ready, comp); + e_book_load_local_address_book (book_data->book, (EBookCallback) e_select_names_completion_book_ready, comp); } else { - - comp->priv->book = book; - gtk_object_ref (GTK_OBJECT (comp->priv->book)); - comp->priv->book_ready = TRUE; - - check_capabilities (comp, book); - + e_select_names_completion_add_book (comp, book); } comp->priv->model = model; @@ -1210,6 +1240,21 @@ e_select_names_completion_new (EBook *book, ESelectNamesModel *model) return E_COMPLETION (comp); } +void +e_select_names_completion_add_book (ESelectNamesCompletion *comp, EBook *book) +{ + ESelectNamesCompletionBookData *book_data; + + g_return_if_fail (book != NULL); + + book_data = g_new0 (ESelectNamesCompletionBookData, 1); + book_data->book = book; + book_data->comp = comp; + check_capabilities (comp, book); + gtk_object_ref (GTK_OBJECT (book_data->book)); + comp->priv->book_data = g_list_append (comp->priv->book_data, book_data); +} + gboolean e_select_names_completion_get_match_contact_lists (ESelectNamesCompletion *comp) { diff --git a/addressbook/gui/component/select-names/e-select-names-completion.h b/addressbook/gui/component/select-names/e-select-names-completion.h index 8b79112569..03a30c3cc2 100644 --- a/addressbook/gui/component/select-names/e-select-names-completion.h +++ b/addressbook/gui/component/select-names/e-select-names-completion.h @@ -57,7 +57,7 @@ struct _ESelectNamesCompletionClass { GtkType e_select_names_completion_get_type (void); ECompletion *e_select_names_completion_new (EBook *, ESelectNamesModel *); - +void e_select_names_completion_add_book (ESelectNamesCompletion *, EBook *); gboolean e_select_names_completion_get_match_contact_lists (ESelectNamesCompletion *); void e_select_names_completion_set_match_contact_lists (ESelectNamesCompletion *, gboolean); diff --git a/addressbook/gui/component/select-names/e-select-names-manager.c b/addressbook/gui/component/select-names/e-select-names-manager.c index d422265c02..10b7662b31 100644 --- a/addressbook/gui/component/select-names/e-select-names-manager.c +++ b/addressbook/gui/component/select-names/e-select-names-manager.c @@ -120,7 +120,7 @@ e_select_names_manager_new (void) CORBA_exception_init (&ev); - db = bonobo_get_object ("wombat:", "Bonobo/ConfigDatabase", &ev); + db = addressbook_config_database (&ev); val = bonobo_config_get_string (db, "/Addressbook/Completion/uri", &ev); @@ -135,10 +135,6 @@ e_select_names_manager_new (void) else manager->completion_book = NULL; - CORBA_exception_init (&ev); - bonobo_object_release_unref (db, &ev); - CORBA_exception_free (&ev); - return manager; } @@ -500,7 +496,10 @@ e_select_names_manager_create_entry (ESelectNamesManager *manager, const char *i e_list_append (manager->entries, entry); g_free(entry); - comp = e_select_names_completion_new (manager->completion_book, section->model); + comp = e_select_names_completion_new (NULL, section->model); + if (manager->completion_book) + e_select_names_completion_add_book (E_SELECT_NAMES_COMPLETION (comp), + manager->completion_book); e_entry_enable_completion_full (eentry, comp, 50, completion_handler); gtk_object_set_data (GTK_OBJECT (eentry), "completion_handler", comp); |