diff options
author | Sushma Rai <rsushma@src.gnome.org> | 2005-09-28 21:25:12 +0800 |
---|---|---|
committer | Sushma Rai <rsushma@src.gnome.org> | 2005-09-28 21:25:12 +0800 |
commit | ebef4e5ed565ae236aed1e644bd62fb475e928f8 (patch) | |
tree | aca5df485c16abd1ca0b090b8825a771ee79480f /addressbook | |
parent | aab7424773357dbe7f60ba18754fa1763b7ee993 (diff) | |
download | gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar.gz gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar.bz2 gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar.lz gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar.xz gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.tar.zst gsoc2013-evolution-ebef4e5ed565ae236aed1e644bd62fb475e928f8.zip |
Fix for the crash when adding duplicate contacts without e-mail ids by
dragging them into contact list editor.
Patch submitted by "Devashish <sdevashish@novell.com>"
svn path=/trunk/; revision=30411
Diffstat (limited to 'addressbook')
-rw-r--r-- | addressbook/ChangeLog | 15 | ||||
-rw-r--r-- | addressbook/gui/contact-list-editor/e-contact-list-editor.c | 16 | ||||
-rw-r--r-- | addressbook/gui/widgets/eab-contact-display.c | 9 |
3 files changed, 30 insertions, 10 deletions
diff --git a/addressbook/ChangeLog b/addressbook/ChangeLog index eb8f359dca..b2a6c7b17d 100644 --- a/addressbook/ChangeLog +++ b/addressbook/ChangeLog @@ -1,6 +1,19 @@ 2005-09-28 Devashish Sharma <sdevashish@novell.com> - gui/component/addressbook-view.c (addressbook_view_init): Added a + * gui/contact-list-editor/e-contact-list-editor.c + (table_drag_data_received_cb): Added a check that the contact received + through drag contains an email-id. There is no point in adding a + contact to the contact-list if the contact has no email-id. This was + causing a crash also. + + * gui/widgets/eab-contact-display.c + (eab_contact_display_render_compact): Added a check for catching null + email-ids, in case of contact-lists, so that null ids are not passed + for rendering, which was causing a crash. + +2005-09-28 Devashish Sharma <sdevashish@novell.com> + + * gui/component/addressbook-view.c (addressbook_view_init): Added a callback, source_selector_key_press_event_callback() so that the contact folder can be removed with Del/Delete Key. Fixes #233424. 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 040dbb6b9a..f141f005d9 100644 --- a/addressbook/gui/contact-list-editor/e-contact-list-editor.c +++ b/addressbook/gui/contact-list-editor/e-contact-list-editor.c @@ -960,12 +960,16 @@ table_drag_data_received_cb (ETable *table, int row, int col, for (c = contact_list; c; c = c->next) { EContact *contact = c->data; - if (!e_contact_get (contact, E_CONTACT_IS_LIST)) { - e_contact_list_model_add_contact (E_CONTACT_LIST_MODEL (editor->model), - contact, - 0 /* Hard-wired for default e-mail */); - - changed = TRUE; + if (!e_contact_get (contact, E_CONTACT_IS_LIST)) { + if (e_contact_get (contact, E_CONTACT_EMAIL)) { + e_contact_list_model_add_contact (E_CONTACT_LIST_MODEL (editor->model), + contact, + 0 /* Hard-wired for default e-mail */); + + changed = TRUE; + } + else + g_warning ("Contact with no email-ids listed can't be added to a Contact-List"); } } g_list_foreach (contact_list, (GFunc)g_object_unref, NULL); diff --git a/addressbook/gui/widgets/eab-contact-display.c b/addressbook/gui/widgets/eab-contact-display.c index a925ce72d6..48725d6fcc 100644 --- a/addressbook/gui/widgets/eab-contact-display.c +++ b/addressbook/gui/widgets/eab-contact-display.c @@ -545,10 +545,13 @@ eab_contact_display_render_compact (EABContactDisplay *display, EContact *contac gtk_html_stream_printf (html_stream, "<b>%s:</b> <td>", _("List Members")); email_list = e_contact_get (contact, E_CONTACT_EMAIL); + for (l = email_list; l; l = l->next) { - char *html = e_text_to_html (l->data, 0); - gtk_html_stream_printf (html_stream, "%s, ", html); - g_free (html); + if (l->data) { + char *html = e_text_to_html (l->data, 0); + gtk_html_stream_printf (html_stream, "%s, ", html); + g_free (html); + } } gtk_html_stream_printf (html_stream, "</td></tr></table>"); } |