X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/ac9b0e954b1d3aed514a3bbd363da1514202af0f..07c0db18b4a795a3a35a4d98b3d001bfc7d4e1c1:/src/scan-gram.l
diff --git a/src/scan-gram.l b/src/scan-gram.l
index 0c12cbaa..73eb3e80 100644
--- a/src/scan-gram.l
+++ b/src/scan-gram.l
@@ -18,7 +18,7 @@
You should have received a copy of the GNU General Public License
along with this program. If not, see . */
-%option debug nodefault nounput noyywrap never-interactive
+%option debug nodefault noinput nounput noyywrap never-interactive
%option prefix="gram_" outfile="lex.yy.c"
%{
@@ -251,7 +251,7 @@ splice (\\[ \f\t\v]*\n)*
}
/* Characters. */
- "'" STRING_GROW; token_start = loc->start; BEGIN SC_ESCAPED_CHARACTER;
+ "'" token_start = loc->start; BEGIN SC_ESCAPED_CHARACTER;
/* Strings. */
"\"" token_start = loc->start; BEGIN SC_ESCAPED_STRING;
@@ -465,16 +465,18 @@ splice (\\[ \f\t\v]*\n)*
{
"'"|"\n" {
- STRING_GROW;
STRING_FINISH;
loc->start = token_start;
- val->character = last_string[1];
+ val->character = last_string[0];
{
/* FIXME: Eventually, make these errors. */
- size_t length = strlen (last_string);
- if (strlen (last_string) < 3)
- warn_at (*loc, _("empty character literal"));
- else if (strlen (last_string) > 3)
+ if (last_string[0] == '\0')
+ {
+ warn_at (*loc, _("empty character literal"));
+ /* '\0' seems dangerous even if we are about to complain. */
+ val->character = '\'';
+ }
+ else if (last_string[1] != '\0')
warn_at (*loc, _("extra characters in character literal"));
}
if (yytext[0] == '\n')
@@ -486,17 +488,17 @@ splice (\\[ \f\t\v]*\n)*
<> {
STRING_FINISH;
loc->start = token_start;
+ val->character = last_string[0];
{
- size_t length = strlen (last_string);
/* FIXME: Eventually, make these errors. */
- if (length < 2)
- warn_at (*loc, _("empty character literal"));
- else if (length > 2)
+ if (last_string[0] == '\0')
+ {
+ warn_at (*loc, _("empty character literal"));
+ /* '\0' seems dangerous even if we are about to complain. */
+ val->character = '\'';
+ }
+ else if (last_string[1] != '\0')
warn_at (*loc, _("extra characters in character literal"));
- if (length > 1)
- val->character = last_string[1];
- else
- val->character = last_string[0];
}
unexpected_eof (token_start, "'");
STRING_FREE;