Commit 9e3a3f43 by Nicolas Capens Committed by Shannon Woods

Add unsigned integer samplers to the lexer/parser.

TRAC #23360 Signed-off-by: Jamie Madill Signed-off-by: Shannon Woods Author: Nicolas Capens
parent 8613229e
...@@ -156,6 +156,8 @@ O [0-7] ...@@ -156,6 +156,8 @@ O [0-7]
"sampler2DRect" { return SAMPLER2DRECT; } "sampler2DRect" { return SAMPLER2DRECT; }
"isampler2D" { return ES2_ident_ES3_keyword(context, ISAMPLER2D); } "isampler2D" { return ES2_ident_ES3_keyword(context, ISAMPLER2D); }
"isamplerCube" { return ES2_ident_ES3_keyword(context, ISAMPLERCUBE); } "isamplerCube" { return ES2_ident_ES3_keyword(context, ISAMPLERCUBE); }
"usampler2D" { return ES2_ident_ES3_keyword(context, USAMPLER2D); }
"usamplerCube" { return ES2_ident_ES3_keyword(context, USAMPLERCUBE); }
"struct" { return STRUCT; } "struct" { return STRUCT; }
......
...@@ -131,7 +131,7 @@ extern void yyerror(TParseContext* context, const char* reason); ...@@ -131,7 +131,7 @@ extern void yyerror(TParseContext* context, const char* reason);
%token <lex> MATRIX2x3 MATRIX3x2 MATRIX2x4 MATRIX4x2 MATRIX3x4 MATRIX4x3 %token <lex> MATRIX2x3 MATRIX3x2 MATRIX2x4 MATRIX4x2 MATRIX3x4 MATRIX4x3
%token <lex> CENTROID FLAT SMOOTH %token <lex> CENTROID FLAT SMOOTH
%token <lex> STRUCT VOID_TYPE WHILE %token <lex> STRUCT VOID_TYPE WHILE
%token <lex> SAMPLER2D SAMPLERCUBE SAMPLER_EXTERNAL_OES SAMPLER2DRECT ISAMPLER2D ISAMPLERCUBE %token <lex> SAMPLER2D SAMPLERCUBE SAMPLER_EXTERNAL_OES SAMPLER2DRECT ISAMPLER2D ISAMPLERCUBE USAMPLER2D USAMPLERCUBE
%token <lex> SAMPLER3D SAMPLER3DRECT SAMPLER2DSHADOW %token <lex> SAMPLER3D SAMPLER3DRECT SAMPLER2DSHADOW
%token <lex> LAYOUT %token <lex> LAYOUT
...@@ -1522,6 +1522,14 @@ type_specifier_nonarray ...@@ -1522,6 +1522,14 @@ type_specifier_nonarray
TQualifier qual = context->symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary; TQualifier qual = context->symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary;
$$.setBasic(EbtISamplerCube, qual, $1.line); $$.setBasic(EbtISamplerCube, qual, $1.line);
} }
| USAMPLER2D {
TQualifier qual = context->symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary;
$$.setBasic(EbtUSampler2D, qual, $1.line);
}
| USAMPLERCUBE {
TQualifier qual = context->symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary;
$$.setBasic(EbtUSamplerCube, qual, $1.line);
}
| SAMPLER_EXTERNAL_OES { | SAMPLER_EXTERNAL_OES {
if (!context->supportsExtension("GL_OES_EGL_image_external")) { if (!context->supportsExtension("GL_OES_EGL_image_external")) {
context->error($1.line, "unsupported type", "samplerExternalOES"); context->error($1.line, "unsupported type", "samplerExternalOES");
......
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -106,62 +106,64 @@ extern int yydebug; ...@@ -106,62 +106,64 @@ extern int yydebug;
SAMPLER2DRECT = 315, SAMPLER2DRECT = 315,
ISAMPLER2D = 316, ISAMPLER2D = 316,
ISAMPLERCUBE = 317, ISAMPLERCUBE = 317,
SAMPLER3D = 318, USAMPLER2D = 318,
SAMPLER3DRECT = 319, USAMPLERCUBE = 319,
SAMPLER2DSHADOW = 320, SAMPLER3D = 320,
LAYOUT = 321, SAMPLER3DRECT = 321,
IDENTIFIER = 322, SAMPLER2DSHADOW = 322,
TYPE_NAME = 323, LAYOUT = 323,
FLOATCONSTANT = 324, IDENTIFIER = 324,
INTCONSTANT = 325, TYPE_NAME = 325,
UINTCONSTANT = 326, FLOATCONSTANT = 326,
BOOLCONSTANT = 327, INTCONSTANT = 327,
FIELD_SELECTION = 328, UINTCONSTANT = 328,
LEFT_OP = 329, BOOLCONSTANT = 329,
RIGHT_OP = 330, FIELD_SELECTION = 330,
INC_OP = 331, LEFT_OP = 331,
DEC_OP = 332, RIGHT_OP = 332,
LE_OP = 333, INC_OP = 333,
GE_OP = 334, DEC_OP = 334,
EQ_OP = 335, LE_OP = 335,
NE_OP = 336, GE_OP = 336,
AND_OP = 337, EQ_OP = 337,
OR_OP = 338, NE_OP = 338,
XOR_OP = 339, AND_OP = 339,
MUL_ASSIGN = 340, OR_OP = 340,
DIV_ASSIGN = 341, XOR_OP = 341,
ADD_ASSIGN = 342, MUL_ASSIGN = 342,
MOD_ASSIGN = 343, DIV_ASSIGN = 343,
LEFT_ASSIGN = 344, ADD_ASSIGN = 344,
RIGHT_ASSIGN = 345, MOD_ASSIGN = 345,
AND_ASSIGN = 346, LEFT_ASSIGN = 346,
XOR_ASSIGN = 347, RIGHT_ASSIGN = 347,
OR_ASSIGN = 348, AND_ASSIGN = 348,
SUB_ASSIGN = 349, XOR_ASSIGN = 349,
LEFT_PAREN = 350, OR_ASSIGN = 350,
RIGHT_PAREN = 351, SUB_ASSIGN = 351,
LEFT_BRACKET = 352, LEFT_PAREN = 352,
RIGHT_BRACKET = 353, RIGHT_PAREN = 353,
LEFT_BRACE = 354, LEFT_BRACKET = 354,
RIGHT_BRACE = 355, RIGHT_BRACKET = 355,
DOT = 356, LEFT_BRACE = 356,
COMMA = 357, RIGHT_BRACE = 357,
COLON = 358, DOT = 358,
EQUAL = 359, COMMA = 359,
SEMICOLON = 360, COLON = 360,
BANG = 361, EQUAL = 361,
DASH = 362, SEMICOLON = 362,
TILDE = 363, BANG = 363,
PLUS = 364, DASH = 364,
STAR = 365, TILDE = 365,
SLASH = 366, PLUS = 366,
PERCENT = 367, STAR = 367,
LEFT_ANGLE = 368, SLASH = 368,
RIGHT_ANGLE = 369, PERCENT = 369,
VERTICAL_BAR = 370, LEFT_ANGLE = 370,
CARET = 371, RIGHT_ANGLE = 371,
AMPERSAND = 372, VERTICAL_BAR = 372,
QUESTION = 373 CARET = 373,
AMPERSAND = 374,
QUESTION = 375
}; };
#endif #endif
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment