3 * Copyright © 2008, 2009 Intel Corporation
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
12 * The above copyright notice and this permission notice (including the next
13 * paragraph) shall be included in all copies or substantial portions of the
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
25 #include "glsl_parser_extras.h"
26 #include "glsl_parser.h"
27 #include "symbol_table.h"
29 #define YY_USER_ACTION \
32 yylloc->first_column = yycolumn + 1; \
33 yylloc->first_line = yylineno + 1; \
39 %option bison-bridge bison-locations reentrant noyywrap
40 %option never-interactive
41 %option prefix="_mesa_glsl_"
42 %option extra-type="struct _mesa_glsl_parse_state *"
49 "/*" { yy_push_state(COMMENT, yyscanner); }
51 <COMMENT>[^*\n]*\n { yylineno++; yycolumn = 0; }
53 <COMMENT>"*"+[^*/\n]*\n { yylineno++; yycolumn = 0; }
54 <COMMENT>"*"+"/" { yy_pop_state(yyscanner); }
56 \/\/.*\n { yylineno++; yycolumn = 0; }
59 /* Preprocessor tokens. */
61 ^[ \t]*#[ \t]*version { BEGIN PP; return VERSION; }
62 ^[ \t]*#[ \t]*extension { BEGIN PP; return EXTENSION; }
63 ^[ \t]*#[ \t]*line { BEGIN PP; return LINE; }
64 ^[ \t]*#[ \t]*pragma { BEGIN PP; return PRAGMA; }
66 <PP>[_a-zA-Z][_a-zA-Z0-9]* {
67 yylval->identifier = strdup(yytext);
71 yylval->n = strtol(yytext, NULL, 10);
74 <PP>\n { BEGIN 0; yylineno++; yycolumn = 0; return EOL; }
76 \n { yylineno++; yycolumn = 0; }
78 attribute return ATTRIBUTE;
85 continue return CONTINUE;
91 discard return DISCARD;
106 mat2x2 return MAT2X2;
107 mat2x3 return MAT2X3;
108 mat2x4 return MAT2X4;
109 mat3x2 return MAT3X2;
110 mat3x3 return MAT3X3;
111 mat3x4 return MAT3X4;
112 mat4x2 return MAT4X2;
113 mat4x3 return MAT4X3;
114 mat4x4 return MAT4X4;
119 uniform return UNIFORM;
120 varying return VARYING;
121 centroid return CENTROID;
122 invariant return INVARIANT;
124 sampler1D return SAMPLER1D;
125 sampler2D return SAMPLER2D;
126 sampler3D return SAMPLER3D;
127 samplerCube return SAMPLERCUBE;
128 sampler1DShadow return SAMPLER1DSHADOW;
129 sampler2DShadow return SAMPLER2DSHADOW;
131 struct return STRUCT;
144 \*= return MUL_ASSIGN;
145 \/= return DIV_ASSIGN;
146 \+= return ADD_ASSIGN;
147 \%= return MOD_ASSIGN;
148 \<\<= return LEFT_ASSIGN;
149 >>= return RIGHT_ASSIGN;
150 &= return AND_ASSIGN;
151 ^= return XOR_ASSIGN;
152 \|= return OR_ASSIGN;
153 -= return SUB_ASSIGN;
156 yylval->n = strtol(yytext, NULL, 10);
160 yylval->n = strtol(yytext + 2, NULL, 16);
164 yylval->n = strtol(yytext + 2, NULL, 8);
168 [0-9]+\.[0-9]+([eE][+-]?[0-9]+)?[fF]? {
169 yylval->real = strtod(yytext, NULL);
170 return FLOATCONSTANT;
172 \.[0-9]+([eE][+-]?[0-9]+)?[fF]? {
173 yylval->real = strtod(yytext, NULL);
174 return FLOATCONSTANT;
176 [0-9]+\.([eE][+-]?[0-9]+)?[fF]? {
177 yylval->real = strtod(yytext, NULL);
178 return FLOATCONSTANT;
180 [0-9]+[eE][+-]?[0-9]+[fF]? {
181 yylval->real = strtod(yytext, NULL);
182 return FLOATCONSTANT;
195 /* Reserved words in GLSL 1.10. */
200 typedef return TYPEDEF;
201 template return TEMPLATE;
203 packed return PACKED;
205 switch return SWITCH;
206 default return DEFAULT;
207 inline return INLINE;
208 noinline return NOINLINE;
209 volatile return VOLATILE;
210 public return PUBLIC;
211 static return STATIC;
212 extern return EXTERN;
213 external return EXTERNAL;
214 interface return INTERFACE;
217 double return DOUBLE;
220 unsigned return UNSIGNED;
222 output return OUTPUT;
232 sampler2DRect return SAMPLER2DRECT;
233 sampler3DRect return SAMPLER3DRECT;
234 sampler2DRectShadow return SAMPLER2DRECTSHADOW;
235 sizeof return SIZEOF;
237 namespace return NAMESPACE;
240 /* Additional reserved words in GLSL 1.20. */
242 mediump return MEDIUMP;
244 precision return PRECISION;
246 [_a-zA-Z][_a-zA-Z0-9]* {
247 yylval->identifier = strdup(yytext);
249 if (_mesa_symbol_table_find_symbol(yyextra->symbols,
257 . { return yytext[0]; }
262 _mesa_glsl_lexer_ctor(struct _mesa_glsl_parse_state *state,
263 const char *string, size_t len)
265 yylex_init_extra(state, & state->scanner);
266 yy_scan_bytes(string, len, state->scanner);
270 _mesa_glsl_lexer_dtor(struct _mesa_glsl_parse_state *state)
272 yylex_destroy(state->scanner);