X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=rcfile_l.l;h=7cbf12ed3c9beaedceb93cd161a85e192204b9f2;hb=87bcf29364c4640edb87cc2186b965d1a564d70c;hp=d40648d5c3762f08a3befa68652c2c46f0ff2dbc;hpb=a1fefd08e2722d93b6f776baa817e2d0d1044ee2;p=~andy%2Ffetchmail diff --git a/rcfile_l.l b/rcfile_l.l index d40648d5..7cbf12ed 100644 --- a/rcfile_l.l +++ b/rcfile_l.l @@ -5,12 +5,14 @@ * * For license terms, see the file COPYING in this directory. */ -#include #include "config.h" #include "fetchmail.h" +#include "xmalloc.h" #include "rcfile_y.h" +#include + int prc_lineno = 1; #ifdef LEXDEBUG @@ -31,39 +33,20 @@ int prc_lineno = 1; %% -\"[^\"]*\" { - yytext[yyleng-1] = '\0'; - escapes(yytext+1, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; - SETSTATE(0); - return STRING; - } +\"[^\"]*\" | \'[^\']*\' { - yytext[yyleng-1] = '\0'; - escapes(yytext+1, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; - SETSTATE(0); + char *in = xstrndup(yytext+1, yyleng-2); + escapes(in, in); + yylval.sval = in; + SETSTATE(0); return STRING; } -"*" { BEGIN(0); return WILDCARD; } - [^=;:, \t\r\n]+ { - static char *in; - static size_t ins; - - if ((size_t)yyleng + 1 > ins) { - ins = yyleng + 1; - in = (char *)xrealloc(in, ins); - } - memcpy(in, yytext, yyleng); - in[yyleng] = '\0'; + char *in = xstrdup(yytext); escapes(in, in); - yyleng = strlen(in); yylval.sval = in; - SETSTATE(0); + SETSTATE(0); return STRING; } @@ -97,9 +80,8 @@ preauth(enticate)? { SETSTATE(AUTH); return AUTHENTICATE; } auth(enticate)? { SETSTATE(AUTH); return AUTHENTICATE; } any { SETSTATE(0); yylval.proto = A_ANY; return AUTHTYPE;} gssapi { SETSTATE(0); yylval.proto = A_GSSAPI; return AUTHTYPE;} -kerberos(_v)?4 { SETSTATE(0); yylval.proto = A_KERBEROS_V4; return AUTHTYPE;} kerberos(_v)?5 { SETSTATE(0); yylval.proto = A_KERBEROS_V5; return AUTHTYPE;} -kerberos { SETSTATE(0); yylval.proto = A_KERBEROS_V4; return AUTHTYPE;} +kerberos { SETSTATE(0); yylval.proto = A_KERBEROS_V5; return AUTHTYPE;} ssh { SETSTATE(0); yylval.proto = A_SSH; return AUTHTYPE;} external { SETSTATE(0); yylval.proto = A_EXTERNAL; return AUTHTYPE;} (otp|opie) { SETSTATE(0); yylval.proto = A_OTP; return AUTHTYPE;} @@ -107,6 +89,7 @@ cram(-md5)? { SETSTATE(0); yylval.proto = A_CRAM_MD5; return AUTHTYPE;} msn { SETSTATE(0); yylval.proto = A_MSN; return AUTHTYPE;} ntlm { SETSTATE(0); yylval.proto = A_NTLM; return AUTHTYPE;} password { SETSTATE(0); yylval.proto = A_PASSWORD; return AUTHTYPE;} +apop { SETSTATE(0); yylval.proto = A_APOP; return AUTHTYPE;} timeout { return TIMEOUT;} envelope { return ENVELOPE; } qvirtual { return QVIRTUAL; } @@ -116,8 +99,15 @@ esmtppassword { return ESMTPPASSWORD; } bad-header { return BADHEADER; } accept { return ACCEPT; } reject { return REJECT_; } +retrieve-error { return RETRIEVEERROR; } +abort { return ABORT; } +continue { return CONTINUE; } +markseen { return MARKSEEN; } user(name)? {SETSTATE(NAME); return USERNAME; } +pwmd_socket { return PWMD_SOCKET; } +pwmd_file { return PWMD_FILE; } +pinentry_timeout { return PINENTRY_TIMEOUT; } pass(word)? {SETSTATE(NAME); return PASSWORD; } folder(s)? { return FOLDER; } smtp(host)? { return SMTPHOST; } @@ -190,6 +180,7 @@ sslkey { return SSLKEY; } sslcert { return SSLCERT; } sslproto { return SSLPROTO; } sslcertck { return SSLCERTCK; } +sslcertfile { return SSLCERTFILE; } sslcertpath { return SSLCERTPATH; } sslcommonname { return SSLCOMMONNAME; } sslfingerprint { return SSLFINGERPRINT; } @@ -205,14 +196,11 @@ options {/* EMPTY */} [;:,] {/* EMPTY */} (auto)|(AUTO) { yylval.proto = P_AUTO; return PROTO; } -(pop2)|(POP2) { yylval.proto = P_POP2; return PROTO; } -(sdps)|(SDPS) { return SDPS; } +(sdps)|(SDPS) { return SDPS; } (pop3)|(POP3) { yylval.proto = P_POP3; return PROTO; } (imap)|(IMAP) { yylval.proto = P_IMAP; return PROTO; } -(apop)|(APOP) { yylval.proto = P_APOP; return PROTO; } -(rpop)|(RPOP) { yylval.proto = P_RPOP; return PROTO; } -(etrn)|(ETRN) { yylval.proto = P_ETRN; return PROTO; } -(odmr)|(ODMR) { yylval.proto = P_ODMR; return PROTO; } +(etrn)|(ETRN) { yylval.proto = P_ETRN; return PROTO; } +(odmr)|(ODMR) { yylval.proto = P_ODMR; return PROTO; } (kpop)|(KPOP) { return KPOP; } (#.*)?\\?\n { prc_lineno++; } /* newline is ignored */ @@ -220,9 +208,9 @@ options {/* EMPTY */} -?[0-9]+ { yylval.number = atoi(yytext); return NUMBER; } [^=;:, \t\r\n]+ { - escapes(yytext, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; + char *in = xstrdup(yytext); + escapes(in, in); + yylval.sval = in; return STRING; }