[Mesa-dev] [Mesa-stable] [PATCH 04/15] glsl: Add preprocessor error condition for #else directive
Carl Worth
cworth at cworth.org
Wed Jun 11 20:00:31 PDT 2014
Carl Worth <cworth at cworth.org> writes:
> I'll poke around at the existing code to see why the garbage after #else
> is caught with #if 0, but not with #if 1.
The difference is fairly straightforward, but it's going to be tricky to
fix.
Currently, the parser has a production for HASH_ELSE and NEWLINE tokens
that looks roughly like this:
HASH_ELSE { change_skip_state(); } NEWLINE
That is, the production matches an "#else" followed immediately by a
newline, (without anything in between), but the mid-rule action causes
the lexer state to change. This means that in the following case:
#if 0
#else garbage
#endif
between the "#if 0" and the "#else", the lexer will be skipping any
non-preprocessor directives. But it will start lexing identifiers again
just in time to catch "garbage" which leads to the desired parse error.
But in the following case:
#if 1
#else garbage
#endif
Here, at the #else we are now switching from not skipping to skipping,
and since the switch happens immediately after the "#else", then the
text of "garbage" gets skipped (along with everything after it and
before the #endif).
We could move the skip switching to after the NEWLINE, (avoiding the
tricky mid-rule action), like so:
HASH_ELSE NEWLINE { change_skip_state(); }
But that would just switch the behavior, (so that the "#if 1" case would
flag the error, but the "#if 0" case would not).
I'm still mulling over a nice clean fix here. (Though I am used to the
fact that with the preprocessor, there's rarely a clean fix---always
more ugly state to communicate from the parser to the lexer.) If anyone
wants to experiment or offer an idea, I'll be happy for the help.
-Carl
--
carl.d.worth at intel.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 818 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20140611/08cc44f7/attachment.sig>
More information about the mesa-dev
mailing list