* (add_to_address_book): now it supports receiving a full
address (form User <email@address>). If it gets it, it
searches in contacts for only email@address. If it's not
found, then it stores a contact with full name User and
email address email@address. Fixes NB#79467.
pmo-trunk-r4102
EBookQuery *query;
GList *contacts = NULL;
GError *err = NULL;
EBookQuery *query;
GList *contacts = NULL;
GError *err = NULL;
g_return_val_if_fail (address, FALSE);
g_return_val_if_fail (address, FALSE);
open_addressbook ();
g_return_val_if_fail (book, FALSE);
open_addressbook ();
g_return_val_if_fail (book, FALSE);
+
+ email = modest_text_utils_get_email_address (address);
- query = e_book_query_field_test (E_CONTACT_EMAIL, E_BOOK_QUERY_IS, address);
+ query = e_book_query_field_test (E_CONTACT_EMAIL, E_BOOK_QUERY_IS, email);
if (!e_book_get_contacts (book, query, &contacts, &err)) {
g_printerr ("modest: failed to get contacts: %s",
err ? err->message : "<unknown>");
if (!e_book_get_contacts (book, query, &contacts, &err)) {
g_printerr ("modest: failed to get contacts: %s",
err ? err->message : "<unknown>");
} else {
/* it's not yet in the addressbook, add it now! */
EContact *new_contact = e_contact_new ();
} else {
/* it's not yet in the addressbook, add it now! */
EContact *new_contact = e_contact_new ();
- e_contact_set (new_contact, E_CONTACT_EMAIL_1, (const gpointer)address);
+ gchar *display_address;
+ display_address = g_strdup (address);
+ if (display_address) {
+ modest_text_utils_get_display_address (display_address);
+ if ((display_address[0] != '\0') && (strlen (display_address) != strlen (address)))
+ e_contact_set (new_contact, E_CONTACT_FULL_NAME, (const gpointer)display_address);
+ }
+ e_contact_set (new_contact, E_CONTACT_EMAIL_1, (const gpointer)email);
+ g_free (display_address);
commit_contact (new_contact, TRUE);
g_debug ("%s added to address book", address);
g_object_unref (new_contact);
}
commit_contact (new_contact, TRUE);
g_debug ("%s added to address book", address);
g_object_unref (new_contact);
}