#include "addr_compl.h"
#include "colorlabel.h"
+#include "matcher_parser.h"
+#include "matcher.h"
+
static struct Filtering {
GtkWidget *window;
/* widget creating functions */
static void prefs_filtering_create (void);
-static void prefs_filtering_set_dialog (void);
+static void prefs_filtering_set_dialog (const gchar *header,
+ const gchar *key);
static void prefs_filtering_set_list (void);
/* callback functions */
gpointer user_data);
static void prefs_filtering_reset_dialog(void);
+static gboolean prefs_filtering_rename_path_func(GNode *node, gpointer data);
+static gboolean prefs_filtering_delete_path_func(GNode *node, gpointer data);
+
+static FolderItem * cur_item = NULL;
enum {
ACTION_MOVE = 0,
ACTION_MARK_AS_UNREAD = 6,
ACTION_FORWARD = 7,
ACTION_FORWARD_AS_ATTACHMENT = 8,
- ACTION_EXECUTE = 9,
- ACTION_COLOR = 10
+ ACTION_REDIRECT = 9,
+ ACTION_EXECUTE = 10,
+ ACTION_COLOR = 11,
+ ACTION_DELETE_ON_SERVER = 12,
};
static gint get_sel_from_list(GtkList * list)
{
switch(action_id) {
case ACTION_MOVE:
- return MATCHING_ACTION_MOVE;
+ return MATCHACTION_MOVE;
case ACTION_COPY:
- return MATCHING_ACTION_COPY;
+ return MATCHACTION_COPY;
case ACTION_DELETE:
- return MATCHING_ACTION_DELETE;
+ return MATCHACTION_DELETE;
case ACTION_MARK:
- return MATCHING_ACTION_MARK;
+ return MATCHACTION_MARK;
case ACTION_UNMARK:
- return MATCHING_ACTION_UNMARK;
+ return MATCHACTION_UNMARK;
case ACTION_MARK_AS_READ:
- return MATCHING_ACTION_MARK_AS_READ;
+ return MATCHACTION_MARK_AS_READ;
case ACTION_MARK_AS_UNREAD:
- return MATCHING_ACTION_MARK_AS_UNREAD;
+ return MATCHACTION_MARK_AS_UNREAD;
case ACTION_FORWARD:
- return MATCHING_ACTION_FORWARD;
+ return MATCHACTION_FORWARD;
case ACTION_FORWARD_AS_ATTACHMENT:
- return MATCHING_ACTION_FORWARD_AS_ATTACHMENT;
+ return MATCHACTION_FORWARD_AS_ATTACHMENT;
+ case ACTION_REDIRECT:
+ return MATCHACTION_REDIRECT;
case ACTION_EXECUTE:
- return MATCHING_EXECUTE;
+ return MATCHACTION_EXECUTE;
case ACTION_COLOR:
- return MATCHING_ACTION_COLOR;
+ return MATCHACTION_COLOR;
+ case ACTION_DELETE_ON_SERVER:
+ return MATCHACTION_DELETE_ON_SERVER;
default:
return -1;
}
N_("Mark as unread"),
N_("Forward"),
N_("Forward as attachment"),
+ N_("Redirect"),
N_("Execute"),
- N_("Color")
+ N_("Color"),
+ N_("Delete on Server")
};
-void prefs_filtering_open(void)
+void prefs_filtering_open(FolderItem * item,
+ const gchar *header,
+ const gchar *key)
{
+ gchar *esckey;
+
if (prefs_rc_is_readonly(FILTERING_RC))
return;
- inc_autocheck_timer_remove();
+ inc_lock();
if (!filtering.window) {
prefs_filtering_create();
manage_window_set_transient(GTK_WINDOW(filtering.window));
gtk_widget_grab_focus(filtering.ok_btn);
- prefs_filtering_set_dialog();
+ cur_item = item;
+
+ esckey = matcher_escape_str(key);
+ prefs_filtering_set_dialog(header, esckey);
+ g_free(esckey);
gtk_widget_show(filtering.window);
end_address_completion();
gtk_widget_hide(filtering.window);
+ inc_unlock();
}
static void prefs_filtering_create(void)
GtkWidget *up_btn;
GtkWidget *down_btn;
- GtkWidget *dummy;
GList *combo_items;
gint i;
GList *accounts;
GList * cur;
- gchar *title[] = {_("Registered rules")};
+ gchar *title[1];
- debug_print(_("Creating filtering setting window...\n"));
+ debug_print("Creating filtering setting window...\n");
window = gtk_window_new (GTK_WINDOW_DIALOG);
gtk_container_set_border_width (GTK_CONTAINER (window), 8);
GTK_SIGNAL_FUNC(prefs_filtering_deleted), NULL);
gtk_signal_connect (GTK_OBJECT(window), "key_press_event",
GTK_SIGNAL_FUNC(prefs_filtering_key_pressed), NULL);
- gtk_signal_connect (GTK_OBJECT(window), "focus_in_event",
- GTK_SIGNAL_FUNC(manage_window_focus_in), NULL);
- gtk_signal_connect (GTK_OBJECT(window), "focus_out_event",
- GTK_SIGNAL_FUNC(manage_window_focus_out), NULL);
+ MANAGE_WINDOW_SIGNALS_CONNECT (window);
gtk_signal_connect (GTK_OBJECT(ok_btn), "clicked",
GTK_SIGNAL_FUNC(prefs_filtering_ok), NULL);
gtk_signal_connect (GTK_OBJECT(cancel_btn), "clicked",
cond_entry = gtk_entry_new ();
gtk_widget_show (cond_entry);
-// gtk_widget_set_usize (cond_entry, 200, -1);
gtk_box_pack_start (GTK_BOX (hbox1), cond_entry, TRUE, TRUE, 0);
cond_btn = gtk_button_new_with_label (_("Define ..."));
action_combo = gtk_combo_new ();
gtk_widget_show (action_combo);
-// gtk_widget_set_usize (action_combo, 200, -1);
gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(action_combo)->entry),
FALSE);
dest_entry = gtk_entry_new ();
gtk_widget_show (dest_entry);
-// gtk_widget_set_usize (dest_entry, 200, -1);
gtk_box_pack_start (GTK_BOX (hbox1), dest_entry, TRUE, TRUE, 0);
color_optmenu = gtk_option_menu_new();
gtk_option_menu_set_menu(GTK_OPTION_MENU(color_optmenu),
colorlabel_create_color_menu());
-// gtk_widget_set_usize(color_optmenu, -1, -1);
gtk_box_pack_start(GTK_BOX(hbox1), color_optmenu, TRUE, TRUE, 0);
dest_btn = gtk_button_new_with_label (_("Select ..."));
GTK_SIGNAL_FUNC (prefs_matcher_exec_info),
NULL);
-// dummy = gtk_label_new("");
-// gtk_widget_show (dummy);
-// gtk_box_pack_start(GTK_BOX (hbox1), dummy, FALSE, FALSE, 0);
-
-
/* register / substitute / delete */
reg_hbox = gtk_hbox_new (FALSE, 4);
GTK_POLICY_AUTOMATIC,
GTK_POLICY_AUTOMATIC);
+ title[0] = _("Registered rules");
cond_clist = gtk_clist_new_with_titles(1, title);
gtk_widget_show (cond_clist);
gtk_container_add (GTK_CONTAINER (cond_scrolledwin), cond_clist);
gtk_clist_set_column_width(GTK_CLIST(filtering.cond_clist), 0, optwidth);
}
-static void prefs_filtering_set_dialog(void)
+void prefs_filtering_rename_path(const gchar *old_path, const gchar *new_path)
+{
+ GList * cur;
+ gchar *paths[2] = {NULL, NULL};
+ paths[0] = (gchar*)old_path;
+ paths[1] = (gchar*)new_path;
+ for (cur = folder_get_list() ; cur != NULL ; cur = g_list_next(cur)) {
+ Folder *folder;
+ folder = (Folder *) cur->data;
+ g_node_traverse(folder->node, G_PRE_ORDER, G_TRAVERSE_ALL, -1,
+ prefs_filtering_rename_path_func, paths);
+ }
+ prefs_filtering_rename_path_func(NULL, paths);
+}
+
+static gboolean prefs_filtering_rename_path_func(GNode *node, gpointer data)
+{
+ GSList *cur;
+ gchar *old_path, *new_path;
+ gchar *base;
+ gchar *prefix;
+ gchar *suffix;
+ gchar *dest_path;
+ gchar *old_path_with_sep;
+ gint destlen;
+ gint prefixlen;
+ gint oldpathlen;
+ FolderItem *item;
+
+ old_path = ((gchar **)data)[0];
+ new_path = ((gchar **)data)[1];
+
+ g_return_val_if_fail(old_path != NULL, FALSE);
+ g_return_val_if_fail(new_path != NULL, FALSE);
+
+ oldpathlen = strlen(old_path);
+ old_path_with_sep = g_strconcat(old_path,G_DIR_SEPARATOR_S,NULL);
+ if (node == NULL)
+ cur = global_processing;
+ else {
+ item = node->data;
+ if (!item || !item->prefs)
+ return FALSE;
+ cur = item->prefs->processing;
+ }
+
+ for (; cur != NULL; cur = cur->next) {
+ FilteringProp *filtering = (FilteringProp *)cur->data;
+ FilteringAction *action = filtering->action;
+
+ if (!action->destination) continue;
+
+ destlen = strlen(action->destination);
+
+ if (destlen > oldpathlen) {
+ prefixlen = destlen - oldpathlen;
+ suffix = action->destination + prefixlen;
+
+ if (!strncmp(old_path, suffix, oldpathlen)) {
+ prefix = g_malloc0(prefixlen + 1);
+ strncpy2(prefix, action->destination, prefixlen);
+
+ base = suffix + oldpathlen;
+ while (*base == G_DIR_SEPARATOR) base++;
+ if (*base == '\0')
+ dest_path = g_strconcat(prefix,
+ G_DIR_SEPARATOR_S,
+ new_path, NULL);
+ else
+ dest_path = g_strconcat(prefix,
+ G_DIR_SEPARATOR_S,
+ new_path,
+ G_DIR_SEPARATOR_S,
+ base, NULL);
+
+ g_free(prefix);
+ g_free(action->destination);
+ action->destination = dest_path;
+ } else { /* for non-leaf folders */
+ /* compare with trailing slash */
+ if (!strncmp(old_path_with_sep, action->destination, oldpathlen+1)) {
+
+ suffix = action->destination + oldpathlen + 1;
+ dest_path = g_strconcat(new_path,
+ G_DIR_SEPARATOR_S,
+ suffix, NULL);
+ g_free(action->destination);
+ action->destination = dest_path;
+ }
+ }
+ } else {
+ /* folder-moving a leaf */
+ if (!strcmp(old_path, action->destination)) {
+ dest_path = g_strdup(new_path);
+ g_free(action->destination);
+ action->destination = dest_path;
+ }
+ }
+ }
+ g_free(old_path_with_sep);
+ prefs_matcher_write_config();
+
+ return FALSE;
+}
+
+void prefs_filtering_delete_path(const gchar *path)
+{
+ GList * cur;
+ for (cur = folder_get_list() ; cur != NULL ; cur = g_list_next(cur)) {
+ Folder *folder;
+ folder = (Folder *) cur->data;
+ g_node_traverse(folder->node, G_PRE_ORDER, G_TRAVERSE_ALL, -1,
+ prefs_filtering_delete_path_func, (gchar *)path);
+ }
+ prefs_filtering_delete_path_func(NULL, (gchar *)path);
+}
+
+static gboolean prefs_filtering_delete_path_func(GNode *node, gpointer data)
+{
+ GSList *cur, *orig;
+ GSList *next;
+ gchar *path = (gchar *)data;
+ gchar *suffix;
+ gint destlen;
+ gint prefixlen;
+ gint pathlen;
+ FolderItem *item;
+
+ g_return_val_if_fail(path != NULL, FALSE);
+
+ pathlen = strlen(path);
+ if (node == NULL)
+ cur = global_processing;
+ else {
+ item = node->data;
+ if (!item || !item->prefs)
+ return FALSE;
+ cur = item->prefs->processing;
+ }
+ orig = cur;
+
+ for (; cur != NULL; cur = cur->next) {
+ FilteringProp *filtering = (FilteringProp *)cur->data;
+ FilteringAction *action;
+ if (!cur->data)
+ break;
+
+ action = filtering->action;
+ next = cur->next;
+
+ if (!action->destination) continue;
+
+ destlen = strlen(action->destination);
+
+ if (destlen > pathlen) {
+ prefixlen = destlen - pathlen;
+ suffix = action->destination + prefixlen;
+
+ if (suffix && !strncmp(path, suffix, pathlen)) {
+ filteringprop_free(filtering);
+ global_processing =
+ g_slist_remove(global_processing, filtering);
+ }
+ } else if (strcmp(action->destination, path) == 0) {
+ filteringprop_free(filtering);
+ orig =
+ g_slist_remove(orig, filtering);
+
+ }
+ }
+
+ prefs_matcher_write_config();
+
+ return FALSE;
+}
+
+static void prefs_filtering_set_dialog(const gchar *header, const gchar *key)
{
GtkCList *clist = GTK_CLIST(filtering.cond_clist);
GSList *cur;
+ GSList * prefs_filtering;
+ gchar *cond_str[1];
+ gint row;
gtk_clist_freeze(clist);
gtk_clist_clear(clist);
- prefs_filtering_clist_set_row(-1, NULL);
+ cond_str[0] = _("(New)");
+ row = gtk_clist_append(clist, cond_str);
+ gtk_clist_set_row_data(clist, row, NULL);
+
+ if (cur_item == NULL)
+ prefs_filtering = global_processing;
+ else
+ prefs_filtering = cur_item->prefs->processing;
+
for(cur = prefs_filtering ; cur != NULL ; cur = g_slist_next(cur)) {
FilteringProp * prop = (FilteringProp *) cur->data;
- prefs_filtering_clist_set_row(-1, prop);
+ cond_str[0] = filteringprop_to_string(prop);
+ subst_char(cond_str[0], '\t', ':');
+ row = gtk_clist_append(clist, cond_str);
+ gtk_clist_set_row_data(clist, row, prop);
+
+ g_free(cond_str[0]);
}
prefs_filtering_update_hscrollbar();
gtk_clist_thaw(clist);
prefs_filtering_reset_dialog();
+
+ if (header && key) {
+ gchar *match_str = g_strconcat(header, " ",
+ get_matchparser_tab_str(MATCHTYPE_MATCHCASE),
+ " \"", key, "\"", NULL);
+ gtk_entry_set_text(GTK_ENTRY(filtering.cond_entry), match_str);
+ g_free(match_str);
+ }
}
static void prefs_filtering_reset_dialog(void)
FilteringProp *prop;
GSList * cur;
gchar * filtering_str;
- gchar * tmp;
+ GSList * prefs_filtering;
+
+ if (cur_item == NULL)
+ prefs_filtering = global_processing;
+ else
+ prefs_filtering = cur_item->prefs->processing;
for(cur = prefs_filtering ; cur != NULL ; cur = g_slist_next(cur))
filteringprop_free((FilteringProp *) cur->data);
while (gtk_clist_get_text(GTK_CLIST(filtering.cond_clist),
row, 0, &filtering_str)) {
if (strcmp(filtering_str, _("(New)")) != 0) {
- tmp = filtering_str;
- prop = filteringprop_parse(&tmp);
+ /* tmp = filtering_str; */
+ prop = matcher_parser_get_filtering(filtering_str);
if (prop != NULL)
- prefs_filtering = g_slist_append(prefs_filtering,
- prop);
+ prefs_filtering =
+ g_slist_append(prefs_filtering, prop);
}
row++;
}
+
+ if (cur_item == NULL)
+ global_processing = prefs_filtering;
+ else
+ cur_item->prefs->processing = prefs_filtering;
}
static gint prefs_filtering_clist_set_row(gint row, FilteringProp * prop)
cond_str = gtk_entry_get_text(GTK_ENTRY(filtering.cond_entry));
if (*cond_str != '\0') {
- gchar * tmp;
-
- tmp = cond_str;
- matchers = matcherlist_parse(&tmp);
- if (tmp == NULL)
+ matchers = matcher_parser_get_cond(cond_str);
+ if (matchers == NULL)
alertpanel_error(_("Match string is not valid."));
}
gchar * cond_str;
FilteringProp * prop;
FilteringAction * action;
- gchar * tmp;
gint list_id;
gint action_id;
gint action_type;
gint account_id;
gchar * destination;
- gint labelcolor;
+ gint labelcolor = 0;
cond_str = gtk_entry_get_text(GTK_ENTRY(filtering.cond_entry));
if (*cond_str == '\0') {
case ACTION_COPY:
case ACTION_FORWARD:
case ACTION_FORWARD_AS_ATTACHMENT:
+ case ACTION_REDIRECT:
case ACTION_EXECUTE:
destination = gtk_entry_get_text(GTK_ENTRY(filtering.dest_entry));
if (*destination == '\0') {
gtk_option_menu_get_menu(GTK_OPTION_MENU(filtering.color_optmenu)));
destination = NULL;
break;
+ case ACTION_DELETE_ON_SERVER:
+ destination = NULL;
+ break;
default:
destination = NULL;
break;
action = filteringaction_new(action_type, account_id, destination, labelcolor);
- tmp = cond_str;
- cond = matcherlist_parse(&tmp);
+ cond = matcher_parser_get_cond(cond_str);
- if (tmp == NULL) {
+ if (cond == NULL) {
alertpanel_error(_("Match string is not valid."));
filteringaction_free(action);
return NULL;
gtk_entry_set_text(GTK_ENTRY(filtering.dest_entry), "");
switch(action->type) {
- case MATCHING_ACTION_MOVE:
+ case MATCHACTION_MOVE:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_MOVE);
break;
- case MATCHING_ACTION_COPY:
+ case MATCHACTION_COPY:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_COPY);
break;
- case MATCHING_ACTION_DELETE:
+ case MATCHACTION_DELETE:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_DELETE);
break;
- case MATCHING_ACTION_MARK:
+ case MATCHACTION_MARK:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_MARK);
break;
- case MATCHING_ACTION_UNMARK:
+ case MATCHACTION_UNMARK:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_UNMARK);
break;
- case MATCHING_ACTION_MARK_AS_READ:
+ case MATCHACTION_MARK_AS_READ:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_MARK_AS_READ);
break;
- case MATCHING_ACTION_MARK_AS_UNREAD:
+ case MATCHACTION_MARK_AS_UNREAD:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_MARK_AS_UNREAD);
break;
- case MATCHING_ACTION_FORWARD:
+ case MATCHACTION_FORWARD:
+ list_id = get_list_id_from_account_id(action->account_id);
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_FORWARD);
- list_id = get_list_id_from_account_id(action->account_id);
gtk_list_select_item(GTK_LIST(filtering.account_list),
list_id);
break;
- case MATCHING_ACTION_FORWARD_AS_ATTACHMENT:
+ case MATCHACTION_FORWARD_AS_ATTACHMENT:
list_id = get_list_id_from_account_id(action->account_id);
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_FORWARD_AS_ATTACHMENT);
gtk_list_select_item(GTK_LIST(filtering.account_list),
list_id);
break;
- case MATCHING_EXECUTE:
+ case MATCHACTION_REDIRECT:
+ list_id = get_list_id_from_account_id(action->account_id);
+ gtk_list_select_item(GTK_LIST(filtering.action_list),
+ ACTION_REDIRECT);
+ gtk_list_select_item(GTK_LIST(filtering.account_list),
+ list_id);
+ break;
+ case MATCHACTION_EXECUTE:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_EXECUTE);
break;
- case MATCHING_ACTION_COLOR:
+ case MATCHACTION_COLOR:
gtk_list_select_item(GTK_LIST(filtering.action_list),
ACTION_COLOR);
gtk_option_menu_set_history(GTK_OPTION_MENU(filtering.color_optmenu), action->labelcolor);
break;
+ case MATCHACTION_DELETE_ON_SERVER:
+ gtk_list_select_item(GTK_LIST(filtering.action_list),
+ ACTION_DELETE_ON_SERVER);
+ break;
}
g_free(matcher_str);
GdkEvent *event)
{
FilteringProp * prop;
- gchar * tmp;
gchar * filtering_str;
if (row == 0) {
row, 0, &filtering_str))
return;
- tmp = filtering_str;
- prop = filteringprop_parse(&tmp);
- if (tmp == NULL)
+ prop = matcher_parser_get_filtering(filtering_str);
+ if (prop == NULL)
return;
prefs_filtering_select_set(prop);
FolderItem *dest;
gchar * path;
- dest = foldersel_folder_sel(NULL, NULL);
+ dest = foldersel_folder_sel(NULL, FOLDER_SEL_COPY, NULL);
if (!dest) return;
path = folder_item_get_identifier(dest);
gtk_widget_hide(filtering.color_optmenu);
gtk_widget_hide(filtering.color_label);
break;
+ case ACTION_REDIRECT:
+ gtk_widget_set_sensitive(filtering.account_combo, TRUE);
+ gtk_widget_show(filtering.dest_entry);
+ gtk_widget_set_sensitive(filtering.dest_entry, TRUE);
+ gtk_widget_hide(filtering.dest_btn);
+ gtk_widget_show(filtering.dest_label);
+ gtk_widget_hide(filtering.exec_label);
+ gtk_widget_hide(filtering.exec_btn);
+ gtk_widget_hide(filtering.color_optmenu);
+ gtk_widget_hide(filtering.color_label);
+ break;
case ACTION_EXECUTE:
gtk_widget_set_sensitive(filtering.account_combo, FALSE);
gtk_widget_show(filtering.dest_entry);
gtk_widget_hide(filtering.dest_btn);
gtk_widget_hide(filtering.dest_label);
gtk_widget_show(filtering.exec_label);
- gtk_widget_set_sensitive(filtering.exec_btn, FALSE);
+ gtk_widget_set_sensitive(filtering.exec_btn, TRUE);
gtk_widget_show(filtering.exec_btn);
gtk_widget_hide(filtering.color_optmenu);
gtk_widget_hide(filtering.color_label);
gtk_widget_show(filtering.color_optmenu);
gtk_widget_show(filtering.color_label);
break;
+ case ACTION_DELETE_ON_SERVER:
+ gtk_widget_set_sensitive(filtering.account_combo, FALSE);
+ gtk_widget_hide(filtering.dest_entry);
+ gtk_widget_hide(filtering.dest_btn);
+ gtk_widget_hide(filtering.dest_label);
+ gtk_widget_hide(filtering.exec_label);
+ gtk_widget_show(filtering.exec_btn);
+ gtk_widget_hide(filtering.exec_btn);
+ gtk_widget_hide(filtering.color_optmenu);
+ gtk_widget_hide(filtering.color_label);
+ break;
}
}
static void prefs_filtering_ok(void)
{
prefs_filtering_set_list();
- prefs_filtering_write_config();
+ prefs_matcher_write_config();
prefs_filtering_close();
}
static void prefs_filtering_cancel(void)
{
- prefs_filtering_read_config();
+ prefs_matcher_read_config();
prefs_filtering_close();
}