blob: 68fda252b9238ec93a9775d7abd08069dfbba788 [file] [log] [blame]
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +00001//
Nicolas Capens16004fc2014-06-11 11:29:11 -04002// Copyright (c) 2002-2014 The ANGLE Project Authors. All rights reserved.
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +00003// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
Geoff Lang0a73dd82014-11-19 16:18:08 -05006#ifndef COMPILER_TRANSLATOR_PARSECONTEXT_H_
7#define COMPILER_TRANSLATOR_PARSECONTEXT_H_
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +00008
Jamie Madilld4a3a312014-06-25 16:04:56 -04009#include "compiler/translator/Compiler.h"
Geoff Lang17732822013-08-29 13:46:49 -040010#include "compiler/translator/Diagnostics.h"
11#include "compiler/translator/DirectiveHandler.h"
Jamie Madillb1a85f42014-08-19 15:23:24 -040012#include "compiler/translator/Intermediate.h"
Geoff Lang17732822013-08-29 13:46:49 -040013#include "compiler/translator/SymbolTable.h"
Martin Radev70866b82016-07-22 15:27:42 +030014#include "compiler/translator/QualifierTypes.h"
daniel@transgaming.comb401a922012-10-26 18:58:24 +000015#include "compiler/preprocessor/Preprocessor.h"
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +000016
Jamie Madill06145232015-05-13 13:10:01 -040017struct TMatrixFields
18{
daniel@transgaming.com0578f812010-05-17 09:58:39 +000019 bool wholeRow;
20 bool wholeCol;
21 int row;
22 int col;
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +000023};
24
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +000025//
26// The following are extra variables needed during parsing, grouped together so
27// they can be passed to the parser without needing a global.
28//
Jamie Madill6e06b1f2015-05-14 10:01:17 -040029class TParseContext : angle::NonCopyable
Jamie Madill06145232015-05-13 13:10:01 -040030{
Jamie Madill6e06b1f2015-05-14 10:01:17 -040031 public:
Jamie Madill06145232015-05-13 13:10:01 -040032 TParseContext(TSymbolTable &symt,
33 TExtensionBehavior &ext,
Jamie Madill06145232015-05-13 13:10:01 -040034 sh::GLenum type,
35 ShShaderSpec spec,
Qiankun Miao7ebb97f2016-09-08 18:01:50 +080036 ShCompileOptions options,
Jamie Madill06145232015-05-13 13:10:01 -040037 bool checksPrecErrors,
38 TInfoSink &is,
Olli Etuahoe1a94c62015-11-16 17:35:25 +020039 const ShBuiltInResources &resources)
Olli Etuahof119a262016-08-19 15:54:22 +030040 : intermediate(),
Jamie Madill06145232015-05-13 13:10:01 -040041 symbolTable(symt),
Corentin Wallezbc99bb62015-05-14 17:42:20 -040042 mDeferredSingleDeclarationErrorCheck(false),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040043 mShaderType(type),
44 mShaderSpec(spec),
Kenneth Russellbccc65d2016-07-19 16:48:43 -070045 mCompileOptions(options),
Corentin Wallezbc99bb62015-05-14 17:42:20 -040046 mShaderVersion(100),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040047 mTreeRoot(nullptr),
Jamie Madill06145232015-05-13 13:10:01 -040048 mLoopNestingLevel(0),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040049 mStructNestingLevel(0),
Jamie Madill06145232015-05-13 13:10:01 -040050 mSwitchNestingLevel(0),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040051 mCurrentFunctionType(nullptr),
Jamie Madill06145232015-05-13 13:10:01 -040052 mFunctionReturnsValue(false),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040053 mChecksPrecisionErrors(checksPrecErrors),
Olli Etuahoa6996682015-10-12 14:32:30 +030054 mFragmentPrecisionHighOnESSL1(false),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040055 mDefaultMatrixPacking(EmpColumnMajor),
Olli Etuahof0173152016-10-17 09:05:03 -070056 mDefaultBlockStorage(IsWebGLBasedSpec(spec) ? EbsStd140 : EbsShared),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040057 mDiagnostics(is),
Olli Etuahoe1a94c62015-11-16 17:35:25 +020058 mDirectiveHandler(ext,
59 mDiagnostics,
60 mShaderVersion,
Olli Etuaho5f80d012016-01-11 11:16:01 +020061 mShaderType,
Olli Etuahoe1a94c62015-11-16 17:35:25 +020062 resources.WEBGL_debug_shader_precision == 1),
Jamie Madill6e06b1f2015-05-14 10:01:17 -040063 mPreprocessor(&mDiagnostics, &mDirectiveHandler),
64 mScanner(nullptr),
Jamie Madill14e95b32015-05-07 10:10:41 -040065 mUsesFragData(false),
Kimmo Kinnunenb18609b2015-07-16 14:13:11 +030066 mUsesFragColor(false),
Olli Etuahoe1a94c62015-11-16 17:35:25 +020067 mUsesSecondaryOutputs(false),
68 mMinProgramTexelOffset(resources.MinProgramTexelOffset),
Martin Radev802abe02016-08-04 17:48:32 +030069 mMaxProgramTexelOffset(resources.MaxProgramTexelOffset),
Martin Radev70866b82016-07-22 15:27:42 +030070 mComputeShaderLocalSizeDeclared(false),
71 mDeclaringFunction(false)
Olli Etuahofa33d582015-04-09 14:33:12 +030072 {
Martin Radev802abe02016-08-04 17:48:32 +030073 mComputeShaderLocalSize.fill(-1);
Olli Etuahofa33d582015-04-09 14:33:12 +030074 }
Jamie Madill06145232015-05-13 13:10:01 -040075
Jamie Madill6e06b1f2015-05-14 10:01:17 -040076 const pp::Preprocessor &getPreprocessor() const { return mPreprocessor; }
77 pp::Preprocessor &getPreprocessor() { return mPreprocessor; }
78 void *getScanner() const { return mScanner; }
79 void setScanner(void *scanner) { mScanner = scanner; }
80 int getShaderVersion() const { return mShaderVersion; }
81 sh::GLenum getShaderType() const { return mShaderType; }
82 ShShaderSpec getShaderSpec() const { return mShaderSpec; }
83 int numErrors() const { return mDiagnostics.numErrors(); }
84 TInfoSink &infoSink() { return mDiagnostics.infoSink(); }
Jamie Madill06145232015-05-13 13:10:01 -040085 void error(const TSourceLoc &loc, const char *reason, const char *token,
86 const char *extraInfo="");
87 void warning(const TSourceLoc &loc, const char *reason, const char *token,
88 const char *extraInfo="");
Jamie Madill14e95b32015-05-07 10:10:41 -040089
Olli Etuaho7c3848e2015-11-04 13:19:17 +020090 // If isError is false, a warning will be reported instead.
91 void outOfRangeError(bool isError,
92 const TSourceLoc &loc,
93 const char *reason,
94 const char *token,
95 const char *extraInfo = "");
96
Olli Etuaho6d40bbd2016-09-30 13:49:38 +010097 TIntermBlock *getTreeRoot() const { return mTreeRoot; }
98 void setTreeRoot(TIntermBlock *treeRoot) { mTreeRoot = treeRoot; }
Jamie Madill6e06b1f2015-05-14 10:01:17 -040099
Olli Etuahoa6996682015-10-12 14:32:30 +0300100 bool getFragmentPrecisionHigh() const
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400101 {
Olli Etuahoa6996682015-10-12 14:32:30 +0300102 return mFragmentPrecisionHighOnESSL1 || mShaderVersion >= 300;
103 }
104 void setFragmentPrecisionHighOnESSL1(bool fragmentPrecisionHigh)
105 {
106 mFragmentPrecisionHighOnESSL1 = fragmentPrecisionHigh;
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400107 }
108
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400109 void setLoopNestingLevel(int loopNestintLevel)
110 {
111 mLoopNestingLevel = loopNestintLevel;
112 }
113
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400114 void incrLoopNestingLevel() { ++mLoopNestingLevel; }
115 void decrLoopNestingLevel() { --mLoopNestingLevel; }
116
117 void incrSwitchNestingLevel() { ++mSwitchNestingLevel; }
118 void decrSwitchNestingLevel() { --mSwitchNestingLevel; }
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +0000119
Martin Radev802abe02016-08-04 17:48:32 +0300120 bool isComputeShaderLocalSizeDeclared() const { return mComputeShaderLocalSizeDeclared; }
Martin Radev4c4c8e72016-08-04 12:25:34 +0300121 sh::WorkGroupSize getComputeShaderLocalSize() const;
Martin Radev802abe02016-08-04 17:48:32 +0300122
Martin Radev70866b82016-07-22 15:27:42 +0300123 void enterFunctionDeclaration() { mDeclaringFunction = true; }
124
125 void exitFunctionDeclaration() { mDeclaringFunction = false; }
126
127 bool declaringFunction() const { return mDeclaringFunction; }
128
Jamie Madill5c097022014-08-20 16:38:32 -0400129 // This method is guaranteed to succeed, even if no variable with 'name' exists.
130 const TVariable *getNamedVariable(const TSourceLoc &location, const TString *name, const TSymbol *symbol);
Olli Etuaho82c29ed2015-11-03 13:06:54 +0200131 TIntermTyped *parseVariableIdentifier(const TSourceLoc &location,
132 const TString *name,
133 const TSymbol *symbol);
Jamie Madill5c097022014-08-20 16:38:32 -0400134
Jamie Madill06145232015-05-13 13:10:01 -0400135 bool parseVectorFields(const TString&, int vecSize, TVectorFields&, const TSourceLoc &line);
alokp@chromium.org75fe6b72011-08-14 05:31:22 +0000136
Jamie Madill06145232015-05-13 13:10:01 -0400137 void assignError(const TSourceLoc &line, const char *op, TString left, TString right);
138 void unaryOpError(const TSourceLoc &line, const char *op, TString operand);
139 void binaryOpError(const TSourceLoc &line, const char *op, TString left, TString right);
Olli Etuaho856c4972016-08-08 11:38:39 +0300140
Olli Etuaho8a176262016-08-16 14:23:01 +0300141 // Check functions - the ones that return bool return false if an error was generated.
142
Olli Etuaho856c4972016-08-08 11:38:39 +0300143 bool checkIsNotReserved(const TSourceLoc &line, const TString &identifier);
144 void checkPrecisionSpecified(const TSourceLoc &line, TPrecision precision, TBasicType type);
145 bool checkCanBeLValue(const TSourceLoc &line, const char *op, TIntermTyped *node);
146 void checkIsConst(TIntermTyped *node);
147 void checkIsScalarInteger(TIntermTyped *node, const char *token);
Qiankun Miaof69682b2016-08-16 14:50:42 +0800148 bool checkIsAtGlobalLevel(const TSourceLoc &line, const char *token);
Olli Etuaho856c4972016-08-08 11:38:39 +0300149 bool checkConstructorArguments(const TSourceLoc &line,
150 TIntermNode *argumentsNode,
151 const TFunction &function,
152 TOperator op,
153 const TType &type);
154
155 // Returns a sanitized array size to use (the size is at least 1).
156 unsigned int checkIsValidArraySize(const TSourceLoc &line, TIntermTyped *expr);
Olli Etuaho8a176262016-08-16 14:23:01 +0300157 bool checkIsValidQualifierForArray(const TSourceLoc &line, const TPublicType &elementQualifier);
158 bool checkIsValidTypeForArray(const TSourceLoc &line, const TPublicType &elementType);
Olli Etuaho856c4972016-08-08 11:38:39 +0300159 bool checkIsNonVoid(const TSourceLoc &line, const TString &identifier, const TBasicType &type);
160 void checkIsScalarBool(const TSourceLoc &line, const TIntermTyped *type);
161 void checkIsScalarBool(const TSourceLoc &line, const TPublicType &pType);
Martin Radev4a9cd802016-09-01 16:51:51 +0300162 bool checkIsNotSampler(const TSourceLoc &line,
163 const TTypeSpecifierNonArray &pType,
164 const char *reason);
Martin Radev2cc85b32016-08-05 16:22:53 +0300165 bool checkIsNotImage(const TSourceLoc &line,
166 const TTypeSpecifierNonArray &pType,
167 const char *reason);
Olli Etuaho856c4972016-08-08 11:38:39 +0300168 void checkDeclaratorLocationIsNotSpecified(const TSourceLoc &line, const TPublicType &pType);
169 void checkLocationIsNotSpecified(const TSourceLoc &location,
170 const TLayoutQualifier &layoutQualifier);
Olli Etuaho856c4972016-08-08 11:38:39 +0300171 void checkIsParameterQualifierValid(const TSourceLoc &line,
Martin Radev70866b82016-07-22 15:27:42 +0300172 const TTypeQualifierBuilder &typeQualifierBuilder,
Olli Etuaho856c4972016-08-08 11:38:39 +0300173 TType *type);
174 bool checkCanUseExtension(const TSourceLoc &line, const TString &extension);
Olli Etuaho383b7912016-08-05 11:22:59 +0300175 void singleDeclarationErrorCheck(const TPublicType &publicType,
176 const TSourceLoc &identifierLocation);
Olli Etuaho856c4972016-08-08 11:38:39 +0300177 void checkLayoutQualifierSupported(const TSourceLoc &location,
178 const TString &layoutQualifierName,
179 int versionRequired);
180 bool checkWorkGroupSizeIsNotSpecified(const TSourceLoc &location,
181 const TLayoutQualifier &layoutQualifier);
Martin Radev2cc85b32016-08-05 16:22:53 +0300182 bool checkInternalFormatIsNotSpecified(const TSourceLoc &location,
183 TLayoutImageInternalFormat internalFormat);
Olli Etuaho856c4972016-08-08 11:38:39 +0300184 void functionCallLValueErrorCheck(const TFunction *fnCandidate, TIntermAggregate *fnCall);
Martin Radev70866b82016-07-22 15:27:42 +0300185 void checkInvariantVariableQualifier(bool invariant,
186 const TQualifier qualifier,
187 const TSourceLoc &invariantLocation);
Olli Etuaho856c4972016-08-08 11:38:39 +0300188 void checkInputOutputTypeIsValidES3(const TQualifier qualifier,
189 const TPublicType &type,
190 const TSourceLoc &qualifierLocation);
Martin Radev2cc85b32016-08-05 16:22:53 +0300191 void checkLocalVariableConstStorageQualifier(const TQualifierWrapperBase &qualifier);
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400192 const TPragma &pragma() const { return mDirectiveHandler.pragma(); }
193 const TExtensionBehavior &extensionBehavior() const { return mDirectiveHandler.extensionBehavior(); }
Jamie Madill06145232015-05-13 13:10:01 -0400194 bool supportsExtension(const char *extension);
195 bool isExtensionEnabled(const char *extension) const;
196 void handleExtensionDirective(const TSourceLoc &loc, const char *extName, const char *behavior);
197 void handlePragmaDirective(const TSourceLoc &loc, const char *name, const char *value, bool stdgl);
alokp@chromium.org75fe6b72011-08-14 05:31:22 +0000198
Jamie Madill06145232015-05-13 13:10:01 -0400199 const TFunction* findFunction(
200 const TSourceLoc &line, TFunction *pfnCall, int inputShaderVersion, bool *builtIn = 0);
201 bool executeInitializer(const TSourceLoc &line,
202 const TString &identifier,
203 const TPublicType &pType,
204 TIntermTyped *initializer,
Olli Etuaho13389b62016-10-16 11:48:18 +0100205 TIntermBinary **initNode);
alokp@chromium.org75fe6b72011-08-14 05:31:22 +0000206
Olli Etuaho0e3aee32016-10-27 12:56:38 +0100207 void addFullySpecifiedType(TPublicType *typeSpecifier);
Martin Radev70866b82016-07-22 15:27:42 +0300208 TPublicType addFullySpecifiedType(const TTypeQualifierBuilder &typeQualifierBuilder,
Jamie Madill06145232015-05-13 13:10:01 -0400209 const TPublicType &typeSpecifier);
Olli Etuahoe7847b02015-03-16 11:56:12 +0200210
Olli Etuaho13389b62016-10-16 11:48:18 +0100211 TIntermDeclaration *parseSingleDeclaration(TPublicType &publicType,
212 const TSourceLoc &identifierOrTypeLocation,
213 const TString &identifier);
214 TIntermDeclaration *parseSingleArrayDeclaration(TPublicType &publicType,
215 const TSourceLoc &identifierLocation,
216 const TString &identifier,
217 const TSourceLoc &indexLocation,
218 TIntermTyped *indexExpression);
219 TIntermDeclaration *parseSingleInitDeclaration(const TPublicType &publicType,
220 const TSourceLoc &identifierLocation,
221 const TString &identifier,
222 const TSourceLoc &initLocation,
223 TIntermTyped *initializer);
Jamie Madill47e3ec02014-08-20 16:38:33 -0400224
Olli Etuaho3875ffd2015-04-10 16:45:14 +0300225 // Parse a declaration like "type a[n] = initializer"
226 // Note that this does not apply to declarations like "type[n] a = initializer"
Olli Etuaho13389b62016-10-16 11:48:18 +0100227 TIntermDeclaration *parseSingleArrayInitDeclaration(TPublicType &publicType,
228 const TSourceLoc &identifierLocation,
229 const TString &identifier,
230 const TSourceLoc &indexLocation,
231 TIntermTyped *indexExpression,
232 const TSourceLoc &initLocation,
233 TIntermTyped *initializer);
Olli Etuaho3875ffd2015-04-10 16:45:14 +0300234
Martin Radev70866b82016-07-22 15:27:42 +0300235 TIntermAggregate *parseInvariantDeclaration(const TTypeQualifierBuilder &typeQualifierBuilder,
Jamie Madill06145232015-05-13 13:10:01 -0400236 const TSourceLoc &identifierLoc,
237 const TString *identifier,
238 const TSymbol *symbol);
Olli Etuahoe7847b02015-03-16 11:56:12 +0200239
Olli Etuaho13389b62016-10-16 11:48:18 +0100240 void parseDeclarator(TPublicType &publicType,
241 const TSourceLoc &identifierLocation,
242 const TString &identifier,
243 TIntermDeclaration *declarationOut);
244 void parseArrayDeclarator(TPublicType &publicType,
245 const TSourceLoc &identifierLocation,
246 const TString &identifier,
247 const TSourceLoc &arrayLocation,
248 TIntermTyped *indexExpression,
249 TIntermDeclaration *declarationOut);
250 void parseInitDeclarator(const TPublicType &publicType,
251 const TSourceLoc &identifierLocation,
252 const TString &identifier,
253 const TSourceLoc &initLocation,
254 TIntermTyped *initializer,
255 TIntermDeclaration *declarationOut);
Olli Etuahoe7847b02015-03-16 11:56:12 +0200256
Olli Etuaho3875ffd2015-04-10 16:45:14 +0300257 // Parse a declarator like "a[n] = initializer"
Olli Etuaho13389b62016-10-16 11:48:18 +0100258 void parseArrayInitDeclarator(const TPublicType &publicType,
259 const TSourceLoc &identifierLocation,
260 const TString &identifier,
261 const TSourceLoc &indexLocation,
262 TIntermTyped *indexExpression,
263 const TSourceLoc &initLocation,
264 TIntermTyped *initializer,
265 TIntermDeclaration *declarationOut);
Olli Etuaho3875ffd2015-04-10 16:45:14 +0300266
Martin Radev70866b82016-07-22 15:27:42 +0300267 void parseGlobalLayoutQualifier(const TTypeQualifierBuilder &typeQualifierBuilder);
Olli Etuaho476197f2016-10-11 13:59:08 +0100268 TIntermAggregate *addFunctionPrototypeDeclaration(const TFunction &parsedFunction,
Olli Etuahoee63f5d2016-01-04 11:34:54 +0200269 const TSourceLoc &location);
Olli Etuaho336b1472016-10-05 16:37:55 +0100270 TIntermFunctionDefinition *addFunctionDefinition(const TFunction &function,
271 TIntermAggregate *functionParameters,
272 TIntermBlock *functionBody,
273 const TSourceLoc &location);
Olli Etuaho476197f2016-10-11 13:59:08 +0100274 void parseFunctionDefinitionHeader(const TSourceLoc &location,
275 TFunction **function,
276 TIntermAggregate **aggregateOut);
Jamie Madill185fb402015-06-12 15:48:48 -0400277 TFunction *parseFunctionDeclarator(const TSourceLoc &location,
278 TFunction *function);
Olli Etuaho9de84a52016-06-14 17:36:01 +0300279 TFunction *parseFunctionHeader(const TPublicType &type,
280 const TString *name,
281 const TSourceLoc &location);
Jamie Madill06145232015-05-13 13:10:01 -0400282 TFunction *addConstructorFunc(const TPublicType &publicType);
283 TIntermTyped *addConstructor(TIntermNode *arguments,
Jamie Madill06145232015-05-13 13:10:01 -0400284 TOperator op,
285 TFunction *fnCall,
286 const TSourceLoc &line);
Olli Etuaho90892fb2016-07-14 14:44:51 +0300287
Jamie Madill06145232015-05-13 13:10:01 -0400288 TIntermTyped *addIndexExpression(TIntermTyped *baseExpression,
289 const TSourceLoc& location,
290 TIntermTyped *indexExpression);
291 TIntermTyped* addFieldSelectionExpression(TIntermTyped *baseExpression,
292 const TSourceLoc &dotLocation,
293 const TString &fieldString,
294 const TSourceLoc &fieldLocation);
shannonwoods@chromium.orga9100882013-05-30 00:11:39 +0000295
Martin Radev70866b82016-07-22 15:27:42 +0300296 TFieldList *addStructDeclaratorListWithQualifiers(
297 const TTypeQualifierBuilder &typeQualifierBuilder,
298 TPublicType *typeSpecifier,
299 TFieldList *fieldList);
Jamie Madill06145232015-05-13 13:10:01 -0400300 TFieldList *addStructDeclaratorList(const TPublicType &typeSpecifier, TFieldList *fieldList);
Martin Radev4a9cd802016-09-01 16:51:51 +0300301 TTypeSpecifierNonArray addStructure(const TSourceLoc &structLine,
302 const TSourceLoc &nameLine,
303 const TString *structName,
304 TFieldList *fieldList);
kbr@chromium.org476541f2011-10-27 21:14:51 +0000305
Olli Etuaho13389b62016-10-16 11:48:18 +0100306 TIntermDeclaration *addInterfaceBlock(const TTypeQualifierBuilder &typeQualifierBuilder,
307 const TSourceLoc &nameLine,
308 const TString &blockName,
309 TFieldList *fieldList,
310 const TString *instanceName,
311 const TSourceLoc &instanceLine,
312 TIntermTyped *arrayIndex,
313 const TSourceLoc &arrayIndexLine);
shannonwoods@chromium.org5668c5d2013-05-30 00:11:48 +0000314
Martin Radev802abe02016-08-04 17:48:32 +0300315 void parseLocalSize(const TString &qualifierType,
316 const TSourceLoc &qualifierTypeLine,
317 int intValue,
318 const TSourceLoc &intValueLine,
319 const std::string &intValueString,
320 size_t index,
Martin Radev4c4c8e72016-08-04 12:25:34 +0300321 sh::WorkGroupSize *localSize);
Jamie Madill06145232015-05-13 13:10:01 -0400322 TLayoutQualifier parseLayoutQualifier(
323 const TString &qualifierType, const TSourceLoc &qualifierTypeLine);
324 TLayoutQualifier parseLayoutQualifier(const TString &qualifierType,
325 const TSourceLoc &qualifierTypeLine,
Jamie Madill06145232015-05-13 13:10:01 -0400326 int intValue,
327 const TSourceLoc &intValueLine);
Olli Etuaho613b9592016-09-05 12:05:53 +0300328 TTypeQualifierBuilder *createTypeQualifierBuilder(const TSourceLoc &loc);
Martin Radev802abe02016-08-04 17:48:32 +0300329 TLayoutQualifier joinLayoutQualifiers(TLayoutQualifier leftQualifier,
330 TLayoutQualifier rightQualifier,
331 const TSourceLoc &rightQualifierLocation);
shannonwoods@chromium.org302adfe2013-05-30 00:21:06 +0000332
kbr@chromium.org476541f2011-10-27 21:14:51 +0000333 // Performs an error check for embedded struct declarations.
Olli Etuaho383b7912016-08-05 11:22:59 +0300334 void enterStructDeclaration(const TSourceLoc &line, const TString &identifier);
kbr@chromium.org476541f2011-10-27 21:14:51 +0000335 void exitStructDeclaration();
336
Olli Etuaho8a176262016-08-16 14:23:01 +0300337 void checkIsBelowStructNestingLimit(const TSourceLoc &line, const TField &field);
Olli Etuaho09b22472015-02-11 11:47:26 +0200338
Olli Etuaho6d40bbd2016-09-30 13:49:38 +0100339 TIntermSwitch *addSwitch(TIntermTyped *init,
340 TIntermBlock *statementList,
341 const TSourceLoc &loc);
Olli Etuahoa3a36662015-02-17 13:46:51 +0200342 TIntermCase *addCase(TIntermTyped *condition, const TSourceLoc &loc);
343 TIntermCase *addDefault(const TSourceLoc &loc);
344
Jamie Madill06145232015-05-13 13:10:01 -0400345 TIntermTyped *addUnaryMath(TOperator op, TIntermTyped *child, const TSourceLoc &loc);
346 TIntermTyped *addUnaryMathLValue(TOperator op, TIntermTyped *child, const TSourceLoc &loc);
347 TIntermTyped *addBinaryMath(
348 TOperator op, TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
349 TIntermTyped *addBinaryMathBooleanResult(
350 TOperator op, TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
351 TIntermTyped *addAssign(
352 TOperator op, TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
Olli Etuaho49300862015-02-20 14:54:49 +0200353
Olli Etuaho0b2d2dc2015-11-04 16:35:32 +0200354 TIntermTyped *addComma(TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
355
Olli Etuaho49300862015-02-20 14:54:49 +0200356 TIntermBranch *addBranch(TOperator op, const TSourceLoc &loc);
357 TIntermBranch *addBranch(TOperator op, TIntermTyped *returnValue, const TSourceLoc &loc);
Olli Etuahoc4ba3be2015-03-02 14:42:24 +0200358
Olli Etuahoe1a94c62015-11-16 17:35:25 +0200359 void checkTextureOffsetConst(TIntermAggregate *functionCall);
Martin Radev2cc85b32016-08-05 16:22:53 +0300360 void checkImageMemoryAccessForBuiltinFunctions(TIntermAggregate *functionCall);
361 void checkImageMemoryAccessForUserDefinedFunctions(const TFunction *functionDefinition,
362 const TIntermAggregate *functionCall);
Jamie Madill06145232015-05-13 13:10:01 -0400363 TIntermTyped *addFunctionCallOrMethod(TFunction *fnCall,
364 TIntermNode *paramNode,
365 TIntermNode *thisNode,
366 const TSourceLoc &loc,
367 bool *fatalError);
Olli Etuahofc1806e2015-03-17 13:03:11 +0200368
Olli Etuahod0bad2c2016-09-09 18:01:16 +0300369 TIntermTyped *addTernarySelection(TIntermTyped *cond,
370 TIntermTyped *trueExpression,
371 TIntermTyped *falseExpression,
372 const TSourceLoc &line);
Olli Etuaho52901742015-04-15 13:42:45 +0300373
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400374 // TODO(jmadill): make these private
Olli Etuahof119a262016-08-19 15:54:22 +0300375 TIntermediate intermediate; // to build a parse tree
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400376 TSymbolTable &symbolTable; // symbol table that goes with the language currently being parsed
377
Olli Etuahofc1806e2015-03-17 13:03:11 +0200378 private:
Olli Etuaho90892fb2016-07-14 14:44:51 +0300379 // Returns a clamped index.
380 int checkIndexOutOfRange(bool outOfRangeIndexIsError,
381 const TSourceLoc &location,
382 int index,
383 int arraySize,
384 const char *reason,
385 const char *token);
386
Olli Etuaho2935c582015-04-08 14:32:06 +0300387 bool declareVariable(const TSourceLoc &line, const TString &identifier, const TType &type, TVariable **variable);
388
Olli Etuaho856c4972016-08-08 11:38:39 +0300389 void checkCanBeDeclaredWithoutInitializer(const TSourceLoc &line,
390 const TString &identifier,
391 TPublicType *type);
Olli Etuaho376f1b52015-04-13 13:23:41 +0300392
Olli Etuaho8a176262016-08-16 14:23:01 +0300393 bool checkIsValidTypeAndQualifierForArray(const TSourceLoc &indexLocation,
394 const TPublicType &elementType);
395
Olli Etuaho1dded802016-08-18 18:13:13 +0300396 // Assumes that multiplication op has already been set based on the types.
397 bool isMultiplicationTypeCombinationValid(TOperator op, const TType &left, const TType &right);
398
Martin Radev2cc85b32016-08-05 16:22:53 +0300399 bool checkIsMemoryQualifierNotSpecified(const TMemoryQualifier &memoryQualifier,
400 const TSourceLoc &location);
401 void checkOutParameterIsNotImage(const TSourceLoc &line,
402 TQualifier qualifier,
403 const TType &type);
404 void checkOutParameterIsNotOpaqueType(const TSourceLoc &line,
405 TQualifier qualifier,
406 const TType &type);
407 void checkOutParameterIsNotSampler(const TSourceLoc &line,
408 TQualifier qualifier,
409 const TType &type);
410
Jamie Madill06145232015-05-13 13:10:01 -0400411 TIntermTyped *addBinaryMathInternal(
412 TOperator op, TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
Olli Etuaho13389b62016-10-16 11:48:18 +0100413 TIntermBinary *createAssign(TOperator op,
414 TIntermTyped *left,
415 TIntermTyped *right,
416 const TSourceLoc &loc);
Olli Etuahof6c694b2015-03-26 14:50:53 +0200417 // The funcReturnType parameter is expected to be non-null when the operation is a built-in function.
418 // It is expected to be null for other unary operators.
Jamie Madill06145232015-05-13 13:10:01 -0400419 TIntermTyped *createUnaryMath(
420 TOperator op, TIntermTyped *child, const TSourceLoc &loc, const TType *funcReturnType);
Olli Etuahod6b14282015-03-17 14:31:35 +0200421
Olli Etuaho47fd36a2015-03-19 14:22:24 +0200422 // Return true if the checks pass
Jamie Madill06145232015-05-13 13:10:01 -0400423 bool binaryOpCommonCheck(
424 TOperator op, TIntermTyped *left, TIntermTyped *right, const TSourceLoc &loc);
Olli Etuahofa33d582015-04-09 14:33:12 +0300425
426 // Set to true when the last/current declarator list was started with an empty declaration.
427 bool mDeferredSingleDeclarationErrorCheck;
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400428
429 sh::GLenum mShaderType; // vertex or fragment language (future: pack or unpack)
Qiankun Miao7ebb97f2016-09-08 18:01:50 +0800430 ShShaderSpec mShaderSpec; // The language specification compiler conforms to - GLES2 or WebGL.
431 ShCompileOptions mCompileOptions; // Options passed to TCompiler
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400432 int mShaderVersion;
Olli Etuaho6d40bbd2016-09-30 13:49:38 +0100433 TIntermBlock *mTreeRoot; // root of parse tree being created
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400434 int mLoopNestingLevel; // 0 if outside all loops
Qiankun Miao7ebb97f2016-09-08 18:01:50 +0800435 int mStructNestingLevel; // incremented while parsing a struct declaration
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400436 int mSwitchNestingLevel; // 0 if outside all switch statements
Qiankun Miao7ebb97f2016-09-08 18:01:50 +0800437 const TType
438 *mCurrentFunctionType; // the return type of the function that's currently being parsed
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400439 bool mFunctionReturnsValue; // true if a non-void function has a return
Qiankun Miao7ebb97f2016-09-08 18:01:50 +0800440 bool mChecksPrecisionErrors; // true if an error will be generated when a variable is declared
441 // without precision, explicit or implicit.
Olli Etuahoa6996682015-10-12 14:32:30 +0300442 bool mFragmentPrecisionHighOnESSL1; // true if highp precision is supported when compiling
443 // ESSL1.
Jamie Madill6e06b1f2015-05-14 10:01:17 -0400444 TLayoutMatrixPacking mDefaultMatrixPacking;
445 TLayoutBlockStorage mDefaultBlockStorage;
446 TString mHashErrMsg;
447 TDiagnostics mDiagnostics;
448 TDirectiveHandler mDirectiveHandler;
449 pp::Preprocessor mPreprocessor;
450 void *mScanner;
Jamie Madill14e95b32015-05-07 10:10:41 -0400451 bool mUsesFragData; // track if we are using both gl_FragData and gl_FragColor
452 bool mUsesFragColor;
Kimmo Kinnunenb18609b2015-07-16 14:13:11 +0300453 bool mUsesSecondaryOutputs; // Track if we are using either gl_SecondaryFragData or
454 // gl_Secondary FragColor or both.
Olli Etuahoe1a94c62015-11-16 17:35:25 +0200455 int mMinProgramTexelOffset;
456 int mMaxProgramTexelOffset;
Martin Radev802abe02016-08-04 17:48:32 +0300457
458 // keep track of local group size declared in layout. It should be declared only once.
459 bool mComputeShaderLocalSizeDeclared;
Martin Radev4c4c8e72016-08-04 12:25:34 +0300460 sh::WorkGroupSize mComputeShaderLocalSize;
Martin Radev70866b82016-07-22 15:27:42 +0300461 // keeps track whether we are declaring / defining a function
462 bool mDeclaringFunction;
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +0000463};
464
Jamie Madill06145232015-05-13 13:10:01 -0400465int PaParseStrings(
466 size_t count, const char *const string[], const int length[], TParseContext *context);
daniel@transgaming.com4f39fd92010-03-08 20:26:45 +0000467
Geoff Lang0a73dd82014-11-19 16:18:08 -0500468#endif // COMPILER_TRANSLATOR_PARSECONTEXT_H_