static MatcherList *cond;
static gint score = 0;
+static GSList *action_list = NULL;
static FilteringAction *action = NULL;
static FilteringProp *filtering;
static GSList **prefs_scoring = NULL;
static GSList **prefs_filtering = NULL;
+#if 0
static int matcher_parser_dialog = 0;
+#endif
+
+enum {
+ MATCHER_PARSE_NONE,
+ MATCHER_PARSE_NO_EOL,
+ MATCHER_PARSE_CONDITION,
+ MATCHER_PARSE_FILTERING_OR_SCORING,
+};
+
+static int matcher_parse_op = MATCHER_PARSE_NONE;
+
/* ******************************************************************** */
matcher_parserparse();
}
-FilteringProp *matcher_parser_get_filtering(gchar *str)
+FilteringProp *matcher_parser_get_filtering(const gchar *str)
{
void *bufstate;
/* bad coding to enable the sub-grammar matching
in yacc */
matcher_parserlineno = 1;
- matcher_parser_dialog = 1;
+ matcher_parse_op = MATCHER_PARSE_NO_EOL;
matcher_parserrestart(NULL);
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parser_switch_to_buffer(bufstate);
if (matcher_parserparse() != 0)
filtering = NULL;
- matcher_parser_dialog = 0;
+ matcher_parse_op = MATCHER_PARSE_NONE;
matcher_parser_delete_buffer(bufstate);
return filtering;
}
-ScoringProp *matcher_parser_get_scoring(gchar *str)
+ScoringProp *matcher_parser_get_scoring(const gchar *str)
{
void *bufstate;
/* bad coding to enable the sub-grammar matching
in yacc */
matcher_parserlineno = 1;
- matcher_parser_dialog = 1;
+ matcher_parse_op = MATCHER_PARSE_NO_EOL;
matcher_parserrestart(NULL);
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parser_switch_to_buffer(bufstate);
if (matcher_parserparse() != 0)
scoring = NULL;
- matcher_parser_dialog = 0;
+ matcher_parse_op = MATCHER_PARSE_NONE;
matcher_parser_delete_buffer(bufstate);
return scoring;
}
static gboolean check_quote_symetry(gchar *str)
{
- gchar *walk;
+ const gchar *walk;
int ret = 0;
if (str == NULL)
return !(ret % 2);
}
-MatcherList *matcher_parser_get_cond(gchar *str)
+MatcherList *matcher_parser_get_cond(const gchar *str)
{
void *bufstate;
/* bad coding to enable the sub-grammar matching
in yacc */
matcher_parserlineno = 1;
- matcher_parser_dialog = 1;
+ matcher_parse_op = MATCHER_PARSE_CONDITION;
matcher_parserrestart(NULL);
matcher_parser_init();
bufstate = matcher_parser_scan_string(str);
matcher_parserparse();
- matcher_parser_dialog = 0;
+ matcher_parse_op = MATCHER_PARSE_NONE;
matcher_parser_delete_buffer(bufstate);
return cond;
}
-MatcherProp *matcher_parser_get_prop(gchar *str)
+GSList *matcher_parser_get_action_list(const gchar *str)
+{
+ void *bufstate;
+
+ if (!check_quote_symetry(str)) {
+ action_list = NULL;
+ return action_list;
+ }
+
+ /* bad coding to enable the sub-grammar matching
+ in yacc */
+ matcher_parserlineno = 1;
+ matcher_parse_op = MATCHER_PARSE_FILTERING_OR_SCORING;
+ matcher_parserrestart(NULL);
+ matcher_parser_init();
+ bufstate = matcher_parser_scan_string(str);
+ matcher_parserparse();
+ matcher_parse_op = MATCHER_PARSE_NONE;
+ matcher_parser_delete_buffer(bufstate);
+ return action_list;
+}
+
+MatcherProp *matcher_parser_get_prop(const gchar *str)
{
MatcherList *list;
MatcherProp *prop;
%token MATCHER_NOT_MESSAGE MATCHER_BODY_PART MATCHER_NOT_BODY_PART
%token MATCHER_EXECUTE MATCHER_NOT_EXECUTE MATCHER_MATCHCASE MATCHER_MATCH
%token MATCHER_REGEXPCASE MATCHER_REGEXP MATCHER_SCORE MATCHER_MOVE
-%token MATCHER_COPY MATCHER_DELETE MATCHER_MARK MATCHER_UNMARK
+%token MATCHER_COPY MATCHER_DELETE MATCHER_MARK MATCHER_UNMARK MATCHER_LOCK MATCHER_UNLOCK
%token MATCHER_MARK_AS_READ MATCHER_MARK_AS_UNREAD MATCHER_FORWARD
%token MATCHER_FORWARD_AS_ATTACHMENT MATCHER_EOL MATCHER_STRING
%token MATCHER_OR MATCHER_AND
-%token MATCHER_COLOR MATCHER_SCORE_EQUAL MATCHER_REDIRECT MATCHER_DELETE_ON_SERVER
+%token MATCHER_COLOR MATCHER_SCORE_EQUAL MATCHER_REDIRECT
%token MATCHER_SIZE_GREATER MATCHER_SIZE_SMALLER MATCHER_SIZE_EQUAL
%token MATCHER_LOCKED MATCHER_NOT_LOCKED
%token MATCHER_COLORLABEL MATCHER_NOT_COLORLABEL
file:
{
- if (!matcher_parser_dialog) {
+ if (matcher_parse_op == MATCHER_PARSE_NONE) {
prefs_scoring = &global_scoring;
prefs_filtering = &global_processing;
}
file_line:
section_notification
-| instruction
+|
+{ action_list = NULL; }
+instruction
| error MATCHER_EOL
{
yyerrok;
gchar *folder = $1;
FolderItem *item = NULL;
- if (!matcher_parser_dialog) {
- item = folder_find_item_from_identifier(folder);
- if (item == NULL) {
+ if (matcher_parse_op == MATCHER_PARSE_NONE) {
+ if (!strcmp(folder, "global")) {
prefs_scoring = &global_scoring;
prefs_filtering = &global_processing;
- }
- else {
- prefs_scoring = &item->prefs->scoring;
- prefs_filtering = &item->prefs->processing;
+ } else {
+ item = folder_find_item_from_identifier(folder);
+ if (item != NULL) {
+ prefs_scoring = &item->prefs->scoring;
+ prefs_filtering = &item->prefs->processing;
+ } else {
+ prefs_scoring = NULL;
+ prefs_filtering = NULL;
+ }
}
}
}
;
instruction:
-condition end_instr_opt
-| MATCHER_EOL
-;
-
-end_instr_opt:
-filtering_or_scoring end_action
-|
+condition filtering_or_scoring MATCHER_EOL
+| condition filtering_or_scoring
{
- if (matcher_parser_dialog)
+ if (matcher_parse_op == MATCHER_PARSE_NO_EOL)
YYACCEPT;
else {
matcher_parsererror("parse error");
YYERROR;
}
}
-;
-
-end_action:
-MATCHER_EOL
-|
+| condition
+{
+ if (matcher_parse_op == MATCHER_PARSE_CONDITION)
+ YYACCEPT;
+ else {
+ matcher_parsererror("parse error");
+ YYERROR;
+ }
+}
+| filtering_action_list
{
- if (matcher_parser_dialog)
+ if (matcher_parse_op == MATCHER_PARSE_FILTERING_OR_SCORING)
YYACCEPT;
else {
matcher_parsererror("parse error");
YYERROR;
}
}
+| MATCHER_EOL
;
filtering_or_scoring:
-filtering_action
+filtering_action_list
{
- filtering = filteringprop_new(cond, action);
+ filtering = filteringprop_new(cond, action_list);
cond = NULL;
- action = NULL;
- if (!matcher_parser_dialog) {
+ action_list = NULL;
+ if ((matcher_parse_op == MATCHER_PARSE_NONE) && (prefs_filtering != NULL)) {
*prefs_filtering = g_slist_append(*prefs_filtering,
filtering);
filtering = NULL;
scoring = scoringprop_new(cond, score);
cond = NULL;
score = 0;
- if (!matcher_parser_dialog) {
+ if ((matcher_parse_op == MATCHER_PARSE_NONE)
+ && (prefs_scoring != NULL)) {
*prefs_scoring = g_slist_append(*prefs_scoring, scoring);
scoring = NULL;
}
}
;
+filtering_action_list:
+filtering_action_b filtering_action_list
+| filtering_action_b
+;
+
+filtering_action_b:
+filtering_action
+{
+ action_list = g_slist_append(action_list, action);
+ action = NULL;
+}
+;
+
match_type:
MATCHER_MATCHCASE
{
action_type = MATCHACTION_UNMARK;
action = filteringaction_new(action_type, 0, NULL, 0);
}
+| MATCHER_LOCK
+{
+ gint action_type = 0;
+
+ action_type = MATCHACTION_LOCK;
+ action = filteringaction_new(action_type, 0, NULL, 0);
+}
+| MATCHER_UNLOCK
+{
+ gint action_type = 0;
+
+ action_type = MATCHACTION_UNLOCK;
+ action = filteringaction_new(action_type, 0, NULL, 0);
+}
| MATCHER_MARK_AS_READ
{
gint action_type = 0;
color = atoi($2);
action = filteringaction_new(action_type, 0, NULL, color);
}
-| MATCHER_DELETE_ON_SERVER
-{
- gint action_type = 0;
- action_type = MATCHACTION_DELETE_ON_SERVER;
- action = filteringaction_new(action_type, 0, NULL, 0);
-}
| MATCHER_CHANGE_SCORE MATCHER_STRING
{
gint action_type = MATCHACTION_CHANGE_SCORE;