[evolution-ews/gnome-3-30] I#32 - Run ResolveNames for "Any field contains" searches



commit 9fb7e95b698b0a907f16c355c8e0638646723171
Author: Milan Crha <mcrha redhat com>
Date:   Mon Jan 21 12:59:24 2019 +0100

    I#32 - Run ResolveNames for "Any field contains" searches
    
    Closes https://gitlab.gnome.org/GNOME/evolution-ews/issues/32

 src/addressbook/e-book-backend-ews.c | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
---
diff --git a/src/addressbook/e-book-backend-ews.c b/src/addressbook/e-book-backend-ews.c
index 724dc73c..52d11b4e 100644
--- a/src/addressbook/e-book-backend-ews.c
+++ b/src/addressbook/e-book-backend-ews.c
@@ -941,7 +941,7 @@ convert_indexed_contact_property_to_updatexml (ESoapMessage *message,
 {
        gboolean delete_field = FALSE;
 
-       if (!value || g_strcmp0 (value, "") == 0)
+       if (!value || !*value)
                delete_field = TRUE;
        e_ews_message_start_set_indexed_item_field (message, name , prefix, "Contact", key, delete_field);
 
@@ -1295,7 +1295,7 @@ convert_indexed_contact_property_to_updatexml_physical_address (ESoapMessage *me
        gchar * fielduri = NULL;
        gboolean delete_field = FALSE;
 
-       if (!value || g_strcmp0 (value, "") == 0)
+       if (!value || !*value)
                delete_field = TRUE;
 
        fielduri = g_strconcat (name, ":", uri_element, NULL);
@@ -2718,7 +2718,8 @@ ebb_ews_func_contains (struct _ESExp *f,
        propname = argv[0]->value.string;
        str = argv[1]->value.string;
 
-       if (!strcmp (propname, "full_name") || !strcmp (propname, "email")) {
+       if (!g_ascii_strcasecmp (propname, "full_name") || !g_ascii_strcasecmp (propname, "email") ||
+           (str && *str && !g_ascii_strcasecmp (propname, "x-evolution-any-field"))) {
                if (!sdata->auto_comp_str) {
                        sdata->auto_comp_str = g_strdup (str);
                        sdata->is_autocompletion = TRUE;
@@ -2754,7 +2755,8 @@ ebb_ews_func_beginswith (struct _ESExp *f,
        propname = argv[0]->value.string;
        str = argv[1]->value.string;
 
-       if (!strcmp (propname, "full_name") || !strcmp (propname, "email")) {
+       if (!g_ascii_strcasecmp (propname, "full_name") || !g_ascii_strcasecmp (propname, "email") ||
+           (str && *str && !g_ascii_strcasecmp (propname, "x-evolution-any-field"))) {
                if (!sdata->auto_comp_str) {
                        sdata->auto_comp_str = g_strdup (str);
                        sdata->is_autocompletion = TRUE;


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]