aboutsummaryrefslogtreecommitdiffstats
path: root/addressbook/backend
diff options
context:
space:
mode:
Diffstat (limited to 'addressbook/backend')
-rw-r--r--addressbook/backend/ebook/e-card.c109
1 files changed, 100 insertions, 9 deletions
diff --git a/addressbook/backend/ebook/e-card.c b/addressbook/backend/ebook/e-card.c
index 216971c650..38116891b5 100644
--- a/addressbook/backend/ebook/e-card.c
+++ b/addressbook/backend/ebook/e-card.c
@@ -383,13 +383,96 @@ static VObject *
addPropValueUTF8(VObject *o, const char *p, const char *v)
{
VObject *prop = addPropValue (o, p, v);
- if (!e_utf8_is_ascii (v))
- addPropValue (prop, "CHARSET", "UTF-8");
+ for (; *v; v++) {
+ if ((*v) & 0x80) {
+ addPropValue (prop, "CHARSET", "UTF-8");
+ for (; *v; v++) {
+ if (*v == '\n') {
+ addProp(prop, VCQuotedPrintableProp);
+ return prop;
+ }
+ }
+ return prop;
+ }
+ if (*v == '\n') {
+ addProp(prop, VCQuotedPrintableProp);
+ for (; *v; v++) {
+ if ((*v) & 0x80) {
+ addPropValue (prop, "CHARSET", "UTF-8");
+ return prop;
+ }
+ }
+ return prop;
+ }
+ }
return prop;
}
-#define ADD_PROP_VALUE(o, p, v) (assumeUTF8 ? (addPropValue ((o), (p), (v))) : addPropValueUTF8 ((o), (p), (v)))
-#define ADD_PROP_VALUE_SET_IS_ASCII(o, p, v) (addPropValue ((o), (p), (v)), is_ascii = is_ascii && e_utf8_is_ascii ((v)))
+static VObject *
+addPropValueQP(VObject *o, const char *p, const char *v)
+{
+ VObject *prop = addPropValue (o, p, v);
+ for (; *v; v++) {
+ if (*v == '\n') {
+ addProp(prop, VCQuotedPrintableProp);
+ break;
+ }
+ }
+ return prop;
+}
+
+static void
+addPropValueSets (VObject *o, char *p, char *v, gboolean assumeUTF8, gboolean *is_ascii, gboolean *has_return)
+{
+ addPropValue (o, p, v);
+ if (*has_return && (assumeUTF8 || !*is_ascii))
+ return;
+ if (*has_return) {
+ for (; *v; v++) {
+ if (*v & 0x80) {
+ *is_ascii = FALSE;
+ return;
+ }
+ }
+ return;
+ }
+ if (assumeUTF8 || !*is_ascii) {
+ for (; *v; v++) {
+ if (*v == '\n') {
+ *has_return = TRUE;
+ return;
+ }
+ }
+ return;
+ }
+ for (; *v; v++) {
+ if (*v & 0x80) {
+ *is_ascii = FALSE;
+ for (; *v; v++) {
+ if (*v == '\n') {
+ *has_return = TRUE;
+ return;
+ }
+ }
+ return;
+ }
+ if (*v == '\n') {
+ *has_return = TRUE;
+ for (; *v; v++) {
+ if (*v & 0x80) {
+ *is_ascii = FALSE;
+ return;
+ }
+ }
+ return;
+ }
+ }
+ return;
+}
+
+#define ADD_PROP_VALUE(o, p, v) (assumeUTF8 ? (addPropValueQP ((o), (p), (v))) : addPropValueUTF8 ((o), (p), (v)))
+#define ADD_PROP_VALUE_SET_IS_ASCII(o, p, v) (addPropValueSets ((o), (p), (v), assumeUTF8, &is_ascii, &has_return))
+
static VObject *
e_card_get_vobject (ECard *card, gboolean assumeUTF8)
@@ -398,12 +481,12 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
vobj = newVObject (VCCardProp);
- if ( card->file_as && *card->file_as )
+ if (card->file_as && *card->file_as)
ADD_PROP_VALUE(vobj, "X-EVOLUTION-FILE-AS", card->file_as);
else if (card->file_as)
addProp(vobj, "X-EVOLUTION-FILE_AS");
- if ( card->fname )
+ if (card->fname && *card->fname)
ADD_PROP_VALUE(vobj, VCFullNameProp, card->fname);
else if (card->fname)
addProp(vobj, VCFullNameProp);
@@ -411,6 +494,7 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
if ( card->name && (card->name->prefix || card->name->given || card->name->additional || card->name->family || card->name->suffix) ) {
VObject *nameprop;
gboolean is_ascii = TRUE;
+ gboolean has_return = FALSE;
nameprop = addProp(vobj, VCNameProp);
if ( card->name->prefix )
ADD_PROP_VALUE_SET_IS_ASCII(nameprop, VCNamePrefixesProp, card->name->prefix);
@@ -422,6 +506,8 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
ADD_PROP_VALUE_SET_IS_ASCII(nameprop, VCFamilyNameProp, card->name->family);
if ( card->name->suffix )
ADD_PROP_VALUE_SET_IS_ASCII(nameprop, VCNameSuffixesProp, card->name->suffix);
+ if (has_return)
+ addProp(nameprop, VCQuotedPrintableProp);
if (!(is_ascii || assumeUTF8))
addPropValue (nameprop, "CHARSET", "UTF-8");
}
@@ -435,6 +521,7 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
VObject *addressprop;
ECardDeliveryAddress *address = (ECardDeliveryAddress *) e_iterator_get(iterator);
gboolean is_ascii = TRUE;
+ gboolean has_return = FALSE;
addressprop = addProp(vobj, VCAdrProp);
@@ -453,7 +540,9 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
ADD_PROP_VALUE_SET_IS_ASCII(addressprop, VCPostalCodeProp, address->code);
if ( address->country )
ADD_PROP_VALUE_SET_IS_ASCII(addressprop, VCCountryNameProp, address->country);
- addProp(addressprop, VCQuotedPrintableProp);
+
+ if (has_return)
+ addProp(addressprop, VCQuotedPrintableProp);
if (!(is_ascii || assumeUTF8))
addPropValue (addressprop, "CHARSET", "UTF-8");
}
@@ -471,7 +560,6 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
labelprop = addProp(vobj, VCDeliveryLabelProp);
set_address_flags (labelprop, address_label->flags);
- addProp(labelprop, VCQuotedPrintableProp);
}
gtk_object_unref(GTK_OBJECT(iterator));
}
@@ -511,12 +599,16 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
if (card->org || card->org_unit) {
VObject *orgprop;
gboolean is_ascii = TRUE;
+ gboolean has_return = FALSE;
orgprop = addProp(vobj, VCOrgProp);
if (card->org)
ADD_PROP_VALUE_SET_IS_ASCII(orgprop, VCOrgNameProp, card->org);
if (card->org_unit)
ADD_PROP_VALUE_SET_IS_ASCII(orgprop, VCOrgUnitProp, card->org_unit);
+
+ if (has_return)
+ addProp(orgprop, VCQuotedPrintableProp);
if (!(is_ascii || assumeUTF8))
addPropValue (orgprop, "CHARSET", "UTF-8");
}
@@ -563,7 +655,6 @@ e_card_get_vobject (ECard *card, gboolean assumeUTF8)
VObject *noteprop;
noteprop = ADD_PROP_VALUE(vobj, VCNoteProp, card->note);
- addProp(noteprop, VCQuotedPrintableProp);
}
if (card->last_use) {