tint/writer: Handle static_asserts
These (with exception to the WGSL writer) are not emitted. Bug: tint:1625 Change-Id: Id8b36b5c83a6fe2dab042cf46b0c3dbca75e0926 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/97962 Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: Dan Sinclair <dsinclair@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
This commit is contained in:
parent
759ac33cd1
commit
b4744ac359
|
@ -1322,6 +1322,7 @@ if (tint_build_unittests) {
|
||||||
"writer/spirv/builder_literal_test.cc",
|
"writer/spirv/builder_literal_test.cc",
|
||||||
"writer/spirv/builder_loop_test.cc",
|
"writer/spirv/builder_loop_test.cc",
|
||||||
"writer/spirv/builder_return_test.cc",
|
"writer/spirv/builder_return_test.cc",
|
||||||
|
"writer/spirv/builder_static_assert_test.cc",
|
||||||
"writer/spirv/builder_switch_test.cc",
|
"writer/spirv/builder_switch_test.cc",
|
||||||
"writer/spirv/builder_test.cc",
|
"writer/spirv/builder_test.cc",
|
||||||
"writer/spirv/builder_type_test.cc",
|
"writer/spirv/builder_type_test.cc",
|
||||||
|
@ -1447,6 +1448,7 @@ if (tint_build_unittests) {
|
||||||
"writer/wgsl/generator_impl_loop_test.cc",
|
"writer/wgsl/generator_impl_loop_test.cc",
|
||||||
"writer/wgsl/generator_impl_member_accessor_test.cc",
|
"writer/wgsl/generator_impl_member_accessor_test.cc",
|
||||||
"writer/wgsl/generator_impl_return_test.cc",
|
"writer/wgsl/generator_impl_return_test.cc",
|
||||||
|
"writer/wgsl/generator_impl_static_assert_test.cc",
|
||||||
"writer/wgsl/generator_impl_switch_test.cc",
|
"writer/wgsl/generator_impl_switch_test.cc",
|
||||||
"writer/wgsl/generator_impl_test.cc",
|
"writer/wgsl/generator_impl_test.cc",
|
||||||
"writer/wgsl/generator_impl_type_test.cc",
|
"writer/wgsl/generator_impl_type_test.cc",
|
||||||
|
@ -1487,6 +1489,7 @@ if (tint_build_unittests) {
|
||||||
"writer/msl/generator_impl_module_constant_test.cc",
|
"writer/msl/generator_impl_module_constant_test.cc",
|
||||||
"writer/msl/generator_impl_return_test.cc",
|
"writer/msl/generator_impl_return_test.cc",
|
||||||
"writer/msl/generator_impl_sanitizer_test.cc",
|
"writer/msl/generator_impl_sanitizer_test.cc",
|
||||||
|
"writer/msl/generator_impl_static_assert_test.cc",
|
||||||
"writer/msl/generator_impl_switch_test.cc",
|
"writer/msl/generator_impl_switch_test.cc",
|
||||||
"writer/msl/generator_impl_test.cc",
|
"writer/msl/generator_impl_test.cc",
|
||||||
"writer/msl/generator_impl_type_test.cc",
|
"writer/msl/generator_impl_type_test.cc",
|
||||||
|
@ -1526,6 +1529,7 @@ if (tint_build_unittests) {
|
||||||
"writer/hlsl/generator_impl_module_constant_test.cc",
|
"writer/hlsl/generator_impl_module_constant_test.cc",
|
||||||
"writer/hlsl/generator_impl_return_test.cc",
|
"writer/hlsl/generator_impl_return_test.cc",
|
||||||
"writer/hlsl/generator_impl_sanitizer_test.cc",
|
"writer/hlsl/generator_impl_sanitizer_test.cc",
|
||||||
|
"writer/hlsl/generator_impl_static_assert_test.cc",
|
||||||
"writer/hlsl/generator_impl_switch_test.cc",
|
"writer/hlsl/generator_impl_switch_test.cc",
|
||||||
"writer/hlsl/generator_impl_test.cc",
|
"writer/hlsl/generator_impl_test.cc",
|
||||||
"writer/hlsl/generator_impl_type_test.cc",
|
"writer/hlsl/generator_impl_type_test.cc",
|
||||||
|
|
|
@ -1039,6 +1039,7 @@ if(TINT_BUILD_TESTS)
|
||||||
writer/spirv/builder_literal_test.cc
|
writer/spirv/builder_literal_test.cc
|
||||||
writer/spirv/builder_loop_test.cc
|
writer/spirv/builder_loop_test.cc
|
||||||
writer/spirv/builder_return_test.cc
|
writer/spirv/builder_return_test.cc
|
||||||
|
writer/spirv/builder_static_assert_test.cc
|
||||||
writer/spirv/builder_switch_test.cc
|
writer/spirv/builder_switch_test.cc
|
||||||
writer/spirv/builder_test.cc
|
writer/spirv/builder_test.cc
|
||||||
writer/spirv/builder_type_test.cc
|
writer/spirv/builder_type_test.cc
|
||||||
|
@ -1078,6 +1079,7 @@ if(TINT_BUILD_TESTS)
|
||||||
writer/wgsl/generator_impl_literal_test.cc
|
writer/wgsl/generator_impl_literal_test.cc
|
||||||
writer/wgsl/generator_impl_member_accessor_test.cc
|
writer/wgsl/generator_impl_member_accessor_test.cc
|
||||||
writer/wgsl/generator_impl_return_test.cc
|
writer/wgsl/generator_impl_return_test.cc
|
||||||
|
writer/wgsl/generator_impl_static_assert_test.cc
|
||||||
writer/wgsl/generator_impl_switch_test.cc
|
writer/wgsl/generator_impl_switch_test.cc
|
||||||
writer/wgsl/generator_impl_type_test.cc
|
writer/wgsl/generator_impl_type_test.cc
|
||||||
writer/wgsl/generator_impl_unary_op_test.cc
|
writer/wgsl/generator_impl_unary_op_test.cc
|
||||||
|
@ -1160,6 +1162,7 @@ if(TINT_BUILD_TESTS)
|
||||||
writer/msl/generator_impl_module_constant_test.cc
|
writer/msl/generator_impl_module_constant_test.cc
|
||||||
writer/msl/generator_impl_return_test.cc
|
writer/msl/generator_impl_return_test.cc
|
||||||
writer/msl/generator_impl_sanitizer_test.cc
|
writer/msl/generator_impl_sanitizer_test.cc
|
||||||
|
writer/msl/generator_impl_static_assert_test.cc
|
||||||
writer/msl/generator_impl_switch_test.cc
|
writer/msl/generator_impl_switch_test.cc
|
||||||
writer/msl/generator_impl_test.cc
|
writer/msl/generator_impl_test.cc
|
||||||
writer/msl/generator_impl_type_test.cc
|
writer/msl/generator_impl_type_test.cc
|
||||||
|
@ -1231,6 +1234,7 @@ if(TINT_BUILD_TESTS)
|
||||||
writer/hlsl/generator_impl_module_constant_test.cc
|
writer/hlsl/generator_impl_module_constant_test.cc
|
||||||
writer/hlsl/generator_impl_return_test.cc
|
writer/hlsl/generator_impl_return_test.cc
|
||||||
writer/hlsl/generator_impl_sanitizer_test.cc
|
writer/hlsl/generator_impl_sanitizer_test.cc
|
||||||
|
writer/hlsl/generator_impl_static_assert_test.cc
|
||||||
writer/hlsl/generator_impl_switch_test.cc
|
writer/hlsl/generator_impl_switch_test.cc
|
||||||
writer/hlsl/generator_impl_test.cc
|
writer/hlsl/generator_impl_test.cc
|
||||||
writer/hlsl/generator_impl_type_test.cc
|
writer/hlsl/generator_impl_type_test.cc
|
||||||
|
|
|
@ -273,8 +273,8 @@ bool GeneratorImpl::Generate() {
|
||||||
|
|
||||||
auto* mod = builder_.Sem().Module();
|
auto* mod = builder_.Sem().Module();
|
||||||
for (auto* decl : mod->DependencyOrderedDeclarations()) {
|
for (auto* decl : mod->DependencyOrderedDeclarations()) {
|
||||||
if (decl->Is<ast::Alias>()) {
|
if (decl->IsAnyOf<ast::Alias, ast::StaticAssert>()) {
|
||||||
continue; // Ignore aliases.
|
continue; // These are not emitted.
|
||||||
}
|
}
|
||||||
|
|
||||||
if (auto* global = decl->As<ast::Variable>()) {
|
if (auto* global = decl->As<ast::Variable>()) {
|
||||||
|
@ -2652,52 +2652,32 @@ bool GeneratorImpl::EmitReturn(const ast::ReturnStatement* stmt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
||||||
if (auto* a = stmt->As<ast::AssignmentStatement>()) {
|
return Switch(
|
||||||
return EmitAssign(a);
|
stmt, //
|
||||||
}
|
[&](const ast::AssignmentStatement* a) { return EmitAssign(a); },
|
||||||
if (auto* b = stmt->As<ast::BlockStatement>()) {
|
[&](const ast::BlockStatement* b) { return EmitBlock(b); },
|
||||||
return EmitBlock(b);
|
[&](const ast::BreakStatement* b) { return EmitBreak(b); },
|
||||||
}
|
[&](const ast::CallStatement* c) {
|
||||||
if (auto* b = stmt->As<ast::BreakStatement>()) {
|
|
||||||
return EmitBreak(b);
|
|
||||||
}
|
|
||||||
if (auto* c = stmt->As<ast::CallStatement>()) {
|
|
||||||
auto out = line();
|
auto out = line();
|
||||||
if (!EmitCall(out, c->expr)) {
|
if (!EmitCall(out, c->expr)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
out << ";";
|
out << ";";
|
||||||
return true;
|
return true;
|
||||||
}
|
},
|
||||||
if (auto* c = stmt->As<ast::ContinueStatement>()) {
|
[&](const ast::ContinueStatement* c) { return EmitContinue(c); },
|
||||||
return EmitContinue(c);
|
[&](const ast::DiscardStatement* d) { return EmitDiscard(d); },
|
||||||
}
|
[&](const ast::FallthroughStatement*) {
|
||||||
if (auto* d = stmt->As<ast::DiscardStatement>()) {
|
|
||||||
return EmitDiscard(d);
|
|
||||||
}
|
|
||||||
if (stmt->As<ast::FallthroughStatement>()) {
|
|
||||||
line() << "/* fallthrough */";
|
line() << "/* fallthrough */";
|
||||||
return true;
|
return true;
|
||||||
}
|
},
|
||||||
if (auto* i = stmt->As<ast::IfStatement>()) {
|
[&](const ast::IfStatement* i) { return EmitIf(i); },
|
||||||
return EmitIf(i);
|
[&](const ast::LoopStatement* l) { return EmitLoop(l); },
|
||||||
}
|
[&](const ast::ForLoopStatement* l) { return EmitForLoop(l); },
|
||||||
if (auto* l = stmt->As<ast::LoopStatement>()) {
|
[&](const ast::WhileStatement* l) { return EmitWhile(l); },
|
||||||
return EmitLoop(l);
|
[&](const ast::ReturnStatement* r) { return EmitReturn(r); },
|
||||||
}
|
[&](const ast::SwitchStatement* s) { return EmitSwitch(s); },
|
||||||
if (auto* l = stmt->As<ast::ForLoopStatement>()) {
|
[&](const ast::VariableDeclStatement* v) {
|
||||||
return EmitForLoop(l);
|
|
||||||
}
|
|
||||||
if (auto* l = stmt->As<ast::WhileStatement>()) {
|
|
||||||
return EmitWhile(l);
|
|
||||||
}
|
|
||||||
if (auto* r = stmt->As<ast::ReturnStatement>()) {
|
|
||||||
return EmitReturn(r);
|
|
||||||
}
|
|
||||||
if (auto* s = stmt->As<ast::SwitchStatement>()) {
|
|
||||||
return EmitSwitch(s);
|
|
||||||
}
|
|
||||||
if (auto* v = stmt->As<ast::VariableDeclStatement>()) {
|
|
||||||
return Switch(
|
return Switch(
|
||||||
v->variable, //
|
v->variable, //
|
||||||
[&](const ast::Var* var) { return EmitVar(var); },
|
[&](const ast::Var* var) { return EmitVar(var); },
|
||||||
|
@ -2710,11 +2690,15 @@ bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
||||||
<< "unknown variable type: " << v->variable->TypeInfo().name;
|
<< "unknown variable type: " << v->variable->TypeInfo().name;
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
|
[&](const ast::StaticAssert*) {
|
||||||
|
return true; // Not emitted
|
||||||
|
},
|
||||||
|
[&](Default) {
|
||||||
diagnostics_.add_error(diag::System::Writer,
|
diagnostics_.add_error(diag::System::Writer,
|
||||||
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
||||||
return false;
|
return false;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GeneratorImpl::EmitSwitch(const ast::SwitchStatement* stmt) {
|
bool GeneratorImpl::EmitSwitch(const ast::SwitchStatement* stmt) {
|
||||||
|
|
|
@ -275,12 +275,8 @@ bool GeneratorImpl::Generate() {
|
||||||
|
|
||||||
auto* mod = builder_.Sem().Module();
|
auto* mod = builder_.Sem().Module();
|
||||||
for (auto* decl : mod->DependencyOrderedDeclarations()) {
|
for (auto* decl : mod->DependencyOrderedDeclarations()) {
|
||||||
if (decl->Is<ast::Alias>()) {
|
if (decl->IsAnyOf<ast::Alias, ast::Enable, ast::StaticAssert>()) {
|
||||||
continue; // Ignore aliases.
|
continue; // These are not emitted.
|
||||||
}
|
|
||||||
if (decl->Is<ast::Enable>()) {
|
|
||||||
// Currently we don't have to do anything for using a extension in HLSL.
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit a new line between declarations if the type of declaration has
|
// Emit a new line between declarations if the type of declaration has
|
||||||
|
@ -3646,6 +3642,9 @@ bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
[&](const ast::StaticAssert*) {
|
||||||
|
return true; // Not emitted
|
||||||
|
},
|
||||||
[&](Default) { //
|
[&](Default) { //
|
||||||
diagnostics_.add_error(diag::System::Writer,
|
diagnostics_.add_error(diag::System::Writer,
|
||||||
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
// Copyright 2022 The Tint Authors.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include "src/tint/writer/hlsl/test_helper.h"
|
||||||
|
|
||||||
|
using namespace tint::number_suffixes; // NOLINT
|
||||||
|
|
||||||
|
namespace tint::writer::hlsl {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using HlslGeneratorImplTest = TestHelper;
|
||||||
|
|
||||||
|
TEST_F(HlslGeneratorImplTest, Emit_GlobalStaticAssert) {
|
||||||
|
GlobalStaticAssert(true);
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(gen.result(), "");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(HlslGeneratorImplTest, Emit_FunctionStaticAssert) {
|
||||||
|
Func("f", utils::Empty, ty.void_(), utils::Vector{StaticAssert(true)});
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(gen.result(), R"(void f() {
|
||||||
|
}
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace tint::writer::hlsl
|
|
@ -286,6 +286,9 @@ bool GeneratorImpl::Generate() {
|
||||||
// Do nothing for enabling extension in MSL
|
// Do nothing for enabling extension in MSL
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
|
[&](const ast::StaticAssert*) {
|
||||||
|
return true; // Not emitted
|
||||||
|
},
|
||||||
[&](Default) {
|
[&](Default) {
|
||||||
// These are pushed into the entry point by sanitizer transforms.
|
// These are pushed into the entry point by sanitizer transforms.
|
||||||
TINT_ICE(Writer, diagnostics_) << "unhandled type: " << decl->TypeInfo().name;
|
TINT_ICE(Writer, diagnostics_) << "unhandled type: " << decl->TypeInfo().name;
|
||||||
|
@ -2419,6 +2422,9 @@ bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
[&](const ast::StaticAssert*) {
|
||||||
|
return true; // Not emitted
|
||||||
|
},
|
||||||
[&](Default) {
|
[&](Default) {
|
||||||
diagnostics_.add_error(diag::System::Writer,
|
diagnostics_.add_error(diag::System::Writer,
|
||||||
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
"unknown statement type: " + std::string(stmt->TypeInfo().name));
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
// Copyright 2022 The Tint Authors.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include "src/tint/writer/msl/test_helper.h"
|
||||||
|
|
||||||
|
using namespace tint::number_suffixes; // NOLINT
|
||||||
|
|
||||||
|
namespace tint::writer::msl {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using MslGeneratorImplTest = TestHelper;
|
||||||
|
|
||||||
|
TEST_F(MslGeneratorImplTest, Emit_GlobalStaticAssert) {
|
||||||
|
GlobalStaticAssert(true);
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(gen.result(), R"(#include <metal_stdlib>
|
||||||
|
|
||||||
|
using namespace metal;
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(MslGeneratorImplTest, Emit_FunctionStaticAssert) {
|
||||||
|
Func("f", utils::Empty, ty.void_(), utils::Vector{StaticAssert(true)});
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(gen.result(), R"(#include <metal_stdlib>
|
||||||
|
|
||||||
|
using namespace metal;
|
||||||
|
void f() {
|
||||||
|
}
|
||||||
|
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace tint::writer::msl
|
|
@ -3723,12 +3723,8 @@ bool Builder::GenerateLoopStatement(const ast::LoopStatement* stmt) {
|
||||||
bool Builder::GenerateStatement(const ast::Statement* stmt) {
|
bool Builder::GenerateStatement(const ast::Statement* stmt) {
|
||||||
return Switch(
|
return Switch(
|
||||||
stmt, [&](const ast::AssignmentStatement* a) { return GenerateAssignStatement(a); },
|
stmt, [&](const ast::AssignmentStatement* a) { return GenerateAssignStatement(a); },
|
||||||
[&](const ast::BlockStatement* b) { //
|
[&](const ast::BlockStatement* b) { return GenerateBlockStatement(b); },
|
||||||
return GenerateBlockStatement(b);
|
[&](const ast::BreakStatement* b) { return GenerateBreakStatement(b); },
|
||||||
},
|
|
||||||
[&](const ast::BreakStatement* b) { //
|
|
||||||
return GenerateBreakStatement(b);
|
|
||||||
},
|
|
||||||
[&](const ast::CallStatement* c) { return GenerateCallExpression(c->expr) != 0; },
|
[&](const ast::CallStatement* c) { return GenerateCallExpression(c->expr) != 0; },
|
||||||
[&](const ast::ContinueStatement* c) { return GenerateContinueStatement(c); },
|
[&](const ast::ContinueStatement* c) { return GenerateContinueStatement(c); },
|
||||||
[&](const ast::DiscardStatement* d) { return GenerateDiscardStatement(d); },
|
[&](const ast::DiscardStatement* d) { return GenerateDiscardStatement(d); },
|
||||||
|
@ -3736,19 +3732,14 @@ bool Builder::GenerateStatement(const ast::Statement* stmt) {
|
||||||
// Do nothing here, the fallthrough gets handled by the switch code.
|
// Do nothing here, the fallthrough gets handled by the switch code.
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
[&](const ast::IfStatement* i) { //
|
[&](const ast::IfStatement* i) { return GenerateIfStatement(i); },
|
||||||
return GenerateIfStatement(i);
|
[&](const ast::LoopStatement* l) { return GenerateLoopStatement(l); },
|
||||||
},
|
[&](const ast::ReturnStatement* r) { return GenerateReturnStatement(r); },
|
||||||
[&](const ast::LoopStatement* l) { //
|
[&](const ast::SwitchStatement* s) { return GenerateSwitchStatement(s); },
|
||||||
return GenerateLoopStatement(l);
|
|
||||||
},
|
|
||||||
[&](const ast::ReturnStatement* r) { //
|
|
||||||
return GenerateReturnStatement(r);
|
|
||||||
},
|
|
||||||
[&](const ast::SwitchStatement* s) { //
|
|
||||||
return GenerateSwitchStatement(s);
|
|
||||||
},
|
|
||||||
[&](const ast::VariableDeclStatement* v) { return GenerateVariableDeclStatement(v); },
|
[&](const ast::VariableDeclStatement* v) { return GenerateVariableDeclStatement(v); },
|
||||||
|
[&](const ast::StaticAssert*) {
|
||||||
|
return true; // Not emitted
|
||||||
|
},
|
||||||
[&](Default) {
|
[&](Default) {
|
||||||
error_ = "Unknown statement: " + std::string(stmt->TypeInfo().name);
|
error_ = "Unknown statement: " + std::string(stmt->TypeInfo().name);
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
// Copyright 2022 The Tint Authors.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include "src/tint/ast/fallthrough_statement.h"
|
||||||
|
#include "src/tint/writer/spirv/spv_dump.h"
|
||||||
|
#include "src/tint/writer/spirv/test_helper.h"
|
||||||
|
|
||||||
|
using namespace tint::number_suffixes; // NOLINT
|
||||||
|
|
||||||
|
namespace tint::writer::spirv {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using BuilderTest = TestHelper;
|
||||||
|
|
||||||
|
TEST_F(BuilderTest, GlobalStaticAssert) {
|
||||||
|
GlobalStaticAssert(true);
|
||||||
|
|
||||||
|
spirv::Builder& b = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(b.Build()) << b.error();
|
||||||
|
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(DumpInstructions(b.types()), "");
|
||||||
|
EXPECT_EQ(b.functions().size(), 0u);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(BuilderTest, FunctionStaticAssert) {
|
||||||
|
Func("f", utils::Empty, ty.void_(), utils::Vector{StaticAssert(true)});
|
||||||
|
|
||||||
|
spirv::Builder& b = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(b.Build()) << b.error();
|
||||||
|
|
||||||
|
// static asserts are not emitted
|
||||||
|
EXPECT_EQ(DumpInstructions(b.types()), R"(%2 = OpTypeVoid
|
||||||
|
%1 = OpTypeFunction %2
|
||||||
|
)");
|
||||||
|
EXPECT_EQ(DumpInstructions(b.functions()[0].instructions()), R"(OpReturn
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace tint::writer::spirv
|
|
@ -80,6 +80,7 @@ bool GeneratorImpl::Generate() {
|
||||||
[&](const ast::TypeDecl* td) { return EmitTypeDecl(td); },
|
[&](const ast::TypeDecl* td) { return EmitTypeDecl(td); },
|
||||||
[&](const ast::Function* func) { return EmitFunction(func); },
|
[&](const ast::Function* func) { return EmitFunction(func); },
|
||||||
[&](const ast::Variable* var) { return EmitVariable(line(), var); },
|
[&](const ast::Variable* var) { return EmitVariable(line(), var); },
|
||||||
|
[&](const ast::StaticAssert* sa) { return EmitStaticAssert(sa); },
|
||||||
[&](Default) {
|
[&](Default) {
|
||||||
TINT_UNREACHABLE(Writer, diagnostics_);
|
TINT_UNREACHABLE(Writer, diagnostics_);
|
||||||
return false;
|
return false;
|
||||||
|
@ -946,6 +947,7 @@ bool GeneratorImpl::EmitStatement(const ast::Statement* stmt) {
|
||||||
[&](const ast::ForLoopStatement* l) { return EmitForLoop(l); },
|
[&](const ast::ForLoopStatement* l) { return EmitForLoop(l); },
|
||||||
[&](const ast::WhileStatement* l) { return EmitWhile(l); },
|
[&](const ast::WhileStatement* l) { return EmitWhile(l); },
|
||||||
[&](const ast::ReturnStatement* r) { return EmitReturn(r); },
|
[&](const ast::ReturnStatement* r) { return EmitReturn(r); },
|
||||||
|
[&](const ast::StaticAssert* s) { return EmitStaticAssert(s); },
|
||||||
[&](const ast::SwitchStatement* s) { return EmitSwitch(s); },
|
[&](const ast::SwitchStatement* s) { return EmitSwitch(s); },
|
||||||
[&](const ast::VariableDeclStatement* v) { return EmitVariable(line(), v->variable); },
|
[&](const ast::VariableDeclStatement* v) { return EmitVariable(line(), v->variable); },
|
||||||
[&](Default) {
|
[&](Default) {
|
||||||
|
@ -1244,6 +1246,16 @@ bool GeneratorImpl::EmitReturn(const ast::ReturnStatement* stmt) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GeneratorImpl::EmitStaticAssert(const ast::StaticAssert* stmt) {
|
||||||
|
auto out = line();
|
||||||
|
out << "static_assert ";
|
||||||
|
if (!EmitExpression(out, stmt->condition)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
out << ";";
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool GeneratorImpl::EmitSwitch(const ast::SwitchStatement* stmt) {
|
bool GeneratorImpl::EmitSwitch(const ast::SwitchStatement* stmt) {
|
||||||
{
|
{
|
||||||
auto out = line();
|
auto out = line();
|
||||||
|
|
|
@ -165,6 +165,10 @@ class GeneratorImpl : public TextGenerator {
|
||||||
/// @param stmt the statement to emit
|
/// @param stmt the statement to emit
|
||||||
/// @returns true if the statement was successfully emitted
|
/// @returns true if the statement was successfully emitted
|
||||||
bool EmitReturn(const ast::ReturnStatement* stmt);
|
bool EmitReturn(const ast::ReturnStatement* stmt);
|
||||||
|
/// Handles static assertion statements
|
||||||
|
/// @param stmt the statement to emit
|
||||||
|
/// @returns true if the statement was successfully emitted
|
||||||
|
bool EmitStaticAssert(const ast::StaticAssert* stmt);
|
||||||
/// Handles statement
|
/// Handles statement
|
||||||
/// @param stmt the statement to emit
|
/// @param stmt the statement to emit
|
||||||
/// @returns true if the statement was emitted
|
/// @returns true if the statement was emitted
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
// Copyright 2022 The Tint Authors.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include "src/tint/writer/wgsl/test_helper.h"
|
||||||
|
|
||||||
|
using namespace tint::number_suffixes; // NOLINT
|
||||||
|
|
||||||
|
namespace tint::writer::wgsl {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using WgslGeneratorImplTest = TestHelper;
|
||||||
|
|
||||||
|
TEST_F(WgslGeneratorImplTest, Emit_GlobalStaticAssert) {
|
||||||
|
GlobalStaticAssert(true);
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
EXPECT_EQ(gen.result(), R"(static_assert true;
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(WgslGeneratorImplTest, Emit_FunctionStaticAssert) {
|
||||||
|
Func("f", utils::Empty, ty.void_(), utils::Vector{StaticAssert(true)});
|
||||||
|
|
||||||
|
GeneratorImpl& gen = Build();
|
||||||
|
|
||||||
|
ASSERT_TRUE(gen.Generate()) << gen.error();
|
||||||
|
EXPECT_EQ(gen.result(), R"(fn f() {
|
||||||
|
static_assert true;
|
||||||
|
}
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace tint::writer::wgsl
|
Loading…
Reference in New Issue