aboutsummaryrefslogtreecommitdiffstats
path: root/mail/importers
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2004-05-07 13:22:25 +0800
committerMichael Zucci <zucchi@src.gnome.org>2004-05-07 13:22:25 +0800
commit3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6 (patch)
treea73cf4f16fb7201a9e94852a65be75cfe375f9fb /mail/importers
parent48ad64875b482b16f35de414f51b37533ca506bb (diff)
downloadgsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar.gz
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar.bz2
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar.lz
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar.xz
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.tar.zst
gsoc2013-evolution-3fcf0b4edc4e1a95ceae5693bd7a65690c3251f6.zip
** Dunno why i bothered, but see bug #58090.
2004-05-07 Not Zed <NotZed@Ximian.com> ** Dunno why i bothered, but see bug #58090. * importers/netscape-importer.c (netscape_filter_parse_conditions): check for custom headers properly. (netscape_filter_flatfile_get_entry): put in some validate checks. (netscape_filter_to_evol_filter): implement custom headers properly. (ns_filter_condition_types): add missing "status" string. svn path=/trunk/; revision=25820
Diffstat (limited to 'mail/importers')
-rw-r--r--mail/importers/netscape-importer.c42
1 files changed, 36 insertions, 6 deletions
diff --git a/mail/importers/netscape-importer.c b/mail/importers/netscape-importer.c
index 5b0e400857..8389e5c5e0 100644
--- a/mail/importers/netscape-importer.c
+++ b/mail/importers/netscape-importer.c
@@ -146,7 +146,7 @@ typedef enum {
static char *ns_filter_condition_types[] =
{
"from", "subject", "to", "CC", "to or CC", "body", "date",
- "priority", "age in days"
+ "status", "priority", "age in days"
};
@@ -171,6 +171,7 @@ typedef struct
NsFilterConditionPropertyType prop;
NsFilterActionValueType prop_val_id; /* for dealing with priority levels */
char *prop_val_str;
+ char *type_str;
} NsFilterCondition;
typedef struct {
@@ -200,15 +201,22 @@ netscape_filter_flatfile_get_entry (FILE *f, char *key, char *val)
char *ptr = NULL;
char *ptr2 = NULL;
+ /* This is fugly awful code */
if (fgets (line, MAXLEN, f)) {
ptr = strchr(line, '=');
+ if (ptr == NULL)
+ goto fail;
*ptr = '\0';
memcpy (key, line, strlen(line)+1);
+ if (ptr[1] == 0)
+ goto fail;
ptr += 2; /* Skip '=' and '"' */
ptr2 = strrchr (ptr, '"');
+ if (ptr2 == NULL)
+ goto fail;
*ptr2 = '\0';
memcpy (val, ptr, strlen(ptr)+1);
@@ -217,7 +225,7 @@ netscape_filter_flatfile_get_entry (FILE *f, char *key, char *val)
return TRUE;
}
-
+fail:
*key = '\0'; *val = '\0';
return FALSE;
}
@@ -284,7 +292,11 @@ netscape_filter_parse_conditions (NsFilter *nsf, FILE *f, char *condition)
cond = g_new0 (NsFilterCondition, 1);
- if (!strcmp (type, ns_filter_condition_types[FROM])) {
+ if (type[0] == '\\' && type[1] == '\"' && (ptr=strstr(type+2, "\\\""))) {
+ *ptr = 0;
+ cond->type_str = g_strdup(type+2);
+ cond->type = X_MSG_HEADER;
+ } else if (!strcmp (type, ns_filter_condition_types[FROM])) {
cond->type = FROM;
} else if (!strcmp (type, ns_filter_condition_types[SUBJECT])) {
cond->type = SUBJECT;
@@ -304,8 +316,6 @@ netscape_filter_parse_conditions (NsFilter *nsf, FILE *f, char *condition)
cond->type = STATUS;
} else if (!strcmp (type, ns_filter_condition_types[AGE_IN_DAYS])) {
cond->type = AGE_IN_DAYS;
- } else if (!strcmp (type, ns_filter_condition_types[X_MSG_HEADER])) {
- cond->type = X_MSG_HEADER;
} else {
d(g_warning ("Unknown condition type '%s' encountered -- skipping.", type));
g_free (cond);
@@ -526,6 +536,7 @@ netscape_filter_cleanup (NsFilter *nsf)
NsFilterCondition *cond = (NsFilterCondition *)l->data;
g_free (cond->prop_val_str);
+ g_free(cond->type_str);
g_free (cond);
}
@@ -1061,8 +1072,27 @@ netscape_filter_to_evol_filter (FilterContext *fc, NsFilter *nsf, gboolean *prio
filter_rule_add_part (fr, fp);
el = filter_part_find_element (fp, "header-field");
filter_input_set_value ((FilterInput *)el, cond->prop_val_str);
+ el = filter_part_find_element (fp, "word");
+ filter_input_set_value ((FilterInput *)el, cond->type_str);
el = filter_part_find_element (fp, "header-type");
- filter_option_set_current ((FilterOption*)el, "exists");
+ switch (cond->prop) {
+ case CONTAINS:
+ filter_option_set_current ((FilterOption*)el, "contains");
+ break;
+ case CONTAINS_NOT:
+ filter_option_set_current ((FilterOption*)el, "not contains");
+ break;
+ case IS:
+ filter_option_set_current ((FilterOption*)el, "is");
+ break;
+ case IS_NOT:
+ filter_option_set_current ((FilterOption*)el, "is not");
+ break;
+ default:
+ filter_rule_remove_part (fr, fp);
+ g_object_unref((fp));
+ continue;
+ }
part_added = TRUE;
break;
default: