glcpp: Don't include the newline when discarding single-line comments
authorCarl Worth <cworth@cworth.org>
Wed, 18 Aug 2010 05:17:09 +0000 (22:17 -0700)
committerCarl Worth <cworth@cworth.org>
Wed, 18 Aug 2010 05:17:09 +0000 (22:17 -0700)
Matching the newline here meant having to do some redundant work here,
(incrementing line number, resetting column number, and returning a
NEWLINE token), that could otherwise simply be left to the existing rule
which matches a newline.

Worse, when the comment rule matches the newline as well, the parser
can lookahead and see a token for something that should actually be skipped.

For example, in a case like this:

#if 0 // comment here
fail
#else
win
#endif

Both fail and win appear in the output, (not that the condition is being
evaluated incorrectly---merely that one token after the comment's newline
was being lexed/parse regardless of the condition).

This commit fixes the above test case, (which is also remarkably similar
to 087-if-comments which now passes).

src/glsl/glcpp/glcpp-lex.l

index 9187926146aeeecad5d664dda9f73e3a46a2b1aa..a14e580ab1a674073c37c02954434158c713c050 100644 (file)
@@ -70,10 +70,7 @@ HEXADECIMAL_INTEGER  0[xX][0-9a-fA-F]+[uU]?
 %%
 
        /* Single-line comments */
-"//"[^\n]*\n {
-       yylineno++;
-       yycolumn = 0;
-       return NEWLINE;
+"//"[^\n]* {
 }
 
        /* Multi-line comments */