BsParserFX.y 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950
  1. %{
  2. #include "BsParserFX.h"
  3. #include "BsLexerFX.h"
  4. #define inline
  5. void yyerror(YYLTYPE *locp, ParseState* parse_state, yyscan_t scanner, const char *msg);
  6. %}
  7. %code requires{
  8. #include "BsMMAlloc.h"
  9. #include "BsASTFX.h"
  10. #ifndef YY_TYPEDEF_YY_SCANNER_T
  11. #define YY_TYPEDEF_YY_SCANNER_T
  12. typedef void* yyscan_t;
  13. #endif
  14. #define ADD_PARAMETER(OUTPUT, TYPE, NAME) \
  15. OUTPUT = nodeCreate(parse_state->memContext, NT_Parameter); \
  16. nodePush(parse_state, OUTPUT); \
  17. \
  18. NodeOption paramType; \
  19. paramType.type = OT_ParamType; \
  20. paramType.value.intValue = TYPE; \
  21. \
  22. NodeOption paramName; \
  23. paramName.type = OT_Identifier; \
  24. paramName.value.strValue = NAME; \
  25. \
  26. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &paramType); \
  27. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &paramName); \
  28. }
  29. %output "BsParserFX.c"
  30. %defines "BsParserFX.h"
  31. %define api.pure
  32. %locations
  33. %lex-param { yyscan_t scanner }
  34. %parse-param { ParseState* parse_state }
  35. %parse-param { yyscan_t scanner }
  36. %glr-parser
  37. %union {
  38. int intValue;
  39. float floatValue;
  40. float matrixValue[16];
  41. int intVectorValue[4];
  42. const char* strValue;
  43. ASTFXNode* nodePtr;
  44. NodeOption nodeOption;
  45. }
  46. /* Value types */
  47. %token <intValue> TOKEN_INTEGER
  48. %token <floatValue> TOKEN_FLOAT
  49. %token <intValue> TOKEN_BOOLEAN
  50. %token <strValue> TOKEN_STRING
  51. %token <strValue> TOKEN_IDENTIFIER
  52. %token <intValue> TOKEN_FILLMODEVALUE
  53. %token <intValue> TOKEN_CULLMODEVALUE
  54. %token <intValue> TOKEN_COMPFUNCVALUE
  55. %token <intValue> TOKEN_OPVALUE
  56. %token <intValue> TOKEN_COLORMASK
  57. %token <intValue> TOKEN_ADDRMODEVALUE
  58. %token <intValue> TOKEN_FILTERVALUE
  59. %token <intValue> TOKEN_BLENDOPVALUE
  60. %token <intValue> TOKEN_BUFFERUSAGE
  61. %token <intValue> TOKEN_FLOATTYPE
  62. %token <intValue> TOKEN_FLOAT2TYPE
  63. %token <intValue> TOKEN_FLOAT3TYPE
  64. %token <intValue> TOKEN_FLOAT4TYPE
  65. %token <intValue> TOKEN_INTTYPE
  66. %token <intValue> TOKEN_INT2TYPE
  67. %token <intValue> TOKEN_INT3TYPE
  68. %token <intValue> TOKEN_INT4TYPE
  69. %token <intValue> TOKEN_COLORTYPE
  70. %token <intValue> TOKEN_MAT2x2TYPE
  71. %token <intValue> TOKEN_MAT2x3TYPE
  72. %token <intValue> TOKEN_MAT2x4TYPE
  73. %token <intValue> TOKEN_MAT3x2TYPE
  74. %token <intValue> TOKEN_MAT3x3TYPE
  75. %token <intValue> TOKEN_MAT3x4TYPE
  76. %token <intValue> TOKEN_MAT4x2TYPE
  77. %token <intValue> TOKEN_MAT4x3TYPE
  78. %token <intValue> TOKEN_MAT4x4TYPE
  79. %token <intValue> TOKEN_SAMPLER1D
  80. %token <intValue> TOKEN_SAMPLER2D
  81. %token <intValue> TOKEN_SAMPLER3D
  82. %token <intValue> TOKEN_SAMPLERCUBE
  83. %token <intValue> TOKEN_SAMPLER2DMS
  84. %token <intValue> TOKEN_TEXTURE1D
  85. %token <intValue> TOKEN_TEXTURE2D
  86. %token <intValue> TOKEN_TEXTURE3D
  87. %token <intValue> TOKEN_TEXTURECUBE
  88. %token <intValue> TOKEN_TEXTURE2DMS
  89. %token <intValue> TOKEN_BYTEBUFFER
  90. %token <intValue> TOKEN_STRUCTBUFFER
  91. %token <intValue> TOKEN_RWTYPEDBUFFER
  92. %token <intValue> TOKEN_RWBYTEBUFFER
  93. %token <intValue> TOKEN_RWSTRUCTBUFFER
  94. %token <intValue> TOKEN_RWAPPENDBUFFER
  95. %token <intValue> TOKEN_RWCONSUMEBUFFER
  96. %token TOKEN_PARAMSBLOCK
  97. /* Qualifiers */
  98. %token TOKEN_AUTO TOKEN_ALIAS TOKEN_SHARED TOKEN_USAGE
  99. /* Shader keywords */
  100. %token TOKEN_SEPARABLE TOKEN_QUEUE TOKEN_PRIORITY TOKEN_TRANSPARENT
  101. %token TOKEN_PARAMETERS TOKEN_BLOCKS TOKEN_TECHNIQUE
  102. /* Technique keywords */
  103. %token TOKEN_RENDERER TOKEN_LANGUAGE TOKEN_INCLUDE TOKEN_PASS
  104. /* Pass keywords */
  105. %token TOKEN_VERTEX TOKEN_FRAGMENT TOKEN_GEOMETRY TOKEN_HULL TOKEN_DOMAIN TOKEN_COMPUTE TOKEN_COMMON
  106. %token TOKEN_STENCILREF
  107. %token TOKEN_FILLMODE TOKEN_CULLMODE TOKEN_DEPTHBIAS TOKEN_SDEPTHBIAS
  108. %token TOKEN_DEPTHCLIP TOKEN_SCISSOR TOKEN_MULTISAMPLE TOKEN_AALINE
  109. %token TOKEN_DEPTHREAD TOKEN_DEPTHWRITE TOKEN_COMPAREFUNC TOKEN_STENCIL
  110. %token TOKEN_STENCILREADMASK TOKEN_STENCILWRITEMASK TOKEN_STENCILOPFRONT TOKEN_STENCILOPBACK
  111. %token TOKEN_FAIL TOKEN_ZFAIL
  112. %token TOKEN_ALPHATOCOVERAGE TOKEN_INDEPENDANTBLEND TOKEN_TARGET TOKEN_INDEX
  113. %token TOKEN_BLEND TOKEN_COLOR TOKEN_ALPHA TOKEN_WRITEMASK
  114. %token TOKEN_SOURCE TOKEN_DEST TOKEN_OP
  115. /* Sampler state keywords */
  116. %token TOKEN_ADDRMODE TOKEN_MINFILTER TOKEN_MAGFILTER TOKEN_MIPFILTER
  117. %token TOKEN_MAXANISO TOKEN_MIPBIAS TOKEN_MIPMIN TOKEN_MIPMAX
  118. %token TOKEN_BORDERCOLOR TOKEN_U TOKEN_V TOKEN_W
  119. %type <nodePtr> shader;
  120. %type <nodeOption> shader_statement;
  121. %type <nodeOption> shader_option;
  122. %type <nodePtr> technique;
  123. %type <nodePtr> technique_header;
  124. %type <nodeOption> technique_statement;
  125. %type <nodeOption> technique_option;
  126. %type <nodePtr> pass;
  127. %type <nodePtr> pass_header;
  128. %type <nodeOption> pass_statement;
  129. %type <nodeOption> pass_option;
  130. %type <nodePtr> code;
  131. %type <nodePtr> code_header;
  132. %type <nodePtr> stencil_op_front_header;
  133. %type <nodePtr> stencil_op_back_header;
  134. %type <nodeOption> stencil_op_option;
  135. %type <nodePtr> target;
  136. %type <nodePtr> target_header;
  137. %type <nodeOption> target_statement;
  138. %type <nodeOption> target_option;
  139. %type <nodePtr> blend_color_header;
  140. %type <nodePtr> blend_alpha_header;
  141. %type <nodeOption> blenddef_option;
  142. %type <nodeOption> sampler_state_option;
  143. %type <nodePtr> addr_mode;
  144. %type <nodePtr> addr_mode_header;
  145. %type <nodeOption> addr_mode_option;
  146. %type <nodePtr> parameters
  147. %type <nodePtr> parameters_header
  148. %type <nodeOption> parameter
  149. %type <nodePtr> block_header
  150. %type <nodeOption> block
  151. %type <nodePtr> blocks_header
  152. %type <nodePtr> blocks
  153. %type <nodeOption> qualifier
  154. %type <matrixValue> float2;
  155. %type <matrixValue> float3;
  156. %type <matrixValue> float4;
  157. %type <intVectorValue> int2;
  158. %type <intVectorValue> int3;
  159. %type <intVectorValue> int4;
  160. %type <matrixValue> mat6;
  161. %type <matrixValue> mat8;
  162. %type <matrixValue> mat9;
  163. %type <matrixValue> mat12;
  164. %type <matrixValue> mat16;
  165. %type <nodePtr> param_header_float
  166. %type <nodePtr> param_header_float2
  167. %type <nodePtr> param_header_float3
  168. %type <nodePtr> param_header_float4
  169. %type <nodePtr> param_header_int
  170. %type <nodePtr> param_header_int2
  171. %type <nodePtr> param_header_int3
  172. %type <nodePtr> param_header_int4
  173. %type <nodePtr> param_header_color
  174. %type <nodePtr> param_header_mat2x2
  175. %type <nodePtr> param_header_mat2x3
  176. %type <nodePtr> param_header_mat2x4
  177. %type <nodePtr> param_header_mat3x2
  178. %type <nodePtr> param_header_mat3x3
  179. %type <nodePtr> param_header_mat3x4
  180. %type <nodePtr> param_header_mat4x2
  181. %type <nodePtr> param_header_mat4x3
  182. %type <nodePtr> param_header_mat4x4
  183. %type <nodePtr> param_header_sampler
  184. %type <nodePtr> param_header_texture
  185. %type <nodePtr> param_header_buffer
  186. %type <nodePtr> param_header_qualified_sampler
  187. %type <nodeOption> param_body_float
  188. %type <nodeOption> param_body_float2
  189. %type <nodeOption> param_body_float3
  190. %type <nodeOption> param_body_float4
  191. %type <nodeOption> param_body_int
  192. %type <nodeOption> param_body_int2
  193. %type <nodeOption> param_body_int3
  194. %type <nodeOption> param_body_int4
  195. %type <nodeOption> param_body_mat6
  196. %type <nodeOption> param_body_mat8
  197. %type <nodeOption> param_body_mat9
  198. %type <nodeOption> param_body_mat12
  199. %type <nodeOption> param_body_mat16
  200. %type <nodeOption> param_body_sampler
  201. %type <nodeOption> param_body_tex
  202. %%
  203. /* Shader */
  204. shader
  205. : /* empty */ { }
  206. | shader_statement shader { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  207. ;
  208. shader_statement
  209. : shader_option
  210. | technique { $$.type = OT_Technique; $$.value.nodePtr = $1; }
  211. | parameters { $$.type = OT_Parameters; $$.value.nodePtr = $1; }
  212. | blocks { $$.type = OT_Blocks; $$.value.nodePtr = $1; }
  213. ;
  214. shader_option
  215. : TOKEN_SEPARABLE '=' TOKEN_BOOLEAN ';' { $$.type = OT_Separable; $$.value.intValue = $3; }
  216. | TOKEN_QUEUE '=' TOKEN_INTEGER ';' { $$.type = OT_Queue; $$.value.intValue = $3; }
  217. | TOKEN_PRIORITY '=' TOKEN_INTEGER ';' { $$.type = OT_Priority; $$.value.intValue = $3; }
  218. | TOKEN_INCLUDE '=' TOKEN_STRING ';' { $$.type = OT_Include; $$.value.strValue = $3; }
  219. | TOKEN_TRANSPARENT '=' TOKEN_BOOLEAN ';' { $$.type = OT_Transparent; $$.value.intValue = $3; }
  220. ;
  221. /* Technique */
  222. technique
  223. : technique_header '{' technique_body '}' ';' { nodePop(parse_state); $$ = $1; }
  224. ;
  225. technique_header
  226. : TOKEN_TECHNIQUE '='
  227. {
  228. $$ = nodeCreate(parse_state->memContext, NT_Technique);
  229. nodePush(parse_state, $$);
  230. }
  231. ;
  232. technique_body
  233. : /* empty */
  234. | technique_statement technique_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  235. ;
  236. technique_statement
  237. : technique_option
  238. | pass { $$.type = OT_Pass; $$.value.nodePtr = $1; }
  239. | pass_option
  240. | code { $$.type = OT_Code; $$.value.nodePtr = $1; }
  241. ;
  242. technique_option
  243. : TOKEN_RENDERER '=' TOKEN_STRING ';' { $$.type = OT_Renderer; $$.value.strValue = $3; }
  244. | TOKEN_LANGUAGE '=' TOKEN_STRING ';' { $$.type = OT_Language; $$.value.strValue = $3; }
  245. ;
  246. /* Pass */
  247. pass
  248. : pass_header '{' pass_body '}' ';' { nodePop(parse_state); $$ = $1; }
  249. ;
  250. pass_header
  251. : TOKEN_PASS '='
  252. {
  253. $$ = nodeCreate(parse_state->memContext, NT_Pass);
  254. nodePush(parse_state, $$);
  255. }
  256. ;
  257. pass_body
  258. : /* empty */
  259. | pass_statement pass_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  260. ;
  261. pass_statement
  262. : pass_option
  263. | code { $$.type = OT_Code; $$.value.nodePtr = $1; }
  264. ;
  265. pass_option
  266. : TOKEN_INDEX '=' TOKEN_INTEGER ';' { $$.type = OT_Index; $$.value.intValue = $3; }
  267. | TOKEN_FILLMODE '=' TOKEN_FILLMODEVALUE ';' { $$.type = OT_FillMode; $$.value.intValue = $3; }
  268. | TOKEN_CULLMODE '=' TOKEN_CULLMODEVALUE ';' { $$.type = OT_CullMode; $$.value.intValue = $3; }
  269. | TOKEN_DEPTHBIAS '=' TOKEN_FLOAT ';' { $$.type = OT_DepthBias; $$.value.floatValue = $3; }
  270. | TOKEN_SDEPTHBIAS '=' TOKEN_FLOAT ';' { $$.type = OT_SDepthBias; $$.value.floatValue = $3; }
  271. | TOKEN_DEPTHCLIP '=' TOKEN_BOOLEAN ';' { $$.type = OT_DepthClip; $$.value.intValue = $3; }
  272. | TOKEN_SCISSOR '=' TOKEN_BOOLEAN ';' { $$.type = OT_Scissor; $$.value.intValue = $3; }
  273. | TOKEN_MULTISAMPLE '=' TOKEN_BOOLEAN ';' { $$.type = OT_Multisample; $$.value.intValue = $3; }
  274. | TOKEN_AALINE '=' TOKEN_BOOLEAN ';' { $$.type = OT_AALine; $$.value.intValue = $3; }
  275. | TOKEN_DEPTHREAD '=' TOKEN_BOOLEAN ';' { $$.type = OT_DepthRead; $$.value.intValue = $3; }
  276. | TOKEN_DEPTHWRITE '=' TOKEN_BOOLEAN ';' { $$.type = OT_DepthWrite; $$.value.intValue = $3; }
  277. | TOKEN_COMPAREFUNC '=' TOKEN_COMPFUNCVALUE ';' { $$.type = OT_CompareFunc; $$.value.intValue = $3; }
  278. | TOKEN_STENCIL '=' TOKEN_BOOLEAN ';' { $$.type = OT_Stencil; $$.value.intValue = $3; }
  279. | TOKEN_STENCILREADMASK '=' TOKEN_INTEGER ';' { $$.type = OT_StencilReadMask; $$.value.intValue = $3; }
  280. | TOKEN_STENCILWRITEMASK '=' TOKEN_INTEGER ';' { $$.type = OT_StencilWriteMask; $$.value.intValue = $3; }
  281. | stencil_op_front_header '{' stencil_op_body '}' ';' { nodePop(parse_state); $$.type = OT_StencilOpFront; $$.value.nodePtr = $1; }
  282. | stencil_op_back_header '{' stencil_op_body '}' ';' { nodePop(parse_state); $$.type = OT_StencilOpBack; $$.value.nodePtr = $1; }
  283. | stencil_op_front_header '{' stencil_op_body_init '}' ';' { nodePop(parse_state); $$.type = OT_StencilOpFront; $$.value.nodePtr = $1; }
  284. | stencil_op_back_header '{' stencil_op_body_init '}' ';' { nodePop(parse_state); $$.type = OT_StencilOpBack; $$.value.nodePtr = $1; }
  285. | TOKEN_ALPHATOCOVERAGE '=' TOKEN_BOOLEAN ';' { $$.type = OT_AlphaToCoverage; $$.value.intValue = $3; }
  286. | TOKEN_INDEPENDANTBLEND '=' TOKEN_BOOLEAN ';' { $$.type = OT_IndependantBlend; $$.value.intValue = $3; }
  287. | target { $$.type = OT_Target; $$.value.nodePtr = $1; }
  288. | TOKEN_STENCILREF '=' TOKEN_INTEGER ';' { $$.type = OT_StencilRef; $$.value.intValue = $3; }
  289. ;
  290. /* Code blocks */
  291. code
  292. : code_header '{' TOKEN_INDEX '=' TOKEN_INTEGER ';' '}' ';'
  293. {
  294. NodeOption index;
  295. index.type = OT_Index;
  296. index.value.intValue = $5;
  297. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &index);
  298. nodePop(parse_state);
  299. $$ = $1;
  300. }
  301. ;
  302. code_header
  303. : TOKEN_VERTEX '='
  304. {
  305. $$ = nodeCreate(parse_state->memContext, NT_Code);
  306. nodePush(parse_state, $$);
  307. }
  308. | TOKEN_FRAGMENT '='
  309. {
  310. $$ = nodeCreate(parse_state->memContext, NT_Code);
  311. nodePush(parse_state, $$);
  312. }
  313. | TOKEN_GEOMETRY '='
  314. {
  315. $$ = nodeCreate(parse_state->memContext, NT_Code);
  316. nodePush(parse_state, $$);
  317. }
  318. | TOKEN_HULL '='
  319. {
  320. $$ = nodeCreate(parse_state->memContext, NT_Code);
  321. nodePush(parse_state, $$);
  322. }
  323. | TOKEN_DOMAIN '='
  324. {
  325. $$ = nodeCreate(parse_state->memContext, NT_Code);
  326. nodePush(parse_state, $$);
  327. }
  328. | TOKEN_COMPUTE '='
  329. {
  330. $$ = nodeCreate(parse_state->memContext, NT_Code);
  331. nodePush(parse_state, $$);
  332. }
  333. | TOKEN_COMMON '='
  334. {
  335. $$ = nodeCreate(parse_state->memContext, NT_Code);
  336. nodePush(parse_state, $$);
  337. }
  338. ;
  339. /* Stencil op */
  340. stencil_op_front_header
  341. : TOKEN_STENCILOPFRONT '='
  342. {
  343. $$ = nodeCreate(parse_state->memContext, NT_StencilOp);
  344. nodePush(parse_state, $$);
  345. }
  346. ;
  347. stencil_op_back_header
  348. : TOKEN_STENCILOPBACK '='
  349. {
  350. $$ = nodeCreate(parse_state->memContext, NT_StencilOp);
  351. nodePush(parse_state, $$);
  352. }
  353. ;
  354. stencil_op_body_init
  355. : TOKEN_OPVALUE ',' TOKEN_OPVALUE ',' TOKEN_OPVALUE ',' TOKEN_COMPFUNCVALUE
  356. {
  357. NodeOption fail; fail.type = OT_Fail; fail.value.intValue = $1;
  358. NodeOption zfail; zfail.type = OT_ZFail; zfail.value.intValue = $3;
  359. NodeOption pass; pass.type = OT_PassOp; pass.value.intValue = $5;
  360. NodeOption cmp; cmp.type = OT_CompareFunc; cmp.value.intValue = $7;
  361. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &fail);
  362. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &zfail);
  363. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &pass);
  364. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &cmp);
  365. }
  366. ;
  367. stencil_op_body
  368. : /* empty */
  369. | stencil_op_option stencil_op_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  370. ;
  371. stencil_op_option
  372. : TOKEN_FAIL '=' TOKEN_OPVALUE ';' { $$.type = OT_Fail; $$.value.intValue = $3; }
  373. | TOKEN_ZFAIL '=' TOKEN_OPVALUE ';' { $$.type = OT_ZFail; $$.value.intValue = $3; }
  374. | TOKEN_PASS '=' TOKEN_OPVALUE ';' { $$.type = OT_PassOp; $$.value.intValue = $3; }
  375. | TOKEN_COMPAREFUNC '=' TOKEN_COMPFUNCVALUE ';' { $$.type = OT_CompareFunc; $$.value.intValue = $3; }
  376. ;
  377. /* Target */
  378. target
  379. : target_header '{' target_body '}' ';' { nodePop(parse_state); $$ = $1; }
  380. ;
  381. target_header
  382. : TOKEN_TARGET '='
  383. {
  384. $$ = nodeCreate(parse_state->memContext, NT_Target);
  385. nodePush(parse_state, $$);
  386. }
  387. ;
  388. target_body
  389. : /* empty */
  390. | target_statement target_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  391. ;
  392. target_statement
  393. : target_option
  394. ;
  395. target_option
  396. : TOKEN_INDEX '=' TOKEN_INTEGER ';' { $$.type = OT_Index; $$.value.intValue = $3; }
  397. | TOKEN_BLEND '=' TOKEN_BOOLEAN ';' { $$.type = OT_Blend; $$.value.intValue = $3; }
  398. | blend_color_header '{' blenddef_body '}' ';' { nodePop(parse_state); $$.type = OT_Color; $$.value.nodePtr = $1; }
  399. | blend_alpha_header '{' blenddef_body '}' ';' { nodePop(parse_state); $$.type = OT_Alpha; $$.value.nodePtr = $1; }
  400. | blend_color_header '{' blenddef_body_init '}' ';' { nodePop(parse_state); $$.type = OT_Color; $$.value.nodePtr = $1; }
  401. | blend_alpha_header '{' blenddef_body_init '}' ';' { nodePop(parse_state); $$.type = OT_Alpha; $$.value.nodePtr = $1; }
  402. | TOKEN_WRITEMASK '=' TOKEN_COLORMASK ';' { $$.type = OT_WriteMask; $$.value.intValue = $3; }
  403. ;
  404. /* Blend definition */
  405. blend_color_header
  406. : TOKEN_COLOR '='
  407. {
  408. $$ = nodeCreate(parse_state->memContext, NT_BlendDef);
  409. nodePush(parse_state, $$);
  410. }
  411. ;
  412. blend_alpha_header
  413. : TOKEN_ALPHA '='
  414. {
  415. $$ = nodeCreate(parse_state->memContext, NT_BlendDef);
  416. nodePush(parse_state, $$);
  417. }
  418. ;
  419. blenddef_body
  420. : /* empty */
  421. | blenddef_option blenddef_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  422. ;
  423. blenddef_body_init
  424. : TOKEN_OPVALUE ',' TOKEN_OPVALUE ',' TOKEN_BLENDOPVALUE
  425. {
  426. NodeOption src; src.type = OT_Source; src.value.intValue = $1;
  427. NodeOption dst; dst.type = OT_Dest; dst.value.intValue = $3;
  428. NodeOption op; op.type = OT_Op; op.value.intValue = $5;
  429. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &src);
  430. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &dst);
  431. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &op);
  432. }
  433. ;
  434. blenddef_option
  435. : TOKEN_SOURCE '=' TOKEN_OPVALUE ';' { $$.type = OT_Source; $$.value.intValue = $3; }
  436. | TOKEN_DEST '=' TOKEN_OPVALUE ';' { $$.type = OT_Dest; $$.value.intValue = $3; }
  437. | TOKEN_OP '=' TOKEN_BLENDOPVALUE ';' { $$.type = OT_Op; $$.value.intValue = $3; }
  438. ;
  439. /* Sampler state */
  440. sampler_state_body
  441. : /* empty */
  442. | sampler_state_option sampler_state_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  443. ;
  444. sampler_state_option
  445. : addr_mode { $$.type = OT_AddrMode; $$.value.nodePtr = $1; }
  446. | TOKEN_MINFILTER '=' TOKEN_FILTERVALUE ';' { $$.type = OT_MinFilter; $$.value.intValue = $3; }
  447. | TOKEN_MAGFILTER '=' TOKEN_FILTERVALUE ';' { $$.type = OT_MagFilter; $$.value.intValue = $3; }
  448. | TOKEN_MIPFILTER '=' TOKEN_FILTERVALUE ';' { $$.type = OT_MipFilter; $$.value.intValue = $3; }
  449. | TOKEN_MAXANISO '=' TOKEN_INTEGER ';' { $$.type = OT_MaxAniso; $$.value.intValue = $3; }
  450. | TOKEN_MIPBIAS '=' TOKEN_FLOAT ';' { $$.type = OT_MipBias; $$.value.floatValue = $3; }
  451. | TOKEN_MIPMIN '=' TOKEN_FLOAT ';' { $$.type = OT_MipMin; $$.value.floatValue = $3; }
  452. | TOKEN_MIPMAX '=' TOKEN_FLOAT ';' { $$.type = OT_MipMax; $$.value.floatValue = $3; }
  453. | TOKEN_BORDERCOLOR '=' float4 ';' { $$.type = OT_BorderColor; memcpy($$.value.matrixValue, $3, sizeof($3)); }
  454. | TOKEN_COMPAREFUNC '=' TOKEN_COMPFUNCVALUE ';' { $$.type = OT_CompareFunc; $$.value.intValue = $3; }
  455. ;
  456. /* Addresing mode */
  457. addr_mode
  458. : addr_mode_header '{' addr_mode_body '}' ';' { nodePop(parse_state); $$ = $1; }
  459. | addr_mode_header '{' addr_mode_body_init '}' ';' { nodePop(parse_state); $$ = $1; }
  460. ;
  461. addr_mode_header
  462. : TOKEN_ADDRMODE '='
  463. {
  464. $$ = nodeCreate(parse_state->memContext, NT_AddrMode);
  465. nodePush(parse_state, $$);
  466. }
  467. ;
  468. addr_mode_body_init
  469. : TOKEN_ADDRMODEVALUE ',' TOKEN_ADDRMODEVALUE ',' TOKEN_ADDRMODEVALUE
  470. {
  471. NodeOption u; u.type = OT_U; u.value.intValue = $1;
  472. NodeOption v; v.type = OT_V; v.value.intValue = $3;
  473. NodeOption w; w.type = OT_W; w.value.intValue = $5;
  474. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &u);
  475. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &v);
  476. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &w);
  477. }
  478. ;
  479. addr_mode_body
  480. : /* empty */
  481. | addr_mode_option addr_mode_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  482. ;
  483. addr_mode_option
  484. : TOKEN_U '=' TOKEN_ADDRMODEVALUE ';' { $$.type = OT_U; $$.value.intValue = $3; }
  485. | TOKEN_V '=' TOKEN_ADDRMODEVALUE ';' { $$.type = OT_V; $$.value.intValue = $3; }
  486. | TOKEN_W '=' TOKEN_ADDRMODEVALUE ';' { $$.type = OT_W; $$.value.intValue = $3; }
  487. ;
  488. /* Value types */
  489. float2
  490. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT '}' { $$[0] = $2; $$[1] = $4; }
  491. ;
  492. float3
  493. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}' { $$[0] = $2; $$[1] = $4; $$[2] = $6; }
  494. ;
  495. float4
  496. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}' { $$[0] = $2; $$[1] = $4; $$[2] = $6; $$[3] = $8;}
  497. ;
  498. int2
  499. : '{' TOKEN_INTEGER ',' TOKEN_INTEGER '}' { $$[0] = $2; $$[1] = $4; }
  500. ;
  501. int3
  502. : '{' TOKEN_INTEGER ',' TOKEN_INTEGER ',' TOKEN_INTEGER '}' { $$[0] = $2; $$[1] = $4; $$[2] = $6; }
  503. ;
  504. int4
  505. : '{' TOKEN_INTEGER ',' TOKEN_INTEGER ',' TOKEN_INTEGER ',' TOKEN_INTEGER '}' { $$[0] = $2; $$[1] = $4; $$[2] = $6; $$[3] = $8;}
  506. ;
  507. mat6
  508. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  509. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}'
  510. {
  511. $$[0] = $2; $$[1] = $4; $$[2] = $6;
  512. $$[3] = $8; $$[4] = $10; $$[5] = $12;
  513. }
  514. ;
  515. mat8
  516. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  517. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  518. TOKEN_FLOAT ',' TOKEN_FLOAT '}'
  519. {
  520. $$[0] = $2; $$[1] = $4; $$[2] = $6;
  521. $$[3] = $8; $$[4] = $10; $$[5] = $12;
  522. $$[6] = $14; $$[7] = $16;
  523. }
  524. ;
  525. mat9
  526. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  527. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  528. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}'
  529. {
  530. $$[0] = $2; $$[1] = $4; $$[2] = $6;
  531. $$[3] = $8; $$[4] = $10; $$[5] = $12;
  532. $$[6] = $14; $$[7] = $16; $$[8] = $18;
  533. }
  534. ;
  535. mat12
  536. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  537. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  538. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}'
  539. {
  540. $$[0] = $2; $$[1] = $4; $$[2] = $6; $$[3] = $8;
  541. $$[4] = $10; $$[5] = $12; $$[6] = $14; $$[7] = $16;
  542. $$[8] = $18; $$[9] = $20; $$[10] = $22; $$[11] = $24;
  543. }
  544. ;
  545. mat16
  546. : '{' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  547. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  548. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ','
  549. TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT ',' TOKEN_FLOAT '}'
  550. {
  551. $$[0] = $2; $$[1] = $4; $$[2] = $6; $$[3] = $8;
  552. $$[4] = $10; $$[5] = $12; $$[6] = $14; $$[7] = $16;
  553. $$[8] = $18; $$[9] = $20; $$[10] = $22; $$[11] = $24;
  554. $$[12] = $26; $$[13] = $28; $$[14] = $30; $$[15] = $32;
  555. }
  556. ;
  557. /* Parameters */
  558. parameters
  559. : parameters_header '{' parameters_body '}' ';' { nodePop(parse_state); $$ = $1; }
  560. ;
  561. parameters_header
  562. : TOKEN_PARAMETERS '='
  563. {
  564. $$ = nodeCreate(parse_state->memContext, NT_Parameters);
  565. nodePush(parse_state, $$);
  566. }
  567. ;
  568. parameters_body
  569. : /* empty */
  570. | parameter parameters_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  571. ;
  572. parameter
  573. : param_header_float qualifier_list param_body_float ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  574. | param_header_float2 qualifier_list param_body_float2 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  575. | param_header_float3 qualifier_list param_body_float3 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  576. | param_header_float4 qualifier_list param_body_float4 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  577. | param_header_int qualifier_list param_body_int ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  578. | param_header_int2 qualifier_list param_body_int2 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  579. | param_header_int3 qualifier_list param_body_int3 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  580. | param_header_int4 qualifier_list param_body_int4 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  581. | param_header_color qualifier_list param_body_float4 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  582. | param_header_mat2x2 qualifier_list param_body_float4 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  583. | param_header_mat2x3 qualifier_list param_body_mat6 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  584. | param_header_mat2x4 qualifier_list param_body_mat8 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  585. | param_header_mat3x2 qualifier_list param_body_mat6 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  586. | param_header_mat3x3 qualifier_list param_body_mat9 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  587. | param_header_mat3x4 qualifier_list param_body_mat12 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  588. | param_header_mat4x2 qualifier_list param_body_mat8 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  589. | param_header_mat4x3 qualifier_list param_body_mat12 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  590. | param_header_mat4x4 qualifier_list param_body_mat16 ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  591. | param_header_texture qualifier_list param_body_tex ';' { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$3); nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  592. | param_header_buffer qualifier_list ';' { nodePop(parse_state); $$.type = OT_Parameter; $$.value.nodePtr = $1; }
  593. | param_header_qualified_sampler param_body_sampler ';'
  594. {
  595. nodePop(parse_state);
  596. NodeOption samplerState;
  597. samplerState.type = OT_SamplerState;
  598. samplerState.value.nodePtr = $1;
  599. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &samplerState);
  600. $$.type = OT_Parameter; $$.value.nodePtr = parse_state->topNode;
  601. nodePop(parse_state);
  602. }
  603. ;
  604. param_header_float
  605. : TOKEN_FLOATTYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  606. ;
  607. param_header_float2
  608. : TOKEN_FLOAT2TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  609. ;
  610. param_header_float3
  611. : TOKEN_FLOAT3TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  612. ;
  613. param_header_float4
  614. : TOKEN_FLOAT4TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  615. ;
  616. param_header_int
  617. : TOKEN_INTTYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  618. ;
  619. param_header_int2
  620. : TOKEN_INT2TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  621. ;
  622. param_header_int3
  623. : TOKEN_INT3TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  624. ;
  625. param_header_int4
  626. : TOKEN_INT4TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  627. ;
  628. param_header_color
  629. : TOKEN_COLORTYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  630. ;
  631. param_header_mat2x2
  632. : TOKEN_MAT2x2TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  633. ;
  634. param_header_mat2x3
  635. : TOKEN_MAT2x3TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  636. ;
  637. param_header_mat2x4
  638. : TOKEN_MAT2x4TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  639. ;
  640. param_header_mat3x2
  641. : TOKEN_MAT3x2TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  642. ;
  643. param_header_mat3x3
  644. : TOKEN_MAT3x3TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  645. ;
  646. param_header_mat3x4
  647. : TOKEN_MAT3x4TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  648. ;
  649. param_header_mat4x2
  650. : TOKEN_MAT4x2TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  651. ;
  652. param_header_mat4x3
  653. : TOKEN_MAT4x3TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  654. ;
  655. param_header_mat4x4
  656. : TOKEN_MAT4x4TYPE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  657. ;
  658. param_header_sampler
  659. : TOKEN_SAMPLER1D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  660. | TOKEN_SAMPLER2D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  661. | TOKEN_SAMPLER3D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  662. | TOKEN_SAMPLERCUBE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  663. | TOKEN_SAMPLER2DMS TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  664. ;
  665. param_header_texture
  666. : TOKEN_TEXTURE1D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  667. | TOKEN_TEXTURE2D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  668. | TOKEN_TEXTURE3D TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  669. | TOKEN_TEXTURECUBE TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  670. | TOKEN_TEXTURE2DMS TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  671. ;
  672. param_header_buffer
  673. : TOKEN_BYTEBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  674. | TOKEN_STRUCTBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  675. | TOKEN_RWTYPEDBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  676. | TOKEN_RWBYTEBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  677. | TOKEN_RWSTRUCTBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  678. | TOKEN_RWAPPENDBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  679. | TOKEN_RWCONSUMEBUFFER TOKEN_IDENTIFIER { ADD_PARAMETER($$, $1, $2); }
  680. ;
  681. param_header_qualified_sampler
  682. : param_header_sampler qualifier_list
  683. {
  684. $$ = nodeCreate(parse_state->memContext, NT_SamplerState);
  685. nodePush(parse_state, $$);
  686. }
  687. ;
  688. param_body_float
  689. : /* empty */ { $$.type = OT_None; }
  690. | '=' TOKEN_FLOAT { $$.type = OT_ParamValue; $$.value.floatValue = $2; }
  691. ;
  692. param_body_float2
  693. : /* empty */ { $$.type = OT_None; }
  694. | '=' float2 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  695. ;
  696. param_body_float3
  697. : /* empty */ { $$.type = OT_None; }
  698. | '=' float3 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  699. ;
  700. param_body_float4
  701. : /* empty */ { $$.type = OT_None; }
  702. | '=' float4 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  703. ;
  704. param_body_int
  705. : /* empty */ { $$.type = OT_None; }
  706. | '=' TOKEN_INTEGER { $$.type = OT_ParamValue; $$.value.intValue = $2; }
  707. ;
  708. param_body_int2
  709. : /* empty */ { $$.type = OT_None; }
  710. | '=' int2 { $$.type = OT_ParamValue; memcpy($$.value.intVectorValue, $2, sizeof($2)); }
  711. ;
  712. param_body_int3
  713. : /* empty */ { $$.type = OT_None; }
  714. | '=' int3 { $$.type = OT_ParamValue; memcpy($$.value.intVectorValue, $2, sizeof($2)); }
  715. ;
  716. param_body_int4
  717. : /* empty */ { $$.type = OT_None; }
  718. | '=' int4 { $$.type = OT_ParamValue; memcpy($$.value.intVectorValue, $2, sizeof($2)); }
  719. ;
  720. param_body_mat6
  721. : /* empty */ { $$.type = OT_None; }
  722. | '=' mat6 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  723. ;
  724. param_body_mat8
  725. : /* empty */ { $$.type = OT_None; }
  726. | '=' mat8 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  727. ;
  728. param_body_mat9
  729. : /* empty */ { $$.type = OT_None; }
  730. | '=' mat9 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  731. ;
  732. param_body_mat12
  733. : /* empty */ { $$.type = OT_None; }
  734. | '=' mat12 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  735. ;
  736. param_body_mat16
  737. : /* empty */ { $$.type = OT_None; }
  738. | '=' mat16 { $$.type = OT_ParamValue; memcpy($$.value.matrixValue, $2, sizeof($2)); }
  739. ;
  740. param_body_sampler
  741. : /* empty */ { $$.type = OT_None; }
  742. | '=' '{' sampler_state_body '}' { }
  743. ;
  744. param_body_tex
  745. : /* empty */ { $$.type = OT_None; }
  746. | '=' TOKEN_STRING { $$.type = OT_ParamStrValue; $$.value.strValue = $2; }
  747. ;
  748. /* Blocks */
  749. blocks
  750. : blocks_header '{' blocks_body '}' ';' { nodePop(parse_state); $$ = $1; }
  751. ;
  752. blocks_header
  753. : TOKEN_BLOCKS '='
  754. {
  755. $$ = nodeCreate(parse_state->memContext, NT_Blocks);
  756. nodePush(parse_state, $$);
  757. }
  758. ;
  759. blocks_body
  760. : /* empty */
  761. | block blocks_body { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  762. ;
  763. block
  764. : block_header qualifier_list ';' { nodePop(parse_state); $$.type = OT_Block; $$.value.nodePtr = $1; }
  765. ;
  766. block_header
  767. : TOKEN_PARAMSBLOCK TOKEN_IDENTIFIER
  768. {
  769. $$ = nodeCreate(parse_state->memContext, NT_Block);
  770. nodePush(parse_state, $$);
  771. NodeOption blockName;
  772. blockName.type = OT_Identifier;
  773. blockName.value.strValue = $2;
  774. nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &blockName);
  775. }
  776. ;
  777. /* Qualifiers */
  778. qualifier_list
  779. : /* empty */
  780. | qualifier qualifier_list { nodeOptionsAdd(parse_state->memContext, parse_state->topNode->options, &$1); }
  781. ;
  782. qualifier
  783. : ':' TOKEN_ALIAS '(' TOKEN_STRING ')' { $$.type = OT_Alias; $$.value.strValue = $4; }
  784. | ':' TOKEN_AUTO '(' TOKEN_STRING ')' { $$.type = OT_Auto; $$.value.strValue = $4; }
  785. | ':' TOKEN_SHARED '(' TOKEN_BOOLEAN ')' { $$.type = OT_Shared; $$.value.intValue = $4; }
  786. | ':' TOKEN_USAGE '(' TOKEN_BUFFERUSAGE ')' { $$.type = OT_Usage; $$.value.intValue = $4; }
  787. ;
  788. %%
  789. void yyerror(YYLTYPE *locp, ParseState* parse_state, yyscan_t scanner, const char *msg)
  790. {
  791. parse_state->hasError = 1;
  792. parse_state->errorLine = locp->first_line;
  793. parse_state->errorColumn = locp->first_column;
  794. parse_state->errorMessage = mmalloc_strdup(parse_state->memContext, msg);
  795. }