diff options
author | Matthew Barnes <mbarnes@redhat.com> | 2009-07-13 00:55:10 +0800 |
---|---|---|
committer | Matthew Barnes <mbarnes@redhat.com> | 2009-07-13 04:00:54 +0800 |
commit | 0d6061a4ebf34cbe4f640e755372c38bd698ed25 (patch) | |
tree | 9ae7c1391e0103d959896b7db9b296bcb61e5f6d /addressbook/gui/contact-list-editor | |
parent | c4d1d29eaaae6c2668599de0c989f5fe2b189c1e (diff) | |
download | gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar.gz gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar.bz2 gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar.lz gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar.xz gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.tar.zst gsoc2013-evolution-0d6061a4ebf34cbe4f640e755372c38bd698ed25.zip |
Add a "quit-requested" signal to the shutdown protocol.
The contact and contact-list editors now demonstrate this part of the
shutdown protocol. They listen for the "quit-requested" signal from the
shell and prompt to save changes, discard changes or cancel. If the user
cancels, the editor calls e_shell_cancel_quit() to do just that.
Diffstat (limited to 'addressbook/gui/contact-list-editor')
-rw-r--r-- | addressbook/gui/contact-list-editor/e-contact-list-editor.c | 64 | ||||
-rw-r--r-- | addressbook/gui/contact-list-editor/e-contact-list-editor.h | 3 |
2 files changed, 46 insertions, 21 deletions
diff --git a/addressbook/gui/contact-list-editor/e-contact-list-editor.c b/addressbook/gui/contact-list-editor/e-contact-list-editor.c index cc64cd5af3..77d91357c5 100644 --- a/addressbook/gui/contact-list-editor/e-contact-list-editor.c +++ b/addressbook/gui/contact-list-editor/e-contact-list-editor.c @@ -881,6 +881,36 @@ contact_list_editor_create_name_selector (gchar *name, gint int1, gint int2); +static gpointer +contact_editor_fudge_new (EBook *book, + EContact *contact, + gboolean is_new, + gboolean editable) +{ + EShell *shell = e_shell_get_default (); + + /* XXX Putting this function signature in libedataserverui + * was a terrible idea. Now we're stuck with it. */ + + return e_contact_editor_new ( + shell, book, contact, is_new, editable); +} + +static gpointer +contact_list_editor_fudge_new (EBook *book, + EContact *contact, + gboolean is_new, + gboolean editable) +{ + EShell *shell = e_shell_get_default (); + + /* XXX Putting this function signature in libedataserverui + * was a terrible idea. Now we're stuck with it. */ + + return e_contact_list_editor_new ( + shell, book, contact, is_new, editable); +} + GtkWidget * contact_list_editor_create_name_selector (gchar *name, gchar *string1, @@ -901,9 +931,9 @@ contact_list_editor_create_name_selector (gchar *name, name_selector, "Members"); e_name_selector_entry_set_contact_editor_func ( - name_selector_entry, e_contact_editor_new); + name_selector_entry, contact_editor_fudge_new); e_name_selector_entry_set_contact_list_editor_func ( - name_selector_entry, e_contact_list_editor_new); + name_selector_entry, contact_list_editor_fudge_new); gtk_widget_show (GTK_WIDGET (name_selector_entry)); g_signal_connect ( @@ -1319,26 +1349,20 @@ e_contact_list_editor_get_type (void) return type; } -static void -contact_list_editor_destroy_notify (gpointer data, - GObject *where_the_object_was) -{ - eab_editor_remove (EAB_EDITOR (data)); -} - -GtkWidget * -e_contact_list_editor_new (EBook *book, - EContact *list_contact, - gboolean is_new_list, - gboolean editable) +EABEditor * +e_contact_list_editor_new (EShell *shell, + EBook *book, + EContact *list_contact, + gboolean is_new_list, + gboolean editable) { - EContactListEditor *editor; + EABEditor *editor; - editor = g_object_new (E_TYPE_CONTACT_LIST_EDITOR, NULL); + g_return_val_if_fail (E_IS_SHELL (shell), NULL); - eab_editor_add (EAB_EDITOR (editor)); - g_object_weak_ref ( - G_OBJECT (editor), contact_list_editor_destroy_notify, editor); + editor = g_object_new ( + E_TYPE_CONTACT_LIST_EDITOR, + "shell", shell, NULL); g_object_set (editor, "book", book, @@ -1347,7 +1371,7 @@ e_contact_list_editor_new (EBook *book, "editable", editable, NULL); - return GTK_WIDGET (editor); + return editor; } EBook * diff --git a/addressbook/gui/contact-list-editor/e-contact-list-editor.h b/addressbook/gui/contact-list-editor/e-contact-list-editor.h index 5b67fe0126..8e258597aa 100644 --- a/addressbook/gui/contact-list-editor/e-contact-list-editor.h +++ b/addressbook/gui/contact-list-editor/e-contact-list-editor.h @@ -68,7 +68,8 @@ struct _EContactListEditorClass }; GType e_contact_list_editor_get_type (void); -GtkWidget * e_contact_list_editor_new (EBook *book, +EABEditor * e_contact_list_editor_new (EShell *shell, + EBook *book, EContact *list_contact, gboolean is_new_list, gboolean editable); |