-
%{
-
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (c) 2001-2002 by Hiroyuki Yamamoto & The Sylpheed Claws Team.
+ * Copyright (c) 2001-2007 by Hiroyuki Yamamoto & The Claws Mail Team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
*
* 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.
*/
#include "defs.h"
#include "matcher.h"
#include "matcher_parser.h"
#include "matcher_parser_lex.h"
-#include "procmsg.h"
-
-#define MAX_COLORLABELS (MSG_CLABEL_7 - MSG_CLABEL_NONE)
+#include "colorlabel.h"
static gint error = 0;
static gint bool_op = 0;
static GSList *matchers_list = NULL;
+static gboolean enabled = TRUE;
static gchar *name = NULL;
+static gint account_id = 0;
static MatcherList *cond;
static GSList *action_list = NULL;
static FilteringAction *action = NULL;
+static gboolean matcher_is_fast = TRUE;
static FilteringProp *filtering;
enum {
MATCHER_PARSE_FILE,
MATCHER_PARSE_NO_EOL,
+ MATCHER_PARSE_ENABLED,
MATCHER_PARSE_NAME,
+ MATCHER_PARSE_ACCOUNT,
MATCHER_PARSE_CONDITION,
MATCHER_PARSE_FILTERING_ACTION,
};
void matcher_parser_init(void);
void matcher_parser_switch_to_buffer(void * new_buffer);
void matcher_parser_delete_buffer(void * b);
+void matcher_parserpop_buffer_state(void);
int matcher_parserlex(void);
void matcher_parser_start_parsing(FILE *f)
{
+ matcher_parserlineno = 1;
matcher_parserrestart(f);
+ account_id = 0;
matcher_parserparse();
}
matcher_parserlineno = 1;
matcher_parse_op = MATCHER_PARSE_NO_EOL;
matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
matcher_parser_init();
bufstate = matcher_parser_scan_string((const char *) tmp_str);
matcher_parser_switch_to_buffer(bufstate);
matcher_parserlineno = 1;
matcher_parse_op = MATCHER_PARSE_NAME;
matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parserparse();
return cond;
}
-MatcherList *matcher_parser_get_cond(gchar *str)
+MatcherList *matcher_parser_get_enabled(gchar *str)
+{
+ void *bufstate;
+
+ if (!check_quote_symetry(str)) {
+ cond = NULL;
+ return cond;
+ }
+
+ /* bad coding to enable the sub-grammar matching
+ in yacc */
+ matcher_parserlineno = 1;
+ matcher_parse_op = MATCHER_PARSE_ENABLED;
+ matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
+ matcher_parser_init();
+ bufstate = matcher_parser_scan_string(str);
+ matcher_parserparse();
+ matcher_parse_op = MATCHER_PARSE_FILE;
+ matcher_parser_delete_buffer(bufstate);
+ return cond;
+}
+
+MatcherList *matcher_parser_get_account(gchar *str)
{
void *bufstate;
return cond;
}
+ /* bad coding to enable the sub-grammar matching
+ in yacc */
+ matcher_parserlineno = 1;
+ matcher_parse_op = MATCHER_PARSE_ACCOUNT;
+ matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
+ matcher_parser_init();
+ bufstate = matcher_parser_scan_string(str);
+ matcher_parserparse();
+ matcher_parse_op = MATCHER_PARSE_FILE;
+ matcher_parser_delete_buffer(bufstate);
+ return cond;
+}
+
+MatcherList *matcher_parser_get_cond(gchar *str, gboolean *is_fast)
+{
+ void *bufstate;
+
+ if (!check_quote_symetry(str)) {
+ cond = NULL;
+ return cond;
+ }
+
+ matcher_is_fast = TRUE;
/* bad coding to enable the sub-grammar matching
in yacc */
matcher_parserlineno = 1;
matcher_parse_op = MATCHER_PARSE_CONDITION;
matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parserparse();
matcher_parse_op = MATCHER_PARSE_FILE;
matcher_parser_delete_buffer(bufstate);
+ if (is_fast)
+ *is_fast = matcher_is_fast;
return cond;
}
matcher_parserlineno = 1;
matcher_parse_op = MATCHER_PARSE_FILTERING_ACTION;
matcher_parserrestart(NULL);
+ matcher_parserpop_buffer_state();
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parserparse();
MatcherProp *prop;
matcher_parserlineno = 1;
- list = matcher_parser_get_cond(str);
+ list = matcher_parser_get_cond(str, NULL);
if (list == NULL)
return NULL;
%token MATCHER_NOT_MESSAGE MATCHER_BODY_PART MATCHER_NOT_BODY_PART
%token MATCHER_TEST MATCHER_NOT_TEST MATCHER_MATCHCASE MATCHER_MATCH
%token MATCHER_REGEXPCASE MATCHER_REGEXP MATCHER_SCORE MATCHER_MOVE
-%token MATCHER_ANY_IN_ADDRESSBOOK MATCHER_ALL_IN_ADDRESSBOOK
+%token MATCHER_FOUND_IN_ADDRESSBOOK MATCHER_NOT_FOUND_IN_ADDRESSBOOK MATCHER_IN
%token MATCHER_COPY MATCHER_DELETE MATCHER_MARK MATCHER_UNMARK
%token MATCHER_LOCK MATCHER_UNLOCK
%token MATCHER_EXECUTE
%token MATCHER_MARK_AS_READ MATCHER_MARK_AS_UNREAD MATCHER_FORWARD
-%token MATCHER_FORWARD_AS_ATTACHMENT MATCHER_EOL MATCHER_STRING
+%token MATCHER_MARK_AS_SPAM MATCHER_MARK_AS_HAM
+%token MATCHER_FORWARD_AS_ATTACHMENT MATCHER_EOL
%token MATCHER_OR MATCHER_AND
%token MATCHER_COLOR MATCHER_SCORE_EQUAL MATCHER_REDIRECT
%token MATCHER_SIZE_GREATER MATCHER_SIZE_SMALLER MATCHER_SIZE_EQUAL
%token MATCHER_COLORLABEL MATCHER_NOT_COLORLABEL
%token MATCHER_IGNORE_THREAD MATCHER_NOT_IGNORE_THREAD
%token MATCHER_CHANGE_SCORE MATCHER_SET_SCORE
-%token MATCHER_STOP MATCHER_HIDE
+%token MATCHER_ADD_TO_ADDRESSBOOK
+%token MATCHER_STOP MATCHER_HIDE MATCHER_IGNORE
+%token MATCHER_SPAM MATCHER_NOT_SPAM
%start file
+%token MATCHER_ENABLED MATCHER_DISABLED
%token MATCHER_RULENAME
+%token MATCHER_ACCOUNT
%token <str> MATCHER_STRING
%token <str> MATCHER_SECTION
%token <str> MATCHER_INTEGER
;
instruction:
-name condition filtering MATCHER_EOL
+enabled name account condition filtering MATCHER_EOL
+| enabled name account condition filtering
+| enabled name condition filtering MATCHER_EOL
+| enabled name condition filtering
+| name condition filtering MATCHER_EOL
| name condition filtering
{
if (matcher_parse_op == MATCHER_PARSE_NO_EOL)
YYACCEPT;
else {
- matcher_parsererror("parse error a");
+ matcher_parsererror("parse error [no eol]");
+ YYERROR;
+ }
+}
+| enabled
+{
+ if (matcher_parse_op == MATCHER_PARSE_ENABLED)
+ YYACCEPT;
+ else {
+ matcher_parsererror("parse error [enabled]");
+ YYERROR;
+ }
+}
+| account
+{
+ if (matcher_parse_op == MATCHER_PARSE_ACCOUNT)
+ YYACCEPT;
+ else {
+ matcher_parsererror("parse error [account]");
YYERROR;
}
}
if (matcher_parse_op == MATCHER_PARSE_NAME)
YYACCEPT;
else {
- matcher_parsererror("parse error b");
+ matcher_parsererror("parse error [name]");
YYERROR;
}
}
if (matcher_parse_op == MATCHER_PARSE_CONDITION)
YYACCEPT;
else {
- matcher_parsererror("parse error c");
+ matcher_parsererror("parse error [condition]");
YYERROR;
}
}
if (matcher_parse_op == MATCHER_PARSE_FILTERING_ACTION)
YYACCEPT;
else {
- matcher_parsererror("parse error d");
+ matcher_parsererror("parse error [filtering action]");
YYERROR;
}
}
| MATCHER_EOL
;
+enabled:
+MATCHER_ENABLED
+{
+ enabled = TRUE;
+}
+| MATCHER_DISABLED
+{
+ enabled = FALSE;
+}
+;
+
name:
MATCHER_RULENAME MATCHER_STRING
{
}
;
+account:
+MATCHER_ACCOUNT MATCHER_INTEGER
+{
+ account_id = strtol($2, NULL, 10);
+}
+;
+
filtering:
filtering_action_list
{
- filtering = filteringprop_new(name, cond, action_list);
- g_free(name);
+ filtering = filteringprop_new(enabled, name, account_id, cond, action_list);
+ enabled = TRUE;
+ account_id = 0;
+ g_free(name);
name = NULL;
if (enable_compatibility) {
prefs_filtering = &filtering_rules;
{
match_type = MATCHTYPE_REGEXP;
}
-| MATCHER_ANY_IN_ADDRESSBOOK
-{
- match_type = MATCHTYPE_ANY_IN_ADDRESSBOOK;
-}
-| MATCHER_ALL_IN_ADDRESSBOOK
-{
- match_type = MATCHTYPE_ALL_IN_ADDRESSBOOK;
-}
;
condition:
criteria = MATCHCRITERIA_NOT_LOCKED;
prop = matcherprop_new(criteria, NULL, 0, NULL, 0);
}
+| MATCHER_SPAM
+{
+ gint criteria = 0;
+
+ criteria = MATCHCRITERIA_SPAM;
+ prop = matcherprop_new(criteria, NULL, 0, NULL, 0);
+}
+| MATCHER_NOT_SPAM
+{
+ gint criteria = 0;
+
+ criteria = MATCHCRITERIA_NOT_SPAM;
+ prop = matcherprop_new(criteria, NULL, 0, NULL, 0);
+}
| MATCHER_PARTIAL
{
gint criteria = 0;
criteria = MATCHCRITERIA_COLORLABEL;
value = strtol($2, NULL, 10);
if (value < 0) value = 0;
- else if (value > MAX_COLORLABELS) value = MAX_COLORLABELS;
+ else if (value > COLORLABELS) value = COLORLABELS;
prop = matcherprop_new(criteria, NULL, 0, NULL, value);
}
| MATCHER_NOT_COLORLABEL MATCHER_INTEGER
criteria = MATCHCRITERIA_NOT_COLORLABEL;
value = strtol($2, NULL, 0);
if (value < 0) value = 0;
- else if (value > MAX_COLORLABELS) value = MAX_COLORLABELS;
+ else if (value > COLORLABELS) value = COLORLABELS;
prop = matcherprop_new(criteria, NULL, 0, NULL, value);
}
| MATCHER_IGNORE_THREAD
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_HEADER;
expr = $2;
prop = matcherprop_new(criteria, header, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_NOT_HEADER;
expr = $2;
prop = matcherprop_new(criteria, header, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_HEADERS_PART;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_NOT_HEADERS_PART;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
}
-| MATCHER_MESSAGE match_type MATCHER_STRING
+| MATCHER_FOUND_IN_ADDRESSBOOK MATCHER_STRING
+{
+ header = g_strdup($2);
+} MATCHER_IN MATCHER_STRING
{
gint criteria = 0;
gchar *expr = NULL;
+ criteria = MATCHCRITERIA_FOUND_IN_ADDRESSBOOK;
+ expr = $2;
+ prop = matcherprop_new(criteria, header, match_type, expr, 0);
+ g_free(header);
+}
+| MATCHER_NOT_FOUND_IN_ADDRESSBOOK MATCHER_STRING
+{
+ header = g_strdup($2);
+} MATCHER_IN MATCHER_STRING
+{
+ gint criteria = 0;
+ gchar *expr = NULL;
+
+ criteria = MATCHCRITERIA_NOT_FOUND_IN_ADDRESSBOOK;
+ expr = $2;
+ prop = matcherprop_new(criteria, header, match_type, expr, 0);
+ g_free(header);
+}
+| MATCHER_MESSAGE match_type MATCHER_STRING
+{
+ gint criteria = 0;
+ gchar *expr = NULL;
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_MESSAGE;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_NOT_MESSAGE;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_BODY_PART;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_NOT_BODY_PART;
expr = $3;
prop = matcherprop_new(criteria, NULL, match_type, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_TEST;
expr = $2;
prop = matcherprop_new(criteria, NULL, 0, expr, 0);
{
gint criteria = 0;
gchar *expr = NULL;
-
+ matcher_is_fast = FALSE;
criteria = MATCHCRITERIA_NOT_TEST;
expr = $2;
prop = matcherprop_new(criteria, NULL, 0, expr, 0);
action_type = MATCHACTION_EXECUTE;
cmd = $2;
- action = filteringaction_new(action_type, 0, cmd, 0, 0);
+ action = filteringaction_new(action_type, 0, cmd, 0, 0, NULL);
}
| MATCHER_MOVE MATCHER_STRING
{
action_type = MATCHACTION_MOVE;
destination = $2;
- action = filteringaction_new(action_type, 0, destination, 0, 0);
+ action = filteringaction_new(action_type, 0, destination, 0, 0, NULL);
}
| MATCHER_COPY MATCHER_STRING
{
action_type = MATCHACTION_COPY;
destination = $2;
- action = filteringaction_new(action_type, 0, destination, 0, 0);
+ action = filteringaction_new(action_type, 0, destination, 0, 0, NULL);
}
| MATCHER_DELETE
{
gint action_type = 0;
action_type = MATCHACTION_DELETE;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_MARK
{
gint action_type = 0;
action_type = MATCHACTION_MARK;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_UNMARK
{
gint action_type = 0;
action_type = MATCHACTION_UNMARK;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_LOCK
{
gint action_type = 0;
action_type = MATCHACTION_LOCK;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_UNLOCK
{
gint action_type = 0;
action_type = MATCHACTION_UNLOCK;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_MARK_AS_READ
{
gint action_type = 0;
action_type = MATCHACTION_MARK_AS_READ;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_MARK_AS_UNREAD
{
gint action_type = 0;
action_type = MATCHACTION_MARK_AS_UNREAD;
- action = filteringaction_new(action_type, 0, NULL, 0, 0);
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
+}
+| MATCHER_MARK_AS_SPAM
+{
+ gint action_type = 0;
+
+ action_type = MATCHACTION_MARK_AS_SPAM;
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
+}
+| MATCHER_MARK_AS_HAM
+{
+ gint action_type = 0;
+
+ action_type = MATCHACTION_MARK_AS_HAM;
+ action = filteringaction_new(action_type, 0, NULL, 0, 0, NULL);
}
| MATCHER_FORWARD MATCHER_INTEGER MATCHER_STRING
{
account_id = strtol($2, NULL, 10);
destination = $3;
action = filteringaction_new(action_type,
- account_id, destination, 0, 0);
+ account_id, destination, 0, 0, NULL);
}
| MATCHER_FORWARD_AS_ATTACHMENT MATCHER_INTEGER MATCHER_STRING
{
account_id = strtol($2, NULL, 10);
destination = $3;
action = filteringaction_new(action_type,
- account_id, destination, 0, 0);
+ account_id, destination, 0, 0, NULL);
}
| MATCHER_REDIRECT MATCHER_INTEGER MATCHER_STRING
{
account_id = strtol($2, NULL, 10);
destination = $3;
action = filteringaction_new(action_type,
- account_id, destination, 0, 0);
+ account_id, destination, 0, 0, NULL);
}
| MATCHER_COLOR MATCHER_INTEGER
{
action_type = MATCHACTION_COLOR;
color = strtol($2, NULL, 10);
- action = filteringaction_new(action_type, 0, NULL, color, 0);
+ action = filteringaction_new(action_type, 0, NULL, color, 0, NULL);
}
| MATCHER_CHANGE_SCORE MATCHER_INTEGER
{
score = strtol($2, NULL, 10);
action = filteringaction_new(MATCHACTION_CHANGE_SCORE, 0,
- NULL, 0, score);
+ NULL, 0, score, NULL);
}
/* backward compatibility */
| MATCHER_SCORE MATCHER_INTEGER
score = strtol($2, NULL, 10);
action = filteringaction_new(MATCHACTION_CHANGE_SCORE, 0,
- NULL, 0, score);
+ NULL, 0, score, NULL);
}
| MATCHER_SET_SCORE MATCHER_INTEGER
{
score = strtol($2, NULL, 10);
action = filteringaction_new(MATCHACTION_SET_SCORE, 0,
- NULL, 0, score);
+ NULL, 0, score, NULL);
}
| MATCHER_HIDE
{
- action = filteringaction_new(MATCHACTION_HIDE, 0, NULL, 0, 0);
+ action = filteringaction_new(MATCHACTION_HIDE, 0, NULL, 0, 0, NULL);
+}
+| MATCHER_IGNORE
+{
+ action = filteringaction_new(MATCHACTION_IGNORE, 0, NULL, 0, 0, NULL);
+}
+| MATCHER_ADD_TO_ADDRESSBOOK MATCHER_STRING
+{
+ header = g_strdup($2);
+} MATCHER_STRING
+{
+ gchar *addressbook = NULL;
+ gint action_type = 0;
+
+ action_type = MATCHACTION_ADD_TO_ADDRESSBOOK;
+ addressbook = $2;
+ action = filteringaction_new(action_type, 0, addressbook, 0, 0, header);
+ g_free(header);
}
| MATCHER_STOP
{
- action = filteringaction_new(MATCHACTION_STOP, 0, NULL, 0, 0);
+ action = filteringaction_new(MATCHACTION_STOP, 0, NULL, 0, 0, NULL);
}
;