mesa/src/glsl/glcpp
Carl Worth 1d7e03e48e glcpp: Fix support for nested #ifdef and nested #ifndef
Previously, if the outer #ifdef/#ifndef evaluated to false, the inner
directive would not be parsed correctly, (the identifier as the subject
of the #ifdef/#ifndef would inadvertently be skipped along with the other
content correctly being skipped).

We fix this by setting the lexing_if state in each case here.

We also add a new test to the test suite to ensure that this case is tested.
2010-07-20 17:01:11 -07:00
..
tests glcpp: Fix support for nested #ifdef and nested #ifndef 2010-07-20 17:01:11 -07:00
.gitignore glsl2: Move the compiler to the subdirectory it will live in in Mesa. 2010-06-24 15:36:00 -07:00
glcpp-lex.l glcpp: Fix support for nested #ifdef and nested #ifndef 2010-07-20 17:01:11 -07:00
glcpp-parse.y glcpp: Fix use-after-free error from #undef directive. 2010-07-20 17:01:11 -07:00
glcpp.c glsl2: Conditionally define preprocessor tokens for optional extensions 2010-07-01 20:40:08 -07:00
glcpp.h glsl2: Conditionally define preprocessor tokens for optional extensions 2010-07-01 20:40:08 -07:00
Makefile.am glcpp: Delete copies of hash_table.c, hash_table.h, and other headers. 2010-07-20 17:01:11 -07:00
pp.c glsl2: Conditionally define preprocessor tokens for optional extensions 2010-07-01 20:40:08 -07:00
README glsl2: Move the compiler to the subdirectory it will live in in Mesa. 2010-06-24 15:36:00 -07:00
xtalloc.c glsl2: Move the compiler to the subdirectory it will live in in Mesa. 2010-06-24 15:36:00 -07:00

glcpp -- GLSL "C" preprocessor

This is a simple preprocessor designed to provide the preprocessing
needs of the GLSL language. The requirements for this preprocessor are
specified in the GLSL 1.30 specification availble from:

http://www.opengl.org/registry/doc/GLSLangSpec.Full.1.30.08.pdf

This specification is not precise on some semantics, (for example,
#define and #if), defining these merely "as is standard for C++
preprocessors". To fill in these details, I've been using the C99
standard (for which I had a convenient copy) as available from:

http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf

Known limitations
-----------------
Macro invocations cannot include embedded newlines.

The __LINE__, __FILE__, and __VERSION__ macros are not yet supported.

The argument of the 'defined' operator cannot yet include enclosing
parentheses.

The #error, #pragma, #extension, #version, and #line macros are not
yet supported.

A file that ends with a function-like macro name as the last
non-whitespace token will result in a parse error, (where it should be
passed through as is).