diff options
-rw-r--r-- | addressbook/ChangeLog | 14 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/e-contact-editor.c | 38 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/e-contact-editor.h | 4 |
3 files changed, 53 insertions, 3 deletions
diff --git a/addressbook/ChangeLog b/addressbook/ChangeLog index 3ac458943b..bdbd66e4ec 100644 --- a/addressbook/ChangeLog +++ b/addressbook/ChangeLog @@ -1,3 +1,17 @@ +2004-06-30 Chris Toshok <toshok@ximian.com> + + * gui/contact-editor/e-contact-editor.c + (e_contact_editor_dispose): disconnect source/target_editable + signal ids. + (e_contact_editor_set_property): disconnect/connect editable + signals. + (writable_changed): new function - we need this since writable + status is generally communicated asynchronously with the async + interface. + + * gui/contact-editor/e-contact-editor.h (struct _EContactEditor): + add source/target_editable_id slots. + 2004-06-29 Rodney Dawes <dobey@novell.com> * tools/Makefile.am (bin_PROGRAMS): Change to privlibexec_PROGRAMS diff --git a/addressbook/gui/contact-editor/e-contact-editor.c b/addressbook/gui/contact-editor/e-contact-editor.c index 6038d44775..0dcfbf47ba 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.c +++ b/addressbook/gui/contact-editor/e-contact-editor.c @@ -2999,11 +2999,13 @@ e_contact_editor_dispose (GObject *object) } if (e_contact_editor->source_book) { + g_signal_handler_disconnect (e_contact_editor->source_book, e_contact_editor->source_editable_id); g_object_unref(e_contact_editor->source_book); e_contact_editor->source_book = NULL; } if (e_contact_editor->target_book) { + g_signal_handler_disconnect (e_contact_editor->target_book, e_contact_editor->target_editable_id); g_object_unref(e_contact_editor->target_book); e_contact_editor->target_book = NULL; } @@ -3079,6 +3081,28 @@ e_contact_editor_new (EBook *book, } static void +writable_changed (EBook *book, gboolean writable, EContactEditor *ce) +{ + int new_source_editable, new_target_editable; + gboolean changed = FALSE; + + new_source_editable = e_book_is_writable (ce->source_book); + new_target_editable = e_book_is_writable (ce->target_book); + + if (ce->source_editable != new_source_editable) + changed = TRUE; + + if (ce->target_editable != new_target_editable) + changed = TRUE; + + ce->source_editable = new_source_editable; + ce->target_editable = new_target_editable; + + if (changed) + sensitize_all (ce); +} + +static void e_contact_editor_set_property (GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec) { EContactEditor *editor; @@ -3090,11 +3114,15 @@ e_contact_editor_set_property (GObject *object, guint prop_id, const GValue *val gboolean writable; gboolean changed = FALSE; - if (editor->source_book) + if (editor->source_book) { + g_signal_handler_disconnect (editor->source_book, editor->source_editable_id); g_object_unref(editor->source_book); + } editor->source_book = E_BOOK (g_value_get_object (value)); g_object_ref (editor->source_book); - + editor->source_editable_id = g_signal_connect (editor->source_book, "writable_status", + G_CALLBACK (writable_changed), editor); + if (!editor->target_book) { editor->target_book = editor->source_book; g_object_ref (editor->target_book); @@ -3122,10 +3150,14 @@ e_contact_editor_set_property (GObject *object, guint prop_id, const GValue *val } case PROP_TARGET_BOOK: { - if (editor->target_book) + if (editor->target_book) { + g_signal_handler_disconnect (editor->target_book, editor->target_editable_id); g_object_unref(editor->target_book); + } editor->target_book = E_BOOK (g_value_get_object (value)); g_object_ref (editor->target_book); + editor->target_editable_id = g_signal_connect (editor->target_book, "writable_status", + G_CALLBACK (writable_changed), editor); e_book_async_get_supported_fields (editor->target_book, (EBookEListCallback) supported_fields_cb, editor); diff --git a/addressbook/gui/contact-editor/e-contact-editor.h b/addressbook/gui/contact-editor/e-contact-editor.h index 7ab3969e3f..58d9f2bb0d 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.h +++ b/addressbook/gui/contact-editor/e-contact-editor.h @@ -96,6 +96,10 @@ struct _EContactEditor /* ID for async load_source call */ guint load_source_id; EBook *load_book; + + /* signal ids for "writable_status" */ + int source_editable_id; + int target_editable_id; }; struct _EContactEditorClass |