[msl-writer] Fix output of array-of-array.
This CL fixes the output of multi-dimentional arrays in the MSL backend. Bug: tint:7, tint:100 Change-Id: I8fe925145973555f77673e9db97f150077e2471f Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/24560 Reviewed-by: David Neto <dneto@google.com>
This commit is contained in:
parent
45101598a1
commit
25058a9213
Binary file not shown.
|
@ -713,20 +713,25 @@ bool GeneratorImpl::EmitType(ast::type::Type* type, const std::string& name) {
|
||||||
} else if (type->IsArray()) {
|
} else if (type->IsArray()) {
|
||||||
auto* ary = type->AsArray();
|
auto* ary = type->AsArray();
|
||||||
|
|
||||||
if (!EmitType(ary->type(), "")) {
|
ast::type::Type* base_type = ary;
|
||||||
|
std::vector<uint32_t> sizes;
|
||||||
|
while (base_type->IsArray()) {
|
||||||
|
if (base_type->AsArray()->IsRuntimeArray()) {
|
||||||
|
sizes.push_back(1);
|
||||||
|
} else {
|
||||||
|
sizes.push_back(base_type->AsArray()->size());
|
||||||
|
}
|
||||||
|
base_type = base_type->AsArray()->type();
|
||||||
|
}
|
||||||
|
if (!EmitType(base_type, "")) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!name.empty()) {
|
if (!name.empty()) {
|
||||||
out_ << " " << namer_.NameFor(name);
|
out_ << " " << namer_.NameFor(name);
|
||||||
}
|
}
|
||||||
out_ << "[";
|
for (uint32_t size : sizes) {
|
||||||
if (ary->IsRuntimeArray()) {
|
out_ << "[" << size << "]";
|
||||||
out_ << "1";
|
|
||||||
} else {
|
|
||||||
out_ << std::to_string(ary->size());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
out_ << "]";
|
|
||||||
} else if (type->IsBool()) {
|
} else if (type->IsBool()) {
|
||||||
out_ << "bool";
|
out_ << "bool";
|
||||||
} else if (type->IsF32()) {
|
} else if (type->IsF32()) {
|
||||||
|
|
|
@ -64,6 +64,39 @@ TEST_F(MslGeneratorImplTest, EmitType_Array) {
|
||||||
EXPECT_EQ(g.result(), "bool ary[4]");
|
EXPECT_EQ(g.result(), "bool ary[4]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(MslGeneratorImplTest, EmitType_ArrayOfArray) {
|
||||||
|
ast::type::BoolType b;
|
||||||
|
ast::type::ArrayType a(&b, 4);
|
||||||
|
ast::type::ArrayType c(&a, 5);
|
||||||
|
|
||||||
|
GeneratorImpl g;
|
||||||
|
ASSERT_TRUE(g.EmitType(&c, "ary")) << g.error();
|
||||||
|
EXPECT_EQ(g.result(), "bool ary[5][4]");
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO(dsinclair): Is this possible? What order should it output in?
|
||||||
|
TEST_F(MslGeneratorImplTest, DISABLED_EmitType_ArrayOfArrayOfRuntimeArray) {
|
||||||
|
ast::type::BoolType b;
|
||||||
|
ast::type::ArrayType a(&b, 4);
|
||||||
|
ast::type::ArrayType c(&a, 5);
|
||||||
|
ast::type::ArrayType d(&c);
|
||||||
|
|
||||||
|
GeneratorImpl g;
|
||||||
|
ASSERT_TRUE(g.EmitType(&c, "ary")) << g.error();
|
||||||
|
EXPECT_EQ(g.result(), "bool ary[5][4][1]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(MslGeneratorImplTest, EmitType_ArrayOfArrayOfArray) {
|
||||||
|
ast::type::BoolType b;
|
||||||
|
ast::type::ArrayType a(&b, 4);
|
||||||
|
ast::type::ArrayType c(&a, 5);
|
||||||
|
ast::type::ArrayType d(&c, 6);
|
||||||
|
|
||||||
|
GeneratorImpl g;
|
||||||
|
ASSERT_TRUE(g.EmitType(&d, "ary")) << g.error();
|
||||||
|
EXPECT_EQ(g.result(), "bool ary[6][5][4]");
|
||||||
|
}
|
||||||
|
|
||||||
TEST_F(MslGeneratorImplTest, EmitType_Array_NameCollision) {
|
TEST_F(MslGeneratorImplTest, EmitType_Array_NameCollision) {
|
||||||
ast::type::BoolType b;
|
ast::type::BoolType b;
|
||||||
ast::type::ArrayType a(&b, 4);
|
ast::type::ArrayType a(&b, 4);
|
||||||
|
|
Loading…
Reference in New Issue