Commit b1672fa0 by John Kessenich Committed by GitHub

Merge pull request #525 from steve-lunarg/implicit-size

HLSL: allow implicit size in array declarations
parents 16a99a38 265c0618
// implicit sized array
uniform float g_array [ ] = { 1, 2, 3, 4, 5 };
// Unused implicit sized array
uniform float g_array_unused [ ] = { 1, 2, 3, 4, 5, 6, 7 };
// Test implicit size arrayed structs
uniform struct mystruct {
int i;
float f;
} g_mystruct[] = {
{ 1, 2.0 },
{ 3, 4.0 },
};
struct PS_OUTPUT { float4 color : SV_Target0; };
// INVALID: implicit size requires an initializer expression.
// uniform float bad[];
// INVALID: function parameters cannot be implicitly sized
// void BadFunction(int a[]) { }
void main(out PS_OUTPUT ps_output)
{
// implicit sized local array
float l_array[] = { 1, 2, 3 };
ps_output.color = g_array[0] + g_array[4] + l_array[1] + g_mystruct[0].f + g_array[idx];
}
...@@ -81,6 +81,7 @@ INSTANTIATE_TEST_CASE_P( ...@@ -81,6 +81,7 @@ INSTANTIATE_TEST_CASE_P(
ToSpirv, HlslCompileTest, ToSpirv, HlslCompileTest,
::testing::ValuesIn(std::vector<FileNameEntryPointPair>{ ::testing::ValuesIn(std::vector<FileNameEntryPointPair>{
{"hlsl.array.frag", "PixelShaderFunction"}, {"hlsl.array.frag", "PixelShaderFunction"},
{"hlsl.array.implicit-size.frag", "PixelShaderFunction"},
{"hlsl.assoc.frag", "PixelShaderFunction"}, {"hlsl.assoc.frag", "PixelShaderFunction"},
{"hlsl.attribute.frag", "PixelShaderFunction"}, {"hlsl.attribute.frag", "PixelShaderFunction"},
{"hlsl.buffer.frag", "PixelShaderFunction"}, {"hlsl.buffer.frag", "PixelShaderFunction"},
......
...@@ -1515,8 +1515,14 @@ bool HlslGrammar::acceptParameterDeclaration(TFunction& function) ...@@ -1515,8 +1515,14 @@ bool HlslGrammar::acceptParameterDeclaration(TFunction& function)
// array_specifier // array_specifier
TArraySizes* arraySizes = nullptr; TArraySizes* arraySizes = nullptr;
acceptArraySpecifier(arraySizes); acceptArraySpecifier(arraySizes);
if (arraySizes) if (arraySizes) {
if (arraySizes->isImplicit()) {
parseContext.error(token.loc, "function parameter array cannot be implicitly sized", "", "");
return false;
}
type->newArraySizes(*arraySizes); type->newArraySizes(*arraySizes);
}
// post_decls // post_decls
acceptPostDecls(type->getQualifier()); acceptPostDecls(type->getQualifier());
...@@ -2601,6 +2607,7 @@ bool HlslGrammar::acceptDefaultLabel(TIntermNode*& statement) ...@@ -2601,6 +2607,7 @@ bool HlslGrammar::acceptDefaultLabel(TIntermNode*& statement)
// array_specifier // array_specifier
// : LEFT_BRACKET integer_expression RGHT_BRACKET post_decls // optional // : LEFT_BRACKET integer_expression RGHT_BRACKET post_decls // optional
// : LEFT_BRACKET RGHT_BRACKET post_decls // optional
// //
void HlslGrammar::acceptArraySpecifier(TArraySizes*& arraySizes) void HlslGrammar::acceptArraySpecifier(TArraySizes*& arraySizes)
{ {
...@@ -2610,21 +2617,25 @@ void HlslGrammar::acceptArraySpecifier(TArraySizes*& arraySizes) ...@@ -2610,21 +2617,25 @@ void HlslGrammar::acceptArraySpecifier(TArraySizes*& arraySizes)
return; return;
TSourceLoc loc = token.loc; TSourceLoc loc = token.loc;
TIntermTyped* sizeExpr; TIntermTyped* sizeExpr = nullptr;
if (! acceptAssignmentExpression(sizeExpr)) {
expected("array-sizing expression"); // Array sizing expression is optional. If ommitted, array is implicitly sized.
return; const bool hasArraySize = acceptAssignmentExpression(sizeExpr);
}
if (! acceptTokenClass(EHTokRightBracket)) { if (! acceptTokenClass(EHTokRightBracket)) {
expected("]"); expected("]");
return; return;
} }
TArraySize arraySize;
parseContext.arraySizeCheck(loc, sizeExpr, arraySize);
arraySizes = new TArraySizes; arraySizes = new TArraySizes;
arraySizes->addInnerSize(arraySize);
if (hasArraySize) {
TArraySize arraySize;
parseContext.arraySizeCheck(loc, sizeExpr, arraySize);
arraySizes->addInnerSize(arraySize);
} else {
arraySizes->addInnerSize(); // implicitly sized
}
} }
// post_decls // post_decls
......
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