*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifdef HAVE_CONFIG_H
#include "defs.h"
#include <glib.h>
+#include <glib/gi18n.h>
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
-#include "intl.h"
#include "main.h"
#include "prefs_gtk.h"
#include "prefs_matcher.h"
#include "matcher_parser.h"
#include "colorlabel.h"
+enum {
+ PREFS_MATCHER_COND,
+ PREFS_MATCHER_COND_VALID,
+ N_PREFS_MATCHER_COLUMNS
+};
+
/*!
*\brief UI data for matcher dialog
*/
GtkWidget *test_btn;
- GtkWidget *cond_clist;
+ GtkWidget *cond_list_view;
GtkWidget *criteria_table;
N_("Test"),
N_("Size greater than"),
N_("Size smaller than"),
- N_("Size exactly")
+ N_("Size exactly"),
+ N_("Partially downloaded")
};
/*!
static void prefs_matcher_create (void);
static void prefs_matcher_set_dialog (MatcherList *matchers);
-static gint prefs_matcher_clist_set_row (gint row, MatcherProp *prop);
+static void prefs_matcher_list_view_set_row (GtkTreeIter *row,
+ MatcherProp *prop);
/* callback functions */
static void prefs_matcher_delete_cb (void);
static void prefs_matcher_up (void);
static void prefs_matcher_down (void);
-static void prefs_matcher_select (GtkCList *clist,
- gint row,
- gint column,
- GdkEvent *event);
static gboolean prefs_matcher_key_pressed(GtkWidget *widget,
GdkEventKey *event,
gpointer data);
gpointer user_data);
static MatcherList *prefs_matcher_get_list (void);
+static GtkListStore* prefs_matcher_create_data_store (void);
+
+static void prefs_matcher_list_view_insert_matcher (GtkWidget *list_view,
+ GtkTreeIter *row_iter,
+ const gchar *matcher,
+ gboolean is_valid);
+
+static GtkWidget *prefs_matcher_list_view_create (void);
+
+static void prefs_matcher_create_list_view_columns (GtkWidget *list_view);
+
+static gboolean prefs_matcher_selected (GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ gpointer data);
/*!
*\brief Find index of list selection
GtkWidget *cond_hbox;
GtkWidget *cond_scrolledwin;
- GtkWidget *cond_clist;
+ GtkWidget *cond_list_view;
GtkWidget *btn_vbox;
GtkWidget *up_btn;
GList *combo_items;
gint i;
- gchar *title[1];
-
debug_print("Creating matcher configuration window...\n");
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_widget_show(vbox);
gtk_container_add(GTK_CONTAINER(window), vbox);
- gtkut_button_set_create(&confirm_area, &ok_btn, _("OK"),
- &cancel_btn, _("Cancel"), NULL, NULL);
+ gtkut_stock_button_set_create(&confirm_area, &ok_btn, GTK_STOCK_OK,
+ &cancel_btn, GTK_STOCK_CANCEL, NULL, NULL);
gtk_widget_show(confirm_area);
gtk_box_pack_end(GTK_BOX(vbox), confirm_area, FALSE, FALSE, 0);
gtk_widget_grab_default(ok_btn);
g_list_free(combo_items);
- gtk_widget_set_usize(criteria_combo, 120, -1);
+ gtk_widget_set_size_request(criteria_combo, 120, -1);
gtk_table_attach(GTK_TABLE(criteria_table), criteria_combo, 0, 1, 1, 2,
0, 0, 0, 0);
criteria_list = GTK_COMBO(criteria_combo)->list;
header_combo = gtk_combo_new();
gtk_widget_show(header_combo);
- gtk_widget_set_usize(header_combo, 96, -1);
+ gtk_widget_set_size_request(header_combo, 96, -1);
gtkut_combo_set_items(GTK_COMBO (header_combo),
"Subject", "From", "To", "Cc", "Reply-To",
"Sender", "X-ML-Name", "X-List", "X-Sequence",
value_entry = gtk_entry_new();
gtk_widget_show(value_entry);
- gtk_widget_set_usize(value_entry, 200, -1);
+ gtk_widget_set_size_request(value_entry, 200, -1);
gtk_table_attach(GTK_TABLE(criteria_table), value_entry, 2, 3, 1, 2,
GTK_FILL | GTK_SHRINK | GTK_EXPAND, 0, 0, 0);
predicate_combo = gtk_combo_new();
gtk_widget_show(predicate_combo);
- gtk_widget_set_usize(predicate_combo, 120, -1);
+ gtk_widget_set_size_request(predicate_combo, 120, -1);
predicate_list = GTK_COMBO(predicate_combo)->list;
gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(predicate_combo)->entry),
FALSE);
predicate_flag_combo = gtk_combo_new();
gtk_widget_hide(predicate_flag_combo);
- gtk_widget_set_usize(predicate_flag_combo, 120, -1);
+ gtk_widget_set_size_request(predicate_flag_combo, 120, -1);
predicate_flag_list = GTK_COMBO(predicate_flag_combo)->list;
gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(predicate_flag_combo)->entry), FALSE);
arrow = gtk_arrow_new(GTK_ARROW_DOWN, GTK_SHADOW_OUT);
gtk_widget_show(arrow);
gtk_box_pack_start(GTK_BOX(reg_hbox), arrow, FALSE, FALSE, 0);
- gtk_widget_set_usize(arrow, -1, 16);
+ gtk_widget_set_size_request(arrow, -1, 16);
btn_hbox = gtk_hbox_new(TRUE, 4);
gtk_widget_show(btn_hbox);
gtk_box_pack_start(GTK_BOX(reg_hbox), btn_hbox, FALSE, FALSE, 0);
- reg_btn = gtk_button_new_with_label(_("Add"));
+ reg_btn = gtk_button_new_from_stock(GTK_STOCK_ADD);
gtk_widget_show(reg_btn);
gtk_box_pack_start(GTK_BOX(btn_hbox), reg_btn, FALSE, TRUE, 0);
g_signal_connect(G_OBJECT(reg_btn), "clicked",
G_CALLBACK(prefs_matcher_substitute_cb),
NULL);
- del_btn = gtk_button_new_with_label(_("Delete"));
+ del_btn = gtk_button_new_from_stock(GTK_STOCK_DELETE);
gtk_widget_show(del_btn);
gtk_box_pack_start(GTK_BOX(btn_hbox), del_btn, FALSE, TRUE, 0);
g_signal_connect(G_OBJECT(del_btn), "clicked",
bool_op_combo = gtk_combo_new();
gtk_widget_show(bool_op_combo);
- gtk_widget_set_usize(bool_op_combo, 50, -1);
+ gtk_widget_set_size_request(bool_op_combo, 50, -1);
bool_op_list = GTK_COMBO(bool_op_combo)->list;
gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(bool_op_combo)->entry),
FALSE);
cond_scrolledwin = gtk_scrolled_window_new(NULL, NULL);
gtk_widget_show(cond_scrolledwin);
- gtk_widget_set_usize(cond_scrolledwin, -1, 150);
+ gtk_widget_set_size_request(cond_scrolledwin, -1, 150);
gtk_box_pack_start(GTK_BOX(cond_hbox), cond_scrolledwin,
TRUE, TRUE, 0);
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(cond_scrolledwin),
GTK_POLICY_AUTOMATIC,
GTK_POLICY_AUTOMATIC);
- title[0] = _("Current condition 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(cond_clist), 0, 80);
- gtk_clist_set_selection_mode(GTK_CLIST(cond_clist),
- GTK_SELECTION_BROWSE);
- GTK_WIDGET_UNSET_FLAGS(GTK_CLIST(cond_clist)->column[0].button,
- GTK_CAN_FOCUS);
- g_signal_connect(G_OBJECT(cond_clist), "select_row",
- G_CALLBACK(prefs_matcher_select), NULL);
+ cond_list_view = prefs_matcher_list_view_create();
+ gtk_widget_show(cond_list_view);
+ gtk_container_add(GTK_CONTAINER(cond_scrolledwin), cond_list_view);
btn_vbox = gtk_vbox_new(FALSE, 8);
gtk_widget_show(btn_vbox);
gtk_box_pack_start(GTK_BOX(cond_hbox), btn_vbox, FALSE, FALSE, 0);
- up_btn = gtk_button_new_with_label(_("Up"));
+ up_btn = gtk_button_new_from_stock(GTK_STOCK_GO_UP);
gtk_widget_show(up_btn);
gtk_box_pack_start(GTK_BOX(btn_vbox), up_btn, FALSE, FALSE, 0);
g_signal_connect(G_OBJECT(up_btn), "clicked",
G_CALLBACK(prefs_matcher_up), NULL);
- down_btn = gtk_button_new_with_label(_("Down"));
+ down_btn = gtk_button_new_from_stock(GTK_STOCK_GO_DOWN);
gtk_widget_show(down_btn);
gtk_box_pack_start(GTK_BOX(btn_vbox), down_btn, FALSE, FALSE, 0);
g_signal_connect(G_OBJECT(down_btn), "clicked",
matcher.color_optmenu = color_optmenu;
matcher.criteria_table = criteria_table;
- matcher.cond_clist = cond_clist;
+ matcher.cond_list_view = cond_list_view;
}
/*!
*
*\return gint Row index \a prop has been added
*/
-static gint prefs_matcher_clist_set_row(gint row, MatcherProp *prop)
+static void prefs_matcher_list_view_set_row(GtkTreeIter *row, MatcherProp *prop)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
- gchar *cond_str[1];
gchar *matcher_str;
if (prop == NULL) {
- cond_str[0] = _("(New)");
- return gtk_clist_append(clist, cond_str);
+ prefs_matcher_list_view_insert_matcher(matcher.cond_list_view,
+ NULL, _("New"), FALSE);
+ return;
}
matcher_str = matcherprop_to_string(prop);
- cond_str[0] = matcher_str;
- if (row < 0)
- row = gtk_clist_append(clist, cond_str);
+ if (!row)
+ prefs_matcher_list_view_insert_matcher(matcher.cond_list_view,
+ NULL, matcher_str,
+ TRUE);
else
- gtk_clist_set_text(clist, row, 0, cond_str[0]);
+ prefs_matcher_list_view_insert_matcher(matcher.cond_list_view,
+ row, matcher_str,
+ TRUE);
g_free(matcher_str);
-
- return row;
}
/*!
gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), "");
}
-/*!
- *\brief Update scrollbar
- */
-static void prefs_matcher_update_hscrollbar(void)
-{
- gint optwidth = gtk_clist_optimal_column_width(GTK_CLIST(matcher.cond_clist), 0);
- gtk_clist_set_column_width(GTK_CLIST(matcher.cond_clist), 0, optwidth);
-}
-
/*!
*\brief Initializes dialog with a set of conditions
*
*/
static void prefs_matcher_set_dialog(MatcherList *matchers)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
GSList *cur;
gboolean bool_op = 1;
+ GtkListStore *store = GTK_LIST_STORE(gtk_tree_view_get_model
+ (GTK_TREE_VIEW(matcher.cond_list_view)));
- gtk_clist_freeze(clist);
- gtk_clist_clear(clist);
+ gtk_list_store_clear(store);
- prefs_matcher_clist_set_row(-1, NULL);
+ prefs_matcher_list_view_set_row(NULL, NULL);
if (matchers != NULL) {
for (cur = matchers->matchers; cur != NULL;
cur = g_slist_next(cur)) {
MatcherProp *prop;
prop = (MatcherProp *) cur->data;
- prefs_matcher_clist_set_row(-1, prop);
+ prefs_matcher_list_view_set_row(NULL, prop);
}
bool_op = matchers->bool_and;
}
- prefs_matcher_update_hscrollbar();
-
- gtk_clist_thaw(clist);
-
gtk_list_select_item(GTK_LIST(matcher.bool_op_list), bool_op);
prefs_matcher_reset_condition();
{
gchar *matcher_str;
MatcherProp *prop;
- gint row = 1;
gboolean bool_and;
GSList *matcher_list;
MatcherList *matchers;
+ GtkTreeModel *model;
+ GtkTreeIter iter;
- matcher_list = NULL;
+ model = gtk_tree_view_get_model(GTK_TREE_VIEW(matcher.cond_list_view));
+ if (!gtk_tree_model_get_iter_first(model, &iter))
+ return NULL;
- while (gtk_clist_get_text(GTK_CLIST(matcher.cond_clist),
- row, 0, &matcher_str)) {
+ matcher_list = NULL;
- if (strcmp(matcher_str, _("(New)")) != 0) {
+ do {
+ gboolean is_valid;
+
+ gtk_tree_model_get(model, &iter,
+ PREFS_MATCHER_COND, &matcher_str,
+ PREFS_MATCHER_COND_VALID, &is_valid,
+ -1);
+
+ if (is_valid) {
/* tmp = matcher_str; */
prop = matcher_parser_get_prop(matcher_str);
-
+ g_free(matcher_str);
if (prop == NULL)
break;
matcher_list = g_slist_append(matcher_list, prop);
}
- row ++;
- }
+ } while (gtk_tree_model_iter_next(model, &iter));
bool_and = get_sel_from_list(GTK_LIST(matcher.bool_op_list));
if (matcherprop == NULL)
return;
- prefs_matcher_clist_set_row(-1, matcherprop);
+ prefs_matcher_list_view_set_row(NULL, matcherprop);
matcherprop_free(matcherprop);
prefs_matcher_reset_condition();
- prefs_matcher_update_hscrollbar();
}
/*!
*/
static void prefs_matcher_substitute_cb(void)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
- gint row;
MatcherProp *matcherprop;
+ GtkTreeIter row;
+ GtkTreeSelection *selection;
+ GtkTreeModel *model;
+ gboolean is_valid;
- if (!clist->selection) return;
- row = GPOINTER_TO_INT(clist->selection->data);
- if (row == 0)
+ selection = gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(matcher.cond_list_view));
+
+ if (!gtk_tree_selection_get_selected(selection, &model, &row))
return;
+ gtk_tree_model_get(model, &row,
+ PREFS_MATCHER_COND_VALID, &is_valid,
+ -1);
+ if (!is_valid)
+ return;
+
matcherprop = prefs_matcher_dialog_to_matcher();
if (matcherprop == NULL)
return;
- prefs_matcher_clist_set_row(row, matcherprop);
+ prefs_matcher_list_view_set_row(&row, matcherprop);
matcherprop_free(matcherprop);
prefs_matcher_reset_condition();
-
- prefs_matcher_update_hscrollbar();
}
/*!
*/
static void prefs_matcher_delete_cb(void)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
- gint row;
+ GtkTreeIter row;
+ GtkTreeSelection *selection;
+ GtkTreeModel *model;
+ gboolean is_valid;
- if (!clist->selection) return;
- row = GPOINTER_TO_INT(clist->selection->data);
- if (row == 0)
+ selection = gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(matcher.cond_list_view));
+
+ if (!gtk_tree_selection_get_selected(selection, &model, &row))
return;
+
+ gtk_tree_model_get(model, &row,
+ PREFS_MATCHER_COND_VALID, &is_valid,
+ -1);
- gtk_clist_remove(clist, row);
+ if (!is_valid)
+ return;
- prefs_matcher_reset_condition();
+ gtk_list_store_remove(GTK_LIST_STORE(model), &row);
- prefs_matcher_update_hscrollbar();
+ prefs_matcher_reset_condition();
}
/*!
*/
static void prefs_matcher_up(void)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
- gint row;
-
- if (!clist->selection) return;
-
- row = GPOINTER_TO_INT(clist->selection->data);
- if (row > 1) {
- gtk_clist_row_move(clist, row, row - 1);
- if (gtk_clist_row_is_visible(clist, row - 1) != GTK_VISIBILITY_FULL)
- gtk_clist_moveto(clist, row - 1, 0, 0, 0);
+ GtkTreePath *prev, *sel, *try;
+ GtkTreeIter isel;
+ GtkListStore *store = NULL;
+ GtkTreeModel *model = NULL;
+ GtkTreeIter iprev;
+
+ if (!gtk_tree_selection_get_selected
+ (gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(matcher.cond_list_view)),
+ &model,
+ &isel))
+ return;
+ store = (GtkListStore *)model;
+ sel = gtk_tree_model_get_path(GTK_TREE_MODEL(store), &isel);
+ if (!sel)
+ return;
+
+ /* no move if we're at row 0 or 1, looks phony, but other
+ * solutions are more convoluted... */
+ try = gtk_tree_path_copy(sel);
+ if (!gtk_tree_path_prev(try) || !gtk_tree_path_prev(try)) {
+ gtk_tree_path_free(try);
+ gtk_tree_path_free(sel);
+ return;
}
+ gtk_tree_path_free(try);
+
+ prev = gtk_tree_path_copy(sel);
+ if (gtk_tree_path_prev(prev)) {
+ gtk_tree_model_get_iter(GTK_TREE_MODEL(store),
+ &iprev, prev);
+ gtk_list_store_swap(store, &iprev, &isel);
+ /* XXX: GTK2 select row?? */
+ }
+
+ gtk_tree_path_free(sel);
+ gtk_tree_path_free(prev);
}
/*!
*/
static void prefs_matcher_down(void)
{
- GtkCList *clist = GTK_CLIST(matcher.cond_clist);
- gint row;
-
- if (!clist->selection) return;
-
- row = GPOINTER_TO_INT(clist->selection->data);
- if (row >= 1 && row < clist->rows - 1) {
- gtk_clist_row_move(clist, row, row + 1);
- if (gtk_clist_row_is_visible(clist, row + 1) != GTK_VISIBILITY_FULL)
- gtk_clist_moveto(clist, row + 1, 0, 1, 0);
- }
-}
-
-/*!
- *\brief Signal handler for select row.
- *
- *\param clist List widget
- *\param row Selected row
- *\param column Selected column
- *\param event Event information
- */
-static void prefs_matcher_select(GtkCList *clist, gint row, gint column,
- GdkEvent *event)
-{
- gchar *matcher_str;
- MatcherProp *prop;
- gboolean negative_cond;
- gint criteria;
-
- if (!gtk_clist_get_text(GTK_CLIST(matcher.cond_clist),
- row, 0, &matcher_str))
- return;
-
- negative_cond = FALSE;
-
- if (row == 0) {
- prefs_matcher_reset_condition();
+ GtkListStore *store = NULL;
+ GtkTreeModel *model = NULL;
+ GtkTreeIter next, sel;
+ GtkTreePath *try;
+
+ if (!gtk_tree_selection_get_selected
+ (gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(matcher.cond_list_view)),
+ &model,
+ &sel))
return;
- }
-
- prop = matcher_parser_get_prop(matcher_str);
- if (prop == NULL)
+ store = (GtkListStore *)model;
+ try = gtk_tree_model_get_path(GTK_TREE_MODEL(store), &sel);
+ if (!try)
return;
-
- criteria = prefs_matcher_get_criteria_from_matching(prop->criteria);
- if (criteria != -1)
- gtk_list_select_item(GTK_LIST(matcher.criteria_list),
- criteria);
-
- switch(prop->criteria) {
- case MATCHCRITERIA_NOT_UNREAD:
- case MATCHCRITERIA_NOT_NEW:
- case MATCHCRITERIA_NOT_MARKED:
- case MATCHCRITERIA_NOT_DELETED:
- case MATCHCRITERIA_NOT_REPLIED:
- case MATCHCRITERIA_NOT_FORWARDED:
- case MATCHCRITERIA_NOT_LOCKED:
- case MATCHCRITERIA_NOT_PARTIAL:
- case MATCHCRITERIA_NOT_COLORLABEL:
- case MATCHCRITERIA_NOT_IGNORE_THREAD:
- case MATCHCRITERIA_NOT_SUBJECT:
- case MATCHCRITERIA_NOT_FROM:
- case MATCHCRITERIA_NOT_TO:
- case MATCHCRITERIA_NOT_CC:
- case MATCHCRITERIA_NOT_NEWSGROUPS:
- case MATCHCRITERIA_NOT_INREPLYTO:
- case MATCHCRITERIA_NOT_REFERENCES:
- case MATCHCRITERIA_NOT_TO_AND_NOT_CC:
- case MATCHCRITERIA_NOT_BODY_PART:
- case MATCHCRITERIA_NOT_MESSAGE:
- case MATCHCRITERIA_NOT_HEADERS_PART:
- case MATCHCRITERIA_NOT_HEADER:
- negative_cond = TRUE;
- break;
- }
- switch(prop->criteria) {
- case MATCHCRITERIA_ALL:
- break;
-
- case MATCHCRITERIA_NOT_SUBJECT:
- case MATCHCRITERIA_NOT_FROM:
- case MATCHCRITERIA_NOT_TO:
- case MATCHCRITERIA_NOT_CC:
- case MATCHCRITERIA_NOT_TO_AND_NOT_CC:
- case MATCHCRITERIA_NOT_NEWSGROUPS:
- case MATCHCRITERIA_NOT_INREPLYTO:
- case MATCHCRITERIA_NOT_REFERENCES:
- case MATCHCRITERIA_NOT_HEADERS_PART:
- case MATCHCRITERIA_NOT_BODY_PART:
- case MATCHCRITERIA_NOT_MESSAGE:
- case MATCHCRITERIA_SUBJECT:
- case MATCHCRITERIA_FROM:
- case MATCHCRITERIA_TO:
- case MATCHCRITERIA_CC:
- case MATCHCRITERIA_TO_OR_CC:
- case MATCHCRITERIA_NEWSGROUPS:
- case MATCHCRITERIA_INREPLYTO:
- case MATCHCRITERIA_REFERENCES:
- case MATCHCRITERIA_HEADERS_PART:
- case MATCHCRITERIA_BODY_PART:
- case MATCHCRITERIA_MESSAGE:
- case MATCHCRITERIA_TEST:
- gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), prop->expr);
- break;
-
- case MATCHCRITERIA_AGE_GREATER:
- case MATCHCRITERIA_AGE_LOWER:
- case MATCHCRITERIA_SCORE_GREATER:
- case MATCHCRITERIA_SCORE_LOWER:
- case MATCHCRITERIA_SCORE_EQUAL:
- case MATCHCRITERIA_SIZE_GREATER:
- case MATCHCRITERIA_SIZE_SMALLER:
- case MATCHCRITERIA_SIZE_EQUAL:
- gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), itos(prop->value));
- break;
-
- case MATCHCRITERIA_NOT_COLORLABEL:
- case MATCHCRITERIA_COLORLABEL:
- gtk_option_menu_set_history(GTK_OPTION_MENU(matcher.color_optmenu),
- prop->value);
- break;
-
- case MATCHCRITERIA_NOT_HEADER:
- case MATCHCRITERIA_HEADER:
- gtk_entry_set_text(GTK_ENTRY(matcher.header_entry), prop->header);
- gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), prop->expr);
- break;
- }
-
- if (negative_cond)
- gtk_list_select_item(GTK_LIST(matcher.predicate_list), 1);
- else
- gtk_list_select_item(GTK_LIST(matcher.predicate_list), 0);
-
- switch(prop->matchtype) {
- case MATCHTYPE_MATCH:
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), FALSE);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), TRUE);
- break;
-
- case MATCHTYPE_MATCHCASE:
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), FALSE);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), FALSE);
- break;
-
- case MATCHTYPE_REGEXP:
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), TRUE);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), TRUE);
- break;
-
- case MATCHTYPE_REGEXPCASE:
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), TRUE);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), FALSE);
- break;
+ /* move when not at row 0 ... */
+ if (gtk_tree_path_prev(try)) {
+ next = sel;
+ if (gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &next))
+ gtk_list_store_swap(store, &next, &sel);
}
+
+ gtk_tree_path_free(try);
}
/*!
gtk_widget_ref(old_widget);
gtkut_container_remove(GTK_CONTAINER(matcher.criteria_table), old_widget);
gtk_widget_show(new_widget);
- gtk_widget_set_usize(new_widget, 200, -1);
+ gtk_widget_set_size_request(new_widget, 200, -1);
gtk_table_attach(GTK_TABLE(matcher.criteria_table), new_widget,
2, 3, 1, 2,
GTK_FILL | GTK_SHRINK | GTK_EXPAND,
old_value = matcher.selected_criteria;
matcher.selected_criteria = value = get_sel_from_list
(GTK_LIST(matcher.criteria_list));
-
+
+ if (old_value == matcher.selected_criteria)
+ return;
+
/* CLAWS: the value widget is currently either the color label combo box,
* or a GtkEntry, so kiss for now */
if (matcher.selected_criteria == CRITERIA_COLORLABEL) {
MatcherProp *matcherprop;
AlertValue val;
gchar *matcher_str = NULL;
- gchar *str;
+ gchar *str = NULL;
gint row = 1;
+ GtkTreeModel *model;
+ GtkTreeIter iter;
matchers = prefs_matcher_get_list();
matcherprop = prefs_matcher_dialog_to_matcher();
if (matcherprop != NULL) {
str = matcherprop_to_string(matcherprop);
- if(strcmp(str, "all") != 0) {
- while (gtk_clist_get_text(GTK_CLIST(matcher.cond_clist),
- row, 0, &matcher_str)) {
- if (matcher_str && strcmp(matcher_str, str) == 0) break;
+ matcherprop_free(matcherprop);
+ if (strcmp(str, "all") != 0) {
+ model = gtk_tree_view_get_model(GTK_TREE_VIEW
+ (matcher.cond_list_view));
+
+ while (gtk_tree_model_iter_nth_child(model, &iter, NULL, row)) {
+ gtk_tree_model_get(model, &iter,
+ PREFS_MATCHER_COND, &matcher_str,
+ -1);
+ if (matcher_str && strcmp(matcher_str, str) == 0)
+ break;
row++;
+ g_free(matcher_str);
+ matcher_str = NULL;
}
if (!matcher_str || strcmp(matcher_str, str) != 0) {
val = alertpanel(_("Entry not saved"),
_("The entry was not saved\nHave you really finished?"),
- _("Yes"), _("No"), NULL);
+ GTK_STOCK_YES, GTK_STOCK_NO, NULL);
if (G_ALERTDEFAULT != val) {
+ g_free(matcher_str);
g_free(str);
return;
}
}
+ g_free(matcher_str);
}
}
g_free(str);
};
static DescriptionWindow test_desc_win = {
+ NULL,
NULL,
2,
N_("Match Type: 'Test'"),
description_window_create(&test_desc_win);
}
+/*
+ * list view
+ */
+
+static GtkListStore* prefs_matcher_create_data_store(void)
+{
+ return gtk_list_store_new(N_PREFS_MATCHER_COLUMNS,
+ G_TYPE_STRING,
+ G_TYPE_BOOLEAN,
+ -1);
+}
+
+static void prefs_matcher_list_view_insert_matcher(GtkWidget *list_view,
+ GtkTreeIter *row_iter,
+ const gchar *matcher,
+ gboolean is_valid)
+{
+ GtkTreeIter iter;
+ GtkListStore *list_store = GTK_LIST_STORE(gtk_tree_view_get_model
+ (GTK_TREE_VIEW(list_view)));
+
+ if (row_iter == NULL) {
+ /* append new */
+ gtk_list_store_append(list_store, &iter);
+ } else {
+ /* change existing */
+ iter = *row_iter;
+ }
+
+ gtk_list_store_set(list_store, &iter,
+ PREFS_MATCHER_COND, matcher,
+ PREFS_MATCHER_COND_VALID, is_valid,
+ -1);
+}
+
+static GtkWidget *prefs_matcher_list_view_create(void)
+{
+ GtkTreeView *list_view;
+ GtkTreeSelection *selector;
+ GtkTreeModel *model;
+
+ model = GTK_TREE_MODEL(prefs_matcher_create_data_store());
+ list_view = GTK_TREE_VIEW(gtk_tree_view_new_with_model(model));
+ g_object_unref(model);
+
+ gtk_tree_view_set_rules_hint(list_view, prefs_common.enable_rules_hint);
+
+ selector = gtk_tree_view_get_selection(list_view);
+ gtk_tree_selection_set_mode(selector, GTK_SELECTION_BROWSE);
+ gtk_tree_selection_set_select_function(selector, prefs_matcher_selected,
+ NULL, NULL);
+
+ /* create the columns */
+ prefs_matcher_create_list_view_columns(GTK_WIDGET(list_view));
+
+ return GTK_WIDGET(list_view);
+}
+
+static void prefs_matcher_create_list_view_columns(GtkWidget *list_view)
+{
+ GtkTreeViewColumn *column;
+ GtkCellRenderer *renderer;
+
+ renderer = gtk_cell_renderer_text_new();
+ column = gtk_tree_view_column_new_with_attributes
+ (_("Current condition rules"),
+ renderer,
+ "text", PREFS_MATCHER_COND,
+ NULL);
+ gtk_tree_view_append_column(GTK_TREE_VIEW(list_view), column);
+}
+
+static gboolean prefs_matcher_selected(GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ gpointer data)
+{
+ gchar *matcher_str;
+ MatcherProp *prop;
+ gboolean negative_cond;
+ gint criteria;
+ GtkTreeIter iter;
+ gboolean is_valid;
+
+ if (currently_selected)
+ return TRUE;
+
+ if (!gtk_tree_model_get_iter(model, &iter, path))
+ return TRUE;
+
+ gtk_tree_model_get(model, &iter,
+ PREFS_MATCHER_COND_VALID, &is_valid,
+ PREFS_MATCHER_COND, &matcher_str,
+ -1);
+
+ if (!is_valid) {
+ g_free(matcher_str);
+ prefs_matcher_reset_condition();
+ return TRUE;
+ }
+
+ negative_cond = FALSE;
+
+ prop = matcher_parser_get_prop(matcher_str);
+ if (prop == NULL) {
+ g_free(matcher_str);
+ return TRUE;
+ }
+
+ criteria = prefs_matcher_get_criteria_from_matching(prop->criteria);
+ if (criteria != -1)
+ gtk_list_select_item(GTK_LIST(matcher.criteria_list),
+ criteria);
+
+ switch(prop->criteria) {
+ case MATCHCRITERIA_NOT_UNREAD:
+ case MATCHCRITERIA_NOT_NEW:
+ case MATCHCRITERIA_NOT_MARKED:
+ case MATCHCRITERIA_NOT_DELETED:
+ case MATCHCRITERIA_NOT_REPLIED:
+ case MATCHCRITERIA_NOT_FORWARDED:
+ case MATCHCRITERIA_NOT_LOCKED:
+ case MATCHCRITERIA_NOT_PARTIAL:
+ case MATCHCRITERIA_NOT_COLORLABEL:
+ case MATCHCRITERIA_NOT_IGNORE_THREAD:
+ case MATCHCRITERIA_NOT_SUBJECT:
+ case MATCHCRITERIA_NOT_FROM:
+ case MATCHCRITERIA_NOT_TO:
+ case MATCHCRITERIA_NOT_CC:
+ case MATCHCRITERIA_NOT_NEWSGROUPS:
+ case MATCHCRITERIA_NOT_INREPLYTO:
+ case MATCHCRITERIA_NOT_REFERENCES:
+ case MATCHCRITERIA_NOT_TO_AND_NOT_CC:
+ case MATCHCRITERIA_NOT_BODY_PART:
+ case MATCHCRITERIA_NOT_MESSAGE:
+ case MATCHCRITERIA_NOT_HEADERS_PART:
+ case MATCHCRITERIA_NOT_HEADER:
+ negative_cond = TRUE;
+ break;
+ }
+
+ switch(prop->criteria) {
+ case MATCHCRITERIA_ALL:
+ break;
+
+ case MATCHCRITERIA_NOT_SUBJECT:
+ case MATCHCRITERIA_NOT_FROM:
+ case MATCHCRITERIA_NOT_TO:
+ case MATCHCRITERIA_NOT_CC:
+ case MATCHCRITERIA_NOT_TO_AND_NOT_CC:
+ case MATCHCRITERIA_NOT_NEWSGROUPS:
+ case MATCHCRITERIA_NOT_INREPLYTO:
+ case MATCHCRITERIA_NOT_REFERENCES:
+ case MATCHCRITERIA_NOT_HEADERS_PART:
+ case MATCHCRITERIA_NOT_BODY_PART:
+ case MATCHCRITERIA_NOT_MESSAGE:
+ case MATCHCRITERIA_SUBJECT:
+ case MATCHCRITERIA_FROM:
+ case MATCHCRITERIA_TO:
+ case MATCHCRITERIA_CC:
+ case MATCHCRITERIA_TO_OR_CC:
+ case MATCHCRITERIA_NEWSGROUPS:
+ case MATCHCRITERIA_INREPLYTO:
+ case MATCHCRITERIA_REFERENCES:
+ case MATCHCRITERIA_HEADERS_PART:
+ case MATCHCRITERIA_BODY_PART:
+ case MATCHCRITERIA_MESSAGE:
+ case MATCHCRITERIA_TEST:
+ gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), prop->expr);
+ break;
+
+ case MATCHCRITERIA_AGE_GREATER:
+ case MATCHCRITERIA_AGE_LOWER:
+ case MATCHCRITERIA_SCORE_GREATER:
+ case MATCHCRITERIA_SCORE_LOWER:
+ case MATCHCRITERIA_SCORE_EQUAL:
+ case MATCHCRITERIA_SIZE_GREATER:
+ case MATCHCRITERIA_SIZE_SMALLER:
+ case MATCHCRITERIA_SIZE_EQUAL:
+ gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), itos(prop->value));
+ break;
+
+ case MATCHCRITERIA_NOT_COLORLABEL:
+ case MATCHCRITERIA_COLORLABEL:
+ gtk_option_menu_set_history(GTK_OPTION_MENU(matcher.color_optmenu),
+ prop->value);
+ break;
+
+ case MATCHCRITERIA_NOT_HEADER:
+ case MATCHCRITERIA_HEADER:
+ gtk_entry_set_text(GTK_ENTRY(matcher.header_entry), prop->header);
+ gtk_entry_set_text(GTK_ENTRY(matcher.value_entry), prop->expr);
+ break;
+ }
+
+ if (negative_cond)
+ gtk_list_select_item(GTK_LIST(matcher.predicate_list), 1);
+ else
+ gtk_list_select_item(GTK_LIST(matcher.predicate_list), 0);
+
+ switch(prop->matchtype) {
+ case MATCHTYPE_MATCH:
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), FALSE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), TRUE);
+ break;
+
+ case MATCHTYPE_MATCHCASE:
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), FALSE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), FALSE);
+ break;
+
+ case MATCHTYPE_REGEXP:
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), TRUE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), TRUE);
+ break;
+
+ case MATCHTYPE_REGEXPCASE:
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.regexp_chkbtn), TRUE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(matcher.case_chkbtn), FALSE);
+ break;
+ }
+
+ g_free(matcher_str);
+ return TRUE;
+}
+