2010-02-22 13:19:34 -08:00
|
|
|
%{
|
|
|
|
/*
|
|
|
|
* Copyright © 2008, 2009 Intel Corporation
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
|
|
* to deal in the Software without restriction, including without limitation
|
|
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice (including the next
|
|
|
|
* paragraph) shall be included in all copies or substantial portions of the
|
|
|
|
* Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
* DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
2010-04-26 14:19:49 -07:00
|
|
|
#include <ctype.h>
|
2010-12-13 08:41:08 -07:00
|
|
|
#include "strtod.h"
|
2010-02-22 13:19:34 -08:00
|
|
|
#include "ast.h"
|
|
|
|
#include "glsl_parser_extras.h"
|
2010-02-25 17:17:23 -08:00
|
|
|
#include "glsl_parser.h"
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
#define YY_USER_ACTION \
|
|
|
|
do { \
|
|
|
|
yylloc->source = 0; \
|
|
|
|
yylloc->first_column = yycolumn + 1; \
|
|
|
|
yylloc->first_line = yylineno + 1; \
|
|
|
|
yycolumn += yyleng; \
|
|
|
|
} while(0);
|
|
|
|
|
2010-07-07 11:40:51 -07:00
|
|
|
#define YY_USER_INIT yylineno = 0; yycolumn = 0;
|
|
|
|
|
2010-11-13 23:09:43 -08:00
|
|
|
#define IS_UINT (yytext[yyleng - 1] == 'u' || yytext[yyleng - 1] == 'U')
|
|
|
|
|
2010-11-13 20:32:59 -08:00
|
|
|
/* A macro for handling reserved words and keywords across language versions.
|
|
|
|
*
|
|
|
|
* Certain words start out as identifiers, become reserved words in
|
|
|
|
* later language revisions, and finally become language keywords.
|
|
|
|
*
|
|
|
|
* For example, consider the following lexer rule:
|
|
|
|
* samplerBuffer KEYWORD(130, 140, SAMPLERBUFFER)
|
|
|
|
*
|
|
|
|
* This means that "samplerBuffer" will be treated as:
|
|
|
|
* - a keyword (SAMPLERBUFFER token) ...in GLSL >= 1.40
|
|
|
|
* - a reserved word - error ...in GLSL >= 1.30
|
|
|
|
* - an identifier ...in GLSL < 1.30
|
|
|
|
*/
|
|
|
|
#define KEYWORD(reserved_version, allowed_version, token) \
|
2010-08-11 17:01:31 -07:00
|
|
|
do { \
|
2010-11-13 20:32:59 -08:00
|
|
|
if (yyextra->language_version >= allowed_version) { \
|
2010-08-11 17:01:31 -07:00
|
|
|
return token; \
|
2010-11-13 20:32:59 -08:00
|
|
|
} else if (yyextra->language_version >= reserved_version) { \
|
2010-08-11 17:01:31 -07:00
|
|
|
_mesa_glsl_error(yylloc, yyextra, \
|
|
|
|
"Illegal use of reserved word `%s'", yytext); \
|
|
|
|
return ERROR_TOK; \
|
2010-11-13 20:32:59 -08:00
|
|
|
} else { \
|
|
|
|
yylval->identifier = strdup(yytext); \
|
|
|
|
return IDENTIFIER; \
|
2010-08-11 17:01:31 -07:00
|
|
|
} \
|
|
|
|
} while (0)
|
2010-11-13 20:32:59 -08:00
|
|
|
|
|
|
|
/* The ES macro can be used in KEYWORD checks:
|
|
|
|
*
|
|
|
|
* word KEYWORD(110 || ES, 400, TOKEN)
|
|
|
|
* ...means the word is reserved in GLSL ES 1.00, while
|
|
|
|
*
|
|
|
|
* word KEYWORD(110, 130 || ES, TOKEN)
|
|
|
|
* ...means the word is a legal keyword in GLSL ES 1.00.
|
|
|
|
*/
|
|
|
|
#define ES yyextra->es_shader
|
2010-02-22 13:19:34 -08:00
|
|
|
%}
|
|
|
|
|
|
|
|
%option bison-bridge bison-locations reentrant noyywrap
|
2010-04-29 17:53:26 -07:00
|
|
|
%option nounput noyy_top_state
|
2010-02-22 13:19:34 -08:00
|
|
|
%option never-interactive
|
|
|
|
%option prefix="_mesa_glsl_"
|
|
|
|
%option extra-type="struct _mesa_glsl_parse_state *"
|
|
|
|
|
2010-08-30 11:58:04 -07:00
|
|
|
%x PP PRAGMA
|
2010-02-22 13:19:34 -08:00
|
|
|
|
2010-04-26 14:19:49 -07:00
|
|
|
DEC_INT [1-9][0-9]*
|
|
|
|
HEX_INT 0[xX][0-9a-fA-F]+
|
|
|
|
OCT_INT 0[0-7]*
|
|
|
|
INT ({DEC_INT}|{HEX_INT}|{OCT_INT})
|
|
|
|
SPC [ \t]*
|
|
|
|
SPCP [ \t]+
|
|
|
|
HASH ^{SPC}#{SPC}
|
2010-02-22 13:19:34 -08:00
|
|
|
%%
|
|
|
|
|
|
|
|
[ \r\t]+ ;
|
|
|
|
|
|
|
|
/* Preprocessor tokens. */
|
|
|
|
^[ \t]*#[ \t]*$ ;
|
|
|
|
^[ \t]*#[ \t]*version { BEGIN PP; return VERSION; }
|
|
|
|
^[ \t]*#[ \t]*extension { BEGIN PP; return EXTENSION; }
|
2010-04-26 14:19:49 -07:00
|
|
|
{HASH}line{SPCP}{INT}{SPCP}{INT}{SPC}$ {
|
|
|
|
/* Eat characters until the first digit is
|
|
|
|
* encountered
|
|
|
|
*/
|
|
|
|
char *ptr = yytext;
|
|
|
|
while (!isdigit(*ptr))
|
|
|
|
ptr++;
|
|
|
|
|
|
|
|
/* Subtract one from the line number because
|
|
|
|
* yylineno is zero-based instead of
|
|
|
|
* one-based.
|
|
|
|
*/
|
|
|
|
yylineno = strtol(ptr, &ptr, 0) - 1;
|
|
|
|
yylloc->source = strtol(ptr, NULL, 0);
|
|
|
|
}
|
|
|
|
{HASH}line{SPCP}{INT}{SPC}$ {
|
|
|
|
/* Eat characters until the first digit is
|
|
|
|
* encountered
|
|
|
|
*/
|
|
|
|
char *ptr = yytext;
|
|
|
|
while (!isdigit(*ptr))
|
|
|
|
ptr++;
|
|
|
|
|
|
|
|
/* Subtract one from the line number because
|
|
|
|
* yylineno is zero-based instead of
|
|
|
|
* one-based.
|
|
|
|
*/
|
|
|
|
yylineno = strtol(ptr, &ptr, 0) - 1;
|
|
|
|
}
|
2010-08-30 11:58:04 -07:00
|
|
|
^{SPC}#{SPC}pragma{SPCP}debug{SPC}\({SPC}on{SPC}\) {
|
|
|
|
BEGIN PP;
|
|
|
|
return PRAGMA_DEBUG_ON;
|
|
|
|
}
|
|
|
|
^{SPC}#{SPC}pragma{SPCP}debug{SPC}\({SPC}off{SPC}\) {
|
|
|
|
BEGIN PP;
|
|
|
|
return PRAGMA_DEBUG_OFF;
|
|
|
|
}
|
|
|
|
^{SPC}#{SPC}pragma{SPCP}optimize{SPC}\({SPC}on{SPC}\) {
|
|
|
|
BEGIN PP;
|
|
|
|
return PRAGMA_OPTIMIZE_ON;
|
|
|
|
}
|
|
|
|
^{SPC}#{SPC}pragma{SPCP}optimize{SPC}\({SPC}off{SPC}\) {
|
|
|
|
BEGIN PP;
|
|
|
|
return PRAGMA_OPTIMIZE_OFF;
|
|
|
|
}
|
2011-01-06 10:49:56 -08:00
|
|
|
^{SPC}#{SPC}pragma{SPCP}STDGL{SPCP}invariant{SPC}\({SPC}all{SPC}\) {
|
|
|
|
BEGIN PP;
|
|
|
|
return PRAGMA_INVARIANT_ALL;
|
|
|
|
}
|
2010-08-30 11:58:04 -07:00
|
|
|
^{SPC}#{SPC}pragma{SPCP} { BEGIN PRAGMA; }
|
|
|
|
|
|
|
|
<PRAGMA>\n { BEGIN 0; yylineno++; yycolumn = 0; }
|
|
|
|
<PRAGMA>. { }
|
|
|
|
|
2010-04-07 13:43:52 -07:00
|
|
|
<PP>\/\/[^\n]* { }
|
2010-04-07 14:49:59 -07:00
|
|
|
<PP>[ \t\r]* { }
|
2010-02-22 13:19:34 -08:00
|
|
|
<PP>: return COLON;
|
|
|
|
<PP>[_a-zA-Z][_a-zA-Z0-9]* {
|
|
|
|
yylval->identifier = strdup(yytext);
|
|
|
|
return IDENTIFIER;
|
|
|
|
}
|
|
|
|
<PP>[1-9][0-9]* {
|
|
|
|
yylval->n = strtol(yytext, NULL, 10);
|
|
|
|
return INTCONSTANT;
|
|
|
|
}
|
|
|
|
<PP>\n { BEGIN 0; yylineno++; yycolumn = 0; return EOL; }
|
|
|
|
|
|
|
|
\n { yylineno++; yycolumn = 0; }
|
|
|
|
|
|
|
|
attribute return ATTRIBUTE;
|
2010-06-30 16:40:47 -07:00
|
|
|
const return CONST_TOK;
|
2010-08-13 09:23:54 -07:00
|
|
|
bool return BOOL_TOK;
|
|
|
|
float return FLOAT_TOK;
|
|
|
|
int return INT_TOK;
|
2010-11-13 20:32:59 -08:00
|
|
|
uint KEYWORD(130, 130, UINT_TOK);
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
break return BREAK;
|
|
|
|
continue return CONTINUE;
|
|
|
|
do return DO;
|
|
|
|
while return WHILE;
|
|
|
|
else return ELSE;
|
|
|
|
for return FOR;
|
|
|
|
if return IF;
|
|
|
|
discard return DISCARD;
|
|
|
|
return return RETURN;
|
|
|
|
|
|
|
|
bvec2 return BVEC2;
|
|
|
|
bvec3 return BVEC3;
|
|
|
|
bvec4 return BVEC4;
|
|
|
|
ivec2 return IVEC2;
|
|
|
|
ivec3 return IVEC3;
|
|
|
|
ivec4 return IVEC4;
|
2010-11-13 20:32:59 -08:00
|
|
|
uvec2 KEYWORD(130, 130, UVEC2);
|
|
|
|
uvec3 KEYWORD(130, 130, UVEC3);
|
|
|
|
uvec4 KEYWORD(130, 130, UVEC4);
|
2010-02-22 13:19:34 -08:00
|
|
|
vec2 return VEC2;
|
|
|
|
vec3 return VEC3;
|
|
|
|
vec4 return VEC4;
|
2010-08-13 09:26:01 -07:00
|
|
|
mat2 return MAT2X2;
|
|
|
|
mat3 return MAT3X3;
|
|
|
|
mat4 return MAT4X4;
|
2010-11-13 20:32:59 -08:00
|
|
|
mat2x2 KEYWORD(120, 120, MAT2X2);
|
|
|
|
mat2x3 KEYWORD(120, 120, MAT2X3);
|
|
|
|
mat2x4 KEYWORD(120, 120, MAT2X4);
|
|
|
|
mat3x2 KEYWORD(120, 120, MAT3X2);
|
|
|
|
mat3x3 KEYWORD(120, 120, MAT3X3);
|
|
|
|
mat3x4 KEYWORD(120, 120, MAT3X4);
|
|
|
|
mat4x2 KEYWORD(120, 120, MAT4X2);
|
|
|
|
mat4x3 KEYWORD(120, 120, MAT4X3);
|
|
|
|
mat4x4 KEYWORD(120, 120, MAT4X4);
|
2010-02-22 13:19:34 -08:00
|
|
|
|
2010-08-13 09:23:54 -07:00
|
|
|
in return IN_TOK;
|
|
|
|
out return OUT_TOK;
|
|
|
|
inout return INOUT_TOK;
|
2010-02-22 13:19:34 -08:00
|
|
|
uniform return UNIFORM;
|
|
|
|
varying return VARYING;
|
2010-11-13 20:32:59 -08:00
|
|
|
centroid KEYWORD(120, 120, CENTROID);
|
|
|
|
invariant KEYWORD(120 || ES, 120 || ES, INVARIANT);
|
|
|
|
flat KEYWORD(130 || ES, 130, FLAT);
|
|
|
|
smooth KEYWORD(130, 130, SMOOTH);
|
|
|
|
noperspective KEYWORD(130, 130, NOPERSPECTIVE);
|
2010-06-18 18:36:51 -07:00
|
|
|
|
2010-02-22 13:19:34 -08:00
|
|
|
sampler1D return SAMPLER1D;
|
|
|
|
sampler2D return SAMPLER2D;
|
|
|
|
sampler3D return SAMPLER3D;
|
|
|
|
samplerCube return SAMPLERCUBE;
|
2010-11-13 22:02:09 -08:00
|
|
|
sampler1DArray KEYWORD(130, 130, SAMPLER1DARRAY);
|
|
|
|
sampler2DArray KEYWORD(130, 130, SAMPLER2DARRAY);
|
2010-02-22 13:19:34 -08:00
|
|
|
sampler1DShadow return SAMPLER1DSHADOW;
|
|
|
|
sampler2DShadow return SAMPLER2DSHADOW;
|
2010-11-13 22:02:09 -08:00
|
|
|
samplerCubeShadow KEYWORD(130, 130, SAMPLERCUBESHADOW);
|
|
|
|
sampler1DArrayShadow KEYWORD(130, 130, SAMPLER1DARRAYSHADOW);
|
|
|
|
sampler2DArrayShadow KEYWORD(130, 130, SAMPLER2DARRAYSHADOW);
|
|
|
|
isampler1D KEYWORD(130, 130, ISAMPLER1D);
|
|
|
|
isampler2D KEYWORD(130, 130, ISAMPLER2D);
|
|
|
|
isampler3D KEYWORD(130, 130, ISAMPLER3D);
|
|
|
|
isamplerCube KEYWORD(130, 130, ISAMPLERCUBE);
|
|
|
|
isampler1DArray KEYWORD(130, 130, ISAMPLER1DARRAY);
|
|
|
|
isampler2DArray KEYWORD(130, 130, ISAMPLER2DARRAY);
|
|
|
|
usampler1D KEYWORD(130, 130, USAMPLER1D);
|
|
|
|
usampler2D KEYWORD(130, 130, USAMPLER2D);
|
|
|
|
usampler3D KEYWORD(130, 130, USAMPLER3D);
|
|
|
|
usamplerCube KEYWORD(130, 130, USAMPLERCUBE);
|
|
|
|
usampler1DArray KEYWORD(130, 130, USAMPLER1DARRAY);
|
|
|
|
usampler2DArray KEYWORD(130, 130, USAMPLER2DARRAY);
|
|
|
|
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
struct return STRUCT;
|
2010-08-13 09:23:54 -07:00
|
|
|
void return VOID_TOK;
|
2010-02-22 13:19:34 -08:00
|
|
|
|
2010-06-30 17:30:03 -07:00
|
|
|
layout {
|
|
|
|
if ((yyextra->language_version >= 140)
|
2011-01-27 01:40:14 -08:00
|
|
|
|| yyextra->AMD_conservative_depth_enable
|
2010-10-05 17:00:31 -07:00
|
|
|
|| yyextra->ARB_explicit_attrib_location_enable
|
2010-06-30 17:30:03 -07:00
|
|
|
|| (yyextra->ARB_fragment_coord_conventions_enable)){
|
|
|
|
return LAYOUT_TOK;
|
|
|
|
} else {
|
|
|
|
yylval->identifier = strdup(yytext);
|
|
|
|
return IDENTIFIER;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-02-22 13:19:34 -08:00
|
|
|
\+\+ return INC_OP;
|
|
|
|
-- return DEC_OP;
|
|
|
|
\<= return LE_OP;
|
|
|
|
>= return GE_OP;
|
|
|
|
== return EQ_OP;
|
|
|
|
!= return NE_OP;
|
|
|
|
&& return AND_OP;
|
|
|
|
\|\| return OR_OP;
|
|
|
|
"^^" return XOR_OP;
|
2010-10-08 16:12:24 -07:00
|
|
|
"<<" return LEFT_OP;
|
|
|
|
">>" return RIGHT_OP;
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
\*= return MUL_ASSIGN;
|
|
|
|
\/= return DIV_ASSIGN;
|
|
|
|
\+= return ADD_ASSIGN;
|
|
|
|
\%= return MOD_ASSIGN;
|
|
|
|
\<\<= return LEFT_ASSIGN;
|
|
|
|
>>= return RIGHT_ASSIGN;
|
|
|
|
&= return AND_ASSIGN;
|
2010-10-15 14:44:28 -07:00
|
|
|
"^=" return XOR_ASSIGN;
|
2010-02-22 13:19:34 -08:00
|
|
|
\|= return OR_ASSIGN;
|
|
|
|
-= return SUB_ASSIGN;
|
|
|
|
|
2010-11-13 23:09:43 -08:00
|
|
|
[1-9][0-9]*[uU]? {
|
2010-02-22 13:19:34 -08:00
|
|
|
yylval->n = strtol(yytext, NULL, 10);
|
2010-11-13 23:09:43 -08:00
|
|
|
return IS_UINT ? UINTCONSTANT : INTCONSTANT;
|
2010-02-22 13:19:34 -08:00
|
|
|
}
|
2010-11-13 23:09:43 -08:00
|
|
|
0[xX][0-9a-fA-F]+[uU]? {
|
2010-02-22 13:19:34 -08:00
|
|
|
yylval->n = strtol(yytext + 2, NULL, 16);
|
2010-11-13 23:09:43 -08:00
|
|
|
return IS_UINT ? UINTCONSTANT : INTCONSTANT;
|
2010-02-22 13:19:34 -08:00
|
|
|
}
|
2010-11-13 23:09:43 -08:00
|
|
|
0[0-7]*[uU]? {
|
2010-07-19 11:52:54 -07:00
|
|
|
yylval->n = strtol(yytext, NULL, 8);
|
2010-11-13 23:09:43 -08:00
|
|
|
return IS_UINT ? UINTCONSTANT : INTCONSTANT;
|
2010-02-22 13:19:34 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
[0-9]+\.[0-9]+([eE][+-]?[0-9]+)?[fF]? {
|
2010-12-13 08:41:08 -07:00
|
|
|
yylval->real = glsl_strtod(yytext, NULL);
|
2010-02-22 13:19:34 -08:00
|
|
|
return FLOATCONSTANT;
|
|
|
|
}
|
|
|
|
\.[0-9]+([eE][+-]?[0-9]+)?[fF]? {
|
2010-12-13 08:41:08 -07:00
|
|
|
yylval->real = glsl_strtod(yytext, NULL);
|
2010-02-22 13:19:34 -08:00
|
|
|
return FLOATCONSTANT;
|
|
|
|
}
|
|
|
|
[0-9]+\.([eE][+-]?[0-9]+)?[fF]? {
|
2010-12-13 08:41:08 -07:00
|
|
|
yylval->real = glsl_strtod(yytext, NULL);
|
2010-02-22 13:19:34 -08:00
|
|
|
return FLOATCONSTANT;
|
|
|
|
}
|
|
|
|
[0-9]+[eE][+-]?[0-9]+[fF]? {
|
2010-12-13 08:41:08 -07:00
|
|
|
yylval->real = glsl_strtod(yytext, NULL);
|
2010-02-22 13:19:34 -08:00
|
|
|
return FLOATCONSTANT;
|
|
|
|
}
|
2010-08-02 11:26:43 -07:00
|
|
|
[0-9]+[fF] {
|
2010-12-13 08:41:08 -07:00
|
|
|
yylval->real = glsl_strtod(yytext, NULL);
|
2010-08-02 11:26:43 -07:00
|
|
|
return FLOATCONSTANT;
|
|
|
|
}
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
true {
|
|
|
|
yylval->n = 1;
|
|
|
|
return BOOLCONSTANT;
|
|
|
|
}
|
|
|
|
false {
|
|
|
|
yylval->n = 0;
|
|
|
|
return BOOLCONSTANT;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Reserved words in GLSL 1.10. */
|
2010-11-13 20:32:59 -08:00
|
|
|
asm KEYWORD(110 || ES, 999, ASM);
|
|
|
|
class KEYWORD(110 || ES, 999, CLASS);
|
|
|
|
union KEYWORD(110 || ES, 999, UNION);
|
|
|
|
enum KEYWORD(110 || ES, 999, ENUM);
|
|
|
|
typedef KEYWORD(110 || ES, 999, TYPEDEF);
|
|
|
|
template KEYWORD(110 || ES, 999, TEMPLATE);
|
|
|
|
this KEYWORD(110 || ES, 999, THIS);
|
|
|
|
packed KEYWORD(110 || ES, 999, PACKED_TOK);
|
|
|
|
goto KEYWORD(110 || ES, 999, GOTO);
|
|
|
|
switch KEYWORD(110 || ES, 130, SWITCH);
|
|
|
|
default KEYWORD(110 || ES, 130, DEFAULT);
|
|
|
|
inline KEYWORD(110 || ES, 999, INLINE_TOK);
|
|
|
|
noinline KEYWORD(110 || ES, 999, NOINLINE);
|
|
|
|
volatile KEYWORD(110 || ES, 999, VOLATILE);
|
|
|
|
public KEYWORD(110 || ES, 999, PUBLIC_TOK);
|
|
|
|
static KEYWORD(110 || ES, 999, STATIC);
|
|
|
|
extern KEYWORD(110 || ES, 999, EXTERN);
|
|
|
|
external KEYWORD(110 || ES, 999, EXTERNAL);
|
|
|
|
interface KEYWORD(110 || ES, 999, INTERFACE);
|
|
|
|
long KEYWORD(110 || ES, 999, LONG_TOK);
|
|
|
|
short KEYWORD(110 || ES, 999, SHORT_TOK);
|
|
|
|
double KEYWORD(110 || ES, 400, DOUBLE_TOK);
|
|
|
|
half KEYWORD(110 || ES, 999, HALF);
|
|
|
|
fixed KEYWORD(110 || ES, 999, FIXED_TOK);
|
|
|
|
unsigned KEYWORD(110 || ES, 999, UNSIGNED);
|
|
|
|
input KEYWORD(110 || ES, 999, INPUT_TOK);
|
|
|
|
output KEYWORD(110 || ES, 999, OUTPUT);
|
|
|
|
hvec2 KEYWORD(110 || ES, 999, HVEC2);
|
|
|
|
hvec3 KEYWORD(110 || ES, 999, HVEC3);
|
|
|
|
hvec4 KEYWORD(110 || ES, 999, HVEC4);
|
|
|
|
dvec2 KEYWORD(110 || ES, 400, DVEC2);
|
|
|
|
dvec3 KEYWORD(110 || ES, 400, DVEC3);
|
|
|
|
dvec4 KEYWORD(110 || ES, 400, DVEC4);
|
|
|
|
fvec2 KEYWORD(110 || ES, 999, FVEC2);
|
|
|
|
fvec3 KEYWORD(110 || ES, 999, FVEC3);
|
|
|
|
fvec4 KEYWORD(110 || ES, 999, FVEC4);
|
2010-02-22 13:19:34 -08:00
|
|
|
sampler2DRect return SAMPLER2DRECT;
|
2010-11-13 20:32:59 -08:00
|
|
|
sampler3DRect KEYWORD(110 || ES, 999, SAMPLER3DRECT);
|
2010-02-22 13:19:34 -08:00
|
|
|
sampler2DRectShadow return SAMPLER2DRECTSHADOW;
|
2010-11-13 20:32:59 -08:00
|
|
|
sizeof KEYWORD(110 || ES, 999, SIZEOF);
|
|
|
|
cast KEYWORD(110 || ES, 999, CAST);
|
|
|
|
namespace KEYWORD(110 || ES, 999, NAMESPACE);
|
|
|
|
using KEYWORD(110 || ES, 999, USING);
|
2010-02-22 13:19:34 -08:00
|
|
|
|
|
|
|
/* Additional reserved words in GLSL 1.20. */
|
2010-11-13 20:32:59 -08:00
|
|
|
lowp KEYWORD(120, 130 || ES, LOWP);
|
|
|
|
mediump KEYWORD(120, 130 || ES, MEDIUMP);
|
|
|
|
highp KEYWORD(120, 130 || ES, HIGHP);
|
|
|
|
precision KEYWORD(120, 130 || ES, PRECISION);
|
2010-02-22 13:19:34 -08:00
|
|
|
|
2010-08-07 00:50:08 -07:00
|
|
|
/* Additional reserved words in GLSL 1.30. */
|
2010-11-13 22:02:09 -08:00
|
|
|
case KEYWORD(130, 130, CASE);
|
2010-11-13 20:32:59 -08:00
|
|
|
common KEYWORD(130, 999, COMMON);
|
|
|
|
partition KEYWORD(130, 999, PARTITION);
|
|
|
|
active KEYWORD(130, 999, ACTIVE);
|
|
|
|
superp KEYWORD(130 || ES, 999, SUPERP);
|
|
|
|
samplerBuffer KEYWORD(130, 140, SAMPLERBUFFER);
|
|
|
|
filter KEYWORD(130, 999, FILTER);
|
|
|
|
image1D KEYWORD(130, 999, IMAGE1D);
|
|
|
|
image2D KEYWORD(130, 999, IMAGE2D);
|
|
|
|
image3D KEYWORD(130, 999, IMAGE3D);
|
|
|
|
imageCube KEYWORD(130, 999, IMAGECUBE);
|
|
|
|
iimage1D KEYWORD(130, 999, IIMAGE1D);
|
|
|
|
iimage2D KEYWORD(130, 999, IIMAGE2D);
|
|
|
|
iimage3D KEYWORD(130, 999, IIMAGE3D);
|
|
|
|
iimageCube KEYWORD(130, 999, IIMAGECUBE);
|
|
|
|
uimage1D KEYWORD(130, 999, UIMAGE1D);
|
|
|
|
uimage2D KEYWORD(130, 999, UIMAGE2D);
|
|
|
|
uimage3D KEYWORD(130, 999, UIMAGE3D);
|
|
|
|
uimageCube KEYWORD(130, 999, UIMAGECUBE);
|
|
|
|
image1DArray KEYWORD(130, 999, IMAGE1DARRAY);
|
|
|
|
image2DArray KEYWORD(130, 999, IMAGE2DARRAY);
|
|
|
|
iimage1DArray KEYWORD(130, 999, IIMAGE1DARRAY);
|
|
|
|
iimage2DArray KEYWORD(130, 999, IIMAGE2DARRAY);
|
|
|
|
uimage1DArray KEYWORD(130, 999, UIMAGE1DARRAY);
|
|
|
|
uimage2DArray KEYWORD(130, 999, UIMAGE2DARRAY);
|
|
|
|
image1DShadow KEYWORD(130, 999, IMAGE1DSHADOW);
|
|
|
|
image2DShadow KEYWORD(130, 999, IMAGE2DSHADOW);
|
2010-11-13 22:02:09 -08:00
|
|
|
image1DArrayShadow KEYWORD(130, 999, IMAGE1DARRAYSHADOW);
|
|
|
|
image2DArrayShadow KEYWORD(130, 999, IMAGE2DARRAYSHADOW);
|
2010-11-13 20:32:59 -08:00
|
|
|
imageBuffer KEYWORD(130, 999, IMAGEBUFFER);
|
|
|
|
iimageBuffer KEYWORD(130, 999, IIMAGEBUFFER);
|
|
|
|
uimageBuffer KEYWORD(130, 999, UIMAGEBUFFER);
|
|
|
|
row_major KEYWORD(130, 999, ROW_MAJOR);
|
2010-08-07 00:50:08 -07:00
|
|
|
|
2010-02-22 13:19:34 -08:00
|
|
|
[_a-zA-Z][_a-zA-Z0-9]* {
|
2010-06-18 17:43:40 -07:00
|
|
|
struct _mesa_glsl_parse_state *state = yyextra;
|
2010-06-25 13:14:37 -07:00
|
|
|
void *ctx = state;
|
2010-06-18 17:43:40 -07:00
|
|
|
yylval->identifier = talloc_strdup(ctx, yytext);
|
2010-03-19 11:12:33 -07:00
|
|
|
return IDENTIFIER;
|
2010-02-22 13:19:34 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
. { return yytext[0]; }
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
void
|
2010-06-21 11:43:42 -07:00
|
|
|
_mesa_glsl_lexer_ctor(struct _mesa_glsl_parse_state *state, const char *string)
|
2010-02-22 13:19:34 -08:00
|
|
|
{
|
|
|
|
yylex_init_extra(state, & state->scanner);
|
2010-06-21 11:43:42 -07:00
|
|
|
yy_scan_string(string, state->scanner);
|
2010-02-22 13:19:34 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
_mesa_glsl_lexer_dtor(struct _mesa_glsl_parse_state *state)
|
|
|
|
{
|
|
|
|
yylex_destroy(state->scanner);
|
|
|
|
}
|