+%option nounput never-interactive
+
%{
+/*
+ * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
+ * 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
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
#include <string.h>
#include <glib.h>
+#include "codeconv.h"
+#include "matcher.h"
#include "matcher_parser_lex.h"
+
+#ifndef YYSTYPE
#include "matcher_parser_parse.h"
+#endif
#define MAX_STR_CONST 512
-#define YY_NO_UNPUT 1
-char string_buf[MAX_STR_CONST];
-char * string_buf_ptr;
+static char string_buf[MAX_STR_CONST];
+static char *string_buf_ptr;
static void add_char(char ch)
{
%x section
%%
+
+"in" return MATCHER_IN;
-"all" return MATCHER_ALL;
-"unread" return MATCHER_UNREAD;
-"~unread" return MATCHER_NOT_UNREAD;
-"new" return MATCHER_NEW;
-"~new" return MATCHER_NOT_NEW;
-"marked" return MATCHER_MARKED;
-"~marked" return MATCHER_NOT_MARKED;
-"deleted" return MATCHER_DELETED;
-"~deleted" return MATCHER_NOT_DELETED;
-"replied" return MATCHER_REPLIED;
-"~replied" return MATCHER_NOT_REPLIED;
-"forwarded" return MATCHER_FORWARDED;
-"~forwarded" return MATCHER_NOT_FORWARDED;
-"locked" return MATCHER_LOCKED;
-"~locked" return MATCHER_NOT_LOCKED;
-"colorlabel" return MATCHER_COLORLABEL;
-"~colorlabel" return MATCHER_NOT_COLORLABEL;
-"subject" return MATCHER_SUBJECT;
-"~subject" return MATCHER_NOT_SUBJECT;
-"from" return MATCHER_FROM;
-"~from" return MATCHER_NOT_FROM;
-"to" return MATCHER_TO;
-"~to" return MATCHER_NOT_TO;
-"cc" return MATCHER_CC;
-"~cc" return MATCHER_NOT_CC;
-"to_or_cc" return MATCHER_TO_OR_CC;
-"~to_or_cc" return MATCHER_NOT_TO_AND_NOT_CC;
-"age_greater" return MATCHER_AGE_GREATER;
-"age_lower" return MATCHER_AGE_LOWER;
-"newsgroups" return MATCHER_NEWSGROUPS;
-"~newsgroups" return MATCHER_NOT_NEWSGROUPS;
-"inreplyto" return MATCHER_INREPLYTO;
-"~inreplyto" return MATCHER_NOT_INREPLYTO;
-"references" return MATCHER_REFERENCES;
-"~references" return MATCHER_NOT_REFERENCES;
-"score_greater" return MATCHER_SCORE_GREATER;
-"score_lower" return MATCHER_SCORE_LOWER;
-"score_equal" return MATCHER_SCORE_EQUAL;
-"size_greater" return MATCHER_SIZE_GREATER;
-"size_smaller" return MATCHER_SIZE_SMALLER;
-"size_equal" return MATCHER_SIZE_EQUAL;
-"header" return MATCHER_HEADER;
-"~header" return MATCHER_NOT_HEADER;
-"headers_part" return MATCHER_HEADERS_PART;
-"~headers_part" return MATCHER_NOT_HEADERS_PART;
-"message" return MATCHER_MESSAGE;
-"~message" return MATCHER_NOT_MESSAGE;
-"body_part" return MATCHER_BODY_PART;
-"~body_part" return MATCHER_NOT_BODY_PART;
-"execute" return MATCHER_EXECUTE;
-"~execute" return MATCHER_NOT_EXECUTE;
-"matchcase" return MATCHER_MATCHCASE;
-"match" return MATCHER_MATCH;
-"regexpcase" return MATCHER_REGEXPCASE;
-"regexp" return MATCHER_REGEXP;
-"score" return MATCHER_SCORE;
-"move" return MATCHER_MOVE;
-"copy" return MATCHER_COPY;
-"delete" return MATCHER_DELETE;
-"mark" return MATCHER_MARK;
-"unmark" return MATCHER_UNMARK;
-"mark_as_read" return MATCHER_MARK_AS_READ;
-"mark_as_unread" return MATCHER_MARK_AS_UNREAD;
-"forward" return MATCHER_FORWARD;
-"forward_as_attachment" return MATCHER_FORWARD_AS_ATTACHMENT;
-"color" return MATCHER_COLOR;
-"redirect" return MATCHER_REDIRECT;
-"delete_on_server" return MATCHER_DELETE_ON_SERVER;
+ /*
+ * a keyword consists of alpha and underscore
+ * characters, possibly preceded by a tilde (~)
+ */
+
+(~|[a-z])[a-z_]* {
+ gint id;
+
+ if (-1 == (id = get_matchparser_tab_id(yytext))) {
+ REJECT;
+ } else
+ return id;
+ }
[ \t]+
"\n" return MATCHER_EOL;
"&" return MATCHER_AND;
BEGIN(string);
string_buf_ptr = string_buf;
}
- /* alfons - OK, the new attempt is to just swallow
- * *EVERYTHING* and make sure everything is escaped
- * when actually performing things. */
-<string>\\\" {
- /* take care of escaped \" because this means the
- * quote char should be skipped */
- add_char('\\');
- add_char('\"');
- }
<string>\" {
/* get out of the state: string ends. */
BEGIN(0);
*string_buf_ptr = '\0';
+ if (!g_utf8_validate(string_buf, -1, NULL)) {
+ gchar *tmp = conv_codeset_strdup(string_buf, conv_get_locale_charset_str(), CS_INTERNAL);
+ if (tmp) {
+ strcpy(string_buf, tmp);
+ g_free(tmp);
+ }
+ }
yylval.str = string_buf;
return MATCHER_STRING;
}
- /* put everything else in the output. */
+<string>\\. {
+ /* take care of quoted characters */
+ add_char(yytext[1]);
+ }
<string>. {
add_char(yytext[0]);
}
\[[^\[\]]*\] {
+ /* for section name in configuration file */
BEGIN(0);
yylval.str = yytext + 1;
yytext[strlen(yytext) - 1] = '\0';
yylval.str = yytext;
return MATCHER_INTEGER;
}
+rulename {
+ return MATCHER_RULENAME;
+ }
+disabled {
+ return MATCHER_DISABLED;
+ }
+account {
+ return MATCHER_ACCOUNT;
+ }
+enabled {
+ return MATCHER_ENABLED;
+ }
%%