diff options
author | Michael Banack <bob5972 at gmail.com> | 2010-04-09 17:56:05 -0700 |
---|---|---|
committer | Matthias Andree <matthias.andree@gmx.de> | 2010-04-10 16:57:29 +0200 |
commit | 1c6fb40e79a1344c35dcc69b292f9b6913cd4e95 (patch) | |
tree | da8c00049d0caba2cedee47729249942d90d31ff | |
parent | a1fefd08e2722d93b6f776baa817e2d0d1044ee2 (diff) | |
download | fetchmail-1c6fb40e79a1344c35dcc69b292f9b6913cd4e95.tar.gz fetchmail-1c6fb40e79a1344c35dcc69b292f9b6913cd4e95.tar.bz2 fetchmail-1c6fb40e79a1344c35dcc69b292f9b6913cd4e95.zip |
Changed the lexer to copy string values out of yytext.
Fixes BerliOS bug #14257.
-rw-r--r-- | rcfile_l.l | 54 |
1 files changed, 41 insertions, 13 deletions
@@ -32,18 +32,36 @@ int prc_lineno = 1; %% \"[^\"]*\" { - yytext[yyleng-1] = '\0'; - escapes(yytext+1, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; + static char *in = NULL; + static size_t ins = 0; + + if ((size_t)yyleng + 1 > ins) { + ins = yyleng + 1; + in = (char *)xrealloc(in, ins); + } + memcpy(in, yytext, yyleng); + + in[yyleng-1] = '\0'; + escapes(in+1, in); + yyleng = strlen(in); + yylval.sval = in; SETSTATE(0); return STRING; } \'[^\']*\' { - yytext[yyleng-1] = '\0'; - escapes(yytext+1, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; + static char *in = NULL; + static size_t ins = 0; + + if ((size_t)yyleng + 1 > ins) { + ins = yyleng + 1; + in = (char *)xrealloc(in, ins); + } + memcpy(in, yytext, yyleng); + + in[yyleng-1] = '\0'; + escapes(in+1, in); + yyleng = strlen(in); + yylval.sval = in; SETSTATE(0); return STRING; } @@ -51,8 +69,8 @@ int prc_lineno = 1; "*" { BEGIN(0); return WILDCARD; } <NAME>[^=;:, \t\r\n]+ { - static char *in; - static size_t ins; + static char *in = NULL; + static size_t ins = 0; if ((size_t)yyleng + 1 > ins) { ins = yyleng + 1; @@ -220,9 +238,19 @@ options {/* EMPTY */} -?[0-9]+ { yylval.number = atoi(yytext); return NUMBER; } [^=;:, \t\r\n]+ { - escapes(yytext, yytext); - yyleng = strlen(yytext); - yylval.sval = yytext; + static char *in = NULL; + static size_t ins = 0; + + if ((size_t)yyleng + 1 > ins) { + ins = yyleng + 1; + in = (char *)xrealloc(in, ins); + } + memcpy(in, yytext, yyleng); + in[yyleng] = '\0'; + + escapes(in, in); + yyleng = strlen(in); + yylval.sval = in; return STRING; } |