diff options
-rw-r--r-- | filter/ChangeLog | 18 | ||||
-rw-r--r-- | filter/filter-context.c | 86 | ||||
-rw-r--r-- | filter/filter-folder.c | 9 | ||||
-rw-r--r-- | filter/filter-folder.h | 1 | ||||
-rw-r--r-- | filter/rule-context.c | 32 | ||||
-rw-r--r-- | filter/rule-context.h | 7 | ||||
-rw-r--r-- | filter/rule-editor.c | 15 |
7 files changed, 160 insertions, 8 deletions
diff --git a/filter/ChangeLog b/filter/ChangeLog index 1e94dae79d..f0b4698be3 100644 --- a/filter/ChangeLog +++ b/filter/ChangeLog @@ -1,5 +1,22 @@ 2001-10-28 <NotZed@Ximian.com> + * filter-context.c (filter_rename_uri): Implement, change any + folder uri's that have been renamed, to the new one. + (filter_delete_uri): Dont actually do any work (yet). + + We could probably put rename_uri on every rule context/filter + part/filter element, and let their methods handle it, but for now + its easy enough just to handle the few cases that we have to + handle manually. + + * rule-context.c (rule_context_delete_uri): Update a filter + context for a deleted uri, e.g. folder removed. + (rule_context_rename_uri): Update a filter context for a renamed + uri, e.g. + + * filter-folder.c (filter_folder_set_value): New function to set + the uri of a folder filter. + * rule-editor.c (rule_move): Add undo for move. (rule_editor_add_undo): Add extra rank item. (rule_editor_play_undo): handle rank case. @@ -8,6 +25,7 @@ EVOLUTION_RULE_UNDO enabled. Code still a bit flakey. (rule_editor_construct): Only enable a cancel button if EVOLUTION_RULE_UNDO is set. + (rule_editor_add_undo): Only add if undo enabled. * filter-rule.c (filter_rule_set_name): Emit a changed event if it changes. diff --git a/filter/filter-context.c b/filter/filter-context.c index 3ec682fc07..aa3b36a5ee 100644 --- a/filter/filter-context.c +++ b/filter/filter-context.c @@ -22,18 +22,26 @@ #include <config.h> #endif +#include <string.h> + #include <gtk/gtktypeutils.h> #include <gtk/gtkobject.h> #include "filter-context.h" #include "filter-filter.h" +/* For poking into filter-folder guts */ +#include "filter-folder.h" + #define d(x) static void filter_context_class_init (FilterContextClass *class); static void filter_context_init (FilterContext *gspaper); static void filter_context_finalise (GtkObject *obj); +static int filter_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp); +static int filter_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp); + #define _PRIVATE(x) (((FilterContext *)(x))->priv) struct _FilterContextPrivate { @@ -73,12 +81,16 @@ static void filter_context_class_init (FilterContextClass *class) { GtkObjectClass *object_class; - + RuleContextClass *rule_class = (RuleContextClass *)class; + object_class = (GtkObjectClass *)class; parent_class = gtk_type_class(rule_context_get_type ()); object_class->finalize = filter_context_finalise; + /* override methods */ + rule_class->rename_uri = filter_rename_uri; + rule_class->delete_uri = filter_delete_uri; /* signals */ @@ -151,3 +163,75 @@ FilterPart *filter_context_next_action(FilterContext *f, FilterPart *last) { return filter_part_next_list(f->actions, last); } + +/* We search for any folders in our actions list that need updating, update them */ +static int filter_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp) +{ + FilterRule *rule; + GList *l, *el; + FilterPart *action; + FilterElement *element; + const char *name; + int count = 0; + + name = strrchr(newuri, '/'); + if (name) + name++; + else + name = newuri; + + d(printf("uri '%s' renamed to '%s'\n", olduri, newuri)); + + /* For all rules, for all actions, for all elements, rename any folder elements */ + /* Yes we could do this inside each part itself, but not today */ + rule = NULL; + while ( (rule = rule_context_next_rule(f, rule, NULL)) ) { + int rulecount = 0; + + d(printf("checking rule '%s'\n", rule->name)); + + l = FILTER_FILTER(rule)->actions; + while (l) { + action = l->data; + + d(printf("checking action '%s'\n", action->name)); + + el = action->elements; + while (el) { + element = el->data; + + d(printf("checking element '%s'\n", element->name)); + if (IS_FILTER_FOLDER(element)) + d(printf(" is folder, existing uri = '%s'\n", FILTER_FOLDER(element)->uri)); + + if (IS_FILTER_FOLDER(element) + && cmp(((FilterFolder *)element)->uri, olduri)) { + d(printf(" Changed!\n")); + filter_folder_set_value((FilterFolder *)element, newuri, name); + rulecount++; + } + el = el->next; + } + l = l->next; + } + + if (rulecount) + filter_rule_emit_changed(rule); + + count += rulecount; + } + + return count + parent_class->rename_uri(f, olduri, newuri, cmp); +} + +static int filter_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp) +{ + /* We basically should do similar to above, but when we find it, + Remove the action, and if thats the last action, remove the rule? */ + + /* But i'm not confident the rest of the mailer wont accidentlly delete + something which was just temporarily not available. */ + + return parent_class->delete_uri(f, uri, cmp); +} + diff --git a/filter/filter-folder.c b/filter/filter-folder.c index 5caac7fb62..177e0996e4 100644 --- a/filter/filter-folder.c +++ b/filter/filter-folder.c @@ -134,6 +134,15 @@ filter_folder_new (void) return o; } +void +filter_folder_set_value(FilterFolder *ff, const char *uri, const char *name) +{ + g_free(ff->uri); + ff->uri = g_strdup(uri); + g_free(ff->name); + ff->name = g_strdup(name); +} + static gboolean validate (FilterElement *fe) { diff --git a/filter/filter-folder.h b/filter/filter-folder.h index 4e77d96fc5..e58444fb14 100644 --- a/filter/filter-folder.h +++ b/filter/filter-folder.h @@ -50,6 +50,7 @@ guint filter_folder_get_type (void); FilterFolder *filter_folder_new (void); /* methods */ +void filter_folder_set_value(FilterFolder *ff, const char *uri, const char *name); #endif /* ! _FILTER_FOLDER_H */ diff --git a/filter/rule-context.c b/filter/rule-context.c index ce83abc662..d11e4ec722 100644 --- a/filter/rule-context.c +++ b/filter/rule-context.c @@ -38,6 +38,8 @@ static int load(RuleContext * f, const char *system, const char *user); static int save(RuleContext * f, const char *user); +static int rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp); +static int delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp); static void rule_context_class_init(RuleContextClass * class); static void rule_context_init(RuleContext * gspaper); @@ -95,7 +97,9 @@ rule_context_class_init (RuleContextClass * class) /* override methods */ class->load = load; class->save = save; - + class->rename_uri = rename_uri; + class->delete_uri = delete_uri; + /* signals */ signals[RULE_ADDED] = gtk_signal_new("rule_added", @@ -647,3 +651,29 @@ rule_context_find_rank_rule (RuleContext *f, int rank, const char *source) return NULL; } + +static int +delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp) +{ + return 0; +} + +int +rule_context_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp) +{ + return ((RuleContextClass *) ((GtkObject *) f)->klass)->delete_uri(f, uri, cmp); +} + +static int +rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp) +{ + return 0; +} + +int +rule_context_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp) +{ + return ((RuleContextClass *) ((GtkObject *) f)->klass)->rename_uri (f, olduri, newuri, cmp); +} + + diff --git a/filter/rule-context.h b/filter/rule-context.h index 05c6ccfcf4..982129b216 100644 --- a/filter/rule-context.h +++ b/filter/rule-context.h @@ -61,6 +61,9 @@ struct _RuleContextClass { int (*load)(RuleContext *f, const char *system, const char *user); int (*save)(RuleContext *f, const char *user); + int (*delete_uri)(RuleContext *f, const char *uri, GCompareFunc cmp); + int (*rename_uri)(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp); + /* signals */ void (*rule_added)(RuleContext *f, FilterRule *rule); void (*rule_removed)(RuleContext *f, FilterRule *rule); @@ -113,5 +116,9 @@ int rule_context_get_rank_rule(RuleContext *f, FilterRule *rule, const char *so void rule_context_add_part_set(RuleContext *f, const char *setname, int part_type, RCPartFunc append, RCNextPartFunc next); void rule_context_add_rule_set(RuleContext *f, const char *setname, int rule_type, RCRuleFunc append, RCNextRuleFunc next); +/* uri's disappear/renamed externally */ +int rule_context_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp); +int rule_context_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp); + #endif /* ! _RULE_CONTEXT_H */ diff --git a/filter/rule-editor.c b/filter/rule-editor.c index 0fdd845dd9..63986e6f2d 100644 --- a/filter/rule-editor.c +++ b/filter/rule-editor.c @@ -36,6 +36,8 @@ /* for getenv only, remove when getenv need removed */ #include <stdlib.h> +static int enable_undo; + void rule_editor_add_undo(RuleEditor *re, int type, FilterRule *rule, int rank, int newrank); void rule_editor_play_undo(RuleEditor *re); @@ -88,7 +90,10 @@ rule_editor_get_type(void) (GtkArgSetFunc) NULL, (GtkArgGetFunc) NULL }; - + + /* TODO: Remove when it works (or never will) */ + enable_undo = getenv("EVOLUTION_RULE_UNDO") != NULL; + type = gtk_type_unique (gnome_dialog_get_type (), &type_info); } @@ -514,9 +519,7 @@ rule_editor_add_undo(RuleEditor *re, int type, FilterRule *rule, int rank, int n { RuleEditorUndo *undo; - printf("Adding udno record: %d object %p '%s'\n", type, rule, rule->name); - - if (!re->undo_active) { + if (!re->undo_active && !enable_undo) { undo = g_malloc0(sizeof(*undo)); undo->rule = rule; undo->type = type; @@ -581,7 +584,7 @@ static void editor_clicked (GtkWidget *dialog, int button, RuleEditor *re) { if (button != 0) { - if (getenv("EVOLUTION_RULE_UNDO")) + if (enable_undo) rule_editor_play_undo(re); else { RuleEditorUndo *undo, *next; @@ -624,7 +627,7 @@ rule_editor_construct (RuleEditor *re, RuleContext *context, GladeXML *gui, cons gtk_signal_connect (GTK_OBJECT (re), "clicked", editor_clicked, re); rule_editor_set_source (re, source); - if (getenv("EVOLUTION_RULE_UNDO")) { + if (enable_undo) { gnome_dialog_append_buttons (GNOME_DIALOG (re), GNOME_STOCK_BUTTON_OK, GNOME_STOCK_BUTTON_CANCEL, NULL); } else |