aboutsummaryrefslogtreecommitdiffstats
path: root/addressbook/conduit
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2004-04-24 06:29:05 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2004-04-24 06:29:05 +0800
commit80c119231387cb3745117b0df792f2e39e0ffcad (patch)
treef334c7c6025c2d6a8f37a934e92f4b329c9d61be /addressbook/conduit
parent34e13572841c231de83ac0d6e0a4ee16486ec476 (diff)
downloadgsoc2013-evolution-80c119231387cb3745117b0df792f2e39e0ffcad.tar.gz
gsoc2013-evolution-80c119231387cb3745117b0df792f2e39e0ffcad.tar.zst
gsoc2013-evolution-80c119231387cb3745117b0df792f2e39e0ffcad.zip
The firt EMAIL item is EMAIL_1, not EMAIL (assuming we want simple
2004-04-23 Jeffrey Stedfast <fejj@ximian.com> * conduit/address-conduit.c (get_next_mail): The firt EMAIL item is EMAIL_1, not EMAIL (assuming we want simple strings). (local_record_from_ecard): Use e_contact_get() for getting the EContactAddress. Loop from FIRST_ADDRESS_ID up to and *including* LAST_ADDRESS_ID. (ecard_from_remote_record): When searching for an address field, loop from FIRST_ADDRESS_ID up to and *including* LAST_ADDRESS_ID. (pre_sync): Use e_book_query_any_field_contains() rather than e_book_query_from_string ("#t") which doesn't work anyway. 2004-04-20 Jeffrey Stedfast <fejj@ximian.com> * conduit/address-conduit.c (map_name): Updated to use ~/.evolution as the evolution directory rather than ~/evolution. svn path=/trunk/; revision=25603
Diffstat (limited to 'addressbook/conduit')
-rw-r--r--addressbook/conduit/address-conduit.c81
1 files changed, 43 insertions, 38 deletions
diff --git a/addressbook/conduit/address-conduit.c b/addressbook/conduit/address-conduit.c
index 5d6530fd85..01a22c690e 100644
--- a/addressbook/conduit/address-conduit.c
+++ b/addressbook/conduit/address-conduit.c
@@ -73,7 +73,7 @@ static EContactField priority [] = {
E_CONTACT_PHONE_BUSINESS,
E_CONTACT_PHONE_HOME,
E_CONTACT_PHONE_BUSINESS_FAX,
- E_CONTACT_EMAIL,
+ E_CONTACT_EMAIL_1,
E_CONTACT_PHONE_PAGER,
E_CONTACT_PHONE_MOBILE,
E_CONTACT_PHONE_BUSINESS_2,
@@ -462,8 +462,8 @@ map_name (EAddrConduitContext *ctxt)
{
char *filename = NULL;
- filename = g_strdup_printf ("%s/evolution/local/Contacts/pilot-map-%d.xml", g_get_home_dir (), ctxt->cfg->pilot_id);
-
+ filename = g_strdup_printf ("%s/.evolution/addressbook/local/system/pilot-map-%d.xml", g_get_home_dir (), ctxt->cfg->pilot_id);
+
return filename;
}
@@ -487,14 +487,15 @@ static EContactField
get_next_mail (EContactField *field)
{
if (field == NULL)
- return E_CONTACT_EMAIL;
+ return E_CONTACT_EMAIL_1;
switch (*field) {
- case E_CONTACT_EMAIL:
+ case E_CONTACT_EMAIL_1:
return E_CONTACT_EMAIL_2;
case E_CONTACT_EMAIL_2:
return E_CONTACT_EMAIL_3;
default:
+ break;
}
return E_CONTACT_FIELD_LAST;
@@ -510,6 +511,7 @@ get_next_home (EContactField *field)
case E_CONTACT_PHONE_HOME:
return E_CONTACT_PHONE_HOME_2;
default:
+ break;
}
return E_CONTACT_FIELD_LAST;
@@ -525,6 +527,7 @@ get_next_work (EContactField *field)
case E_CONTACT_PHONE_BUSINESS:
return E_CONTACT_PHONE_BUSINESS_2;
default:
+ break;
}
return E_CONTACT_FIELD_LAST;
@@ -542,6 +545,7 @@ get_next_fax (EContactField *field)
case E_CONTACT_PHONE_HOME_FAX:
return E_CONTACT_PHONE_OTHER_FAX;
default:
+ break;
}
return E_CONTACT_FIELD_LAST;
@@ -781,10 +785,9 @@ local_record_to_pilot_record (EAddrLocalRecord *local,
static void
local_record_from_ecard (EAddrLocalRecord *local, EContact *contact, EAddrConduitContext *ctxt)
{
- const EContactAddress *address;
- EContactField mailing_address;
+ EContactAddress *address = NULL;
int phone = entryPhone1;
-
+ EContactField field;
gboolean syncable;
int i;
@@ -835,25 +838,16 @@ local_record_from_ecard (EAddrLocalRecord *local, EContact *contact, EAddrCondui
local->addr->entry[entryTitle] = e_pilot_utf8_to_pchar (e_contact_get_const (contact, E_CONTACT_TITLE));
/* See if the default has something in it */
- mailing_address = -1;
- if (e_contact_get_const (contact, ctxt->cfg->default_address))
- mailing_address = ctxt->cfg->default_address;
-
- /* If it doesn't, look for any address */
- if (mailing_address == -1) {
- for (i = E_CONTACT_FIRST_LABEL_ID; i < E_CONTACT_LAST_LABEL_ID; i++) {
- if (e_contact_get_const (contact, i)) {
- mailing_address = i;
+ if ((address = e_contact_get (contact, ctxt->cfg->default_address))) {
+ field = ctxt->cfg->default_address;
+ } else {
+ /* Try to find a non-empty address field */
+ for (field = E_CONTACT_FIRST_ADDRESS_ID; field <= E_CONTACT_LAST_ADDRESS_ID; field++) {
+ if ((address = e_contact_get (contact, field)))
break;
- }
}
}
- /* If all else fails, use the default */
- if (mailing_address == -1)
- mailing_address = ctxt->cfg->default_address;
-
- address = e_contact_get_const (contact, mailing_address);
if (address) {
char *add;
@@ -869,8 +863,10 @@ local_record_from_ecard (EAddrLocalRecord *local, EContact *contact, EAddrCondui
local->addr->entry[entryState] = e_pilot_utf8_to_pchar (address->region);
local->addr->entry[entryZip] = e_pilot_utf8_to_pchar (address->code);
local->addr->entry[entryCountry] = e_pilot_utf8_to_pchar (address->country);
+
+ e_contact_address_free (address);
}
-
+
/* Phone numbers */
/* See if everything is syncable */
@@ -893,7 +889,7 @@ local_record_from_ecard (EAddrLocalRecord *local, EContact *contact, EAddrCondui
}
}
for ( ; phone <= entryPhone5; phone++)
- local->addr->phoneLabel[phone - entryPhone1] = phone - entryPhone1;
+ local->addr->phoneLabel[phone - entryPhone1] = phone - entryPhone1;
local->addr->showPhone = 0;
} else {
EContactField next_mail, next_home, next_work, next_fax;
@@ -1017,13 +1013,14 @@ ecard_from_remote_record(EAddrConduitContext *ctxt,
/* Address */
mailing_address = -1;
- if (e_contact_get_const (contact, ctxt->cfg->default_address))
+ if ((eaddress = e_contact_get (contact, ctxt->cfg->default_address))) {
mailing_address = ctxt->cfg->default_address;
-
- if (mailing_address == -1) {
- for (i = E_CONTACT_FIRST_LABEL_ID; i < E_CONTACT_LAST_LABEL_ID; i++) {
- if (e_contact_get_const (contact, i)) {
- mailing_address = i;
+ e_contact_address_free (eaddress);
+ } else {
+ for (i = E_CONTACT_FIRST_ADDRESS_ID; i <= E_CONTACT_LAST_ADDRESS_ID; i++) {
+ if ((eaddress = e_contact_get (contact, i))) {
+ e_contact_address_free (eaddress);
+ mailing_address = i;
break;
}
}
@@ -1031,14 +1028,17 @@ ecard_from_remote_record(EAddrConduitContext *ctxt,
if (mailing_address == -1)
mailing_address = ctxt->cfg->default_address;
-
+
eaddress = g_new0 (EContactAddress, 1);
txt = get_entry_text (address, entryAddress);
- if ((find = strchr (txt, '\n')) != NULL) {
+ if (txt && (find = strchr (txt, '\n')) != NULL) {
*find = '\0';
find++;
- }
+ } else {
+ find = NULL;
+ }
+
eaddress->street = txt;
eaddress->ext = find != NULL ? g_strdup (find) : g_strdup ("");
eaddress->locality = get_entry_text (address, entryCity);
@@ -1159,13 +1159,18 @@ pre_sync (GnomePilotConduit *conduit,
g_free (filename);
/* Get a list of all contacts */
- query = e_book_query_from_string ("#t");
+ if (!(query = e_book_query_any_field_contains (""))) {
+ LOG (g_warning ("Failed to get EBookQuery"));
+ return -1;
+ }
+
if (!e_book_get_contacts (ctxt->ebook, query, &ctxt->cards, NULL)) {
- g_object_unref (query);
-
+ LOG (g_warning ("Failed to get Contacts"));
+ e_book_query_unref (query);
return -1;
}
- g_object_unref (query);
+
+ e_book_query_unref (query);
/* Count and hash the changes */
change_id = g_strdup_printf ("pilot-sync-evolution-addressbook-%d", ctxt->cfg->pilot_id);