mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-14 23:56:16 +00:00
sem: Rename Function methods
Explicitly name references as either Direct or Transitive. Rename workgroup_size() to WorkgroupSize(). Remove the return_statements. These were not used anywhere. Change-Id: I7191665db9c3211d086dd90939abec7003cd7be7 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/68405 Kokoro: Kokoro <noreply+kokoro@google.com> Reviewed-by: James Price <jrprice@google.com>
This commit is contained in:
@@ -3795,10 +3795,10 @@ void Resolver::CreateSemanticNodes() const {
|
||||
}
|
||||
|
||||
auto remap_vars = [&sem](const std::vector<VariableInfo*>& in) {
|
||||
std::vector<const sem::Variable*> out;
|
||||
std::vector<const sem::GlobalVariable*> out;
|
||||
out.reserve(in.size());
|
||||
for (auto* info : in) {
|
||||
out.emplace_back(sem.Get(info->declaration));
|
||||
out.emplace_back(sem.Get<sem::GlobalVariable>(info->declaration));
|
||||
}
|
||||
return out;
|
||||
};
|
||||
@@ -3818,9 +3818,8 @@ void Resolver::CreateSemanticNodes() const {
|
||||
auto* sem_func = builder_->create<sem::Function>(
|
||||
info->declaration, info->return_type, parameters,
|
||||
remap_vars(info->referenced_module_vars),
|
||||
remap_vars(info->local_referenced_module_vars), info->return_statements,
|
||||
info->callsites, ancestor_entry_points[func->symbol],
|
||||
info->workgroup_size);
|
||||
remap_vars(info->local_referenced_module_vars), info->callsites,
|
||||
ancestor_entry_points[func->symbol], info->workgroup_size);
|
||||
func_info_to_sem_func.emplace(info, sem_func);
|
||||
sem.Add(func, sem_func);
|
||||
}
|
||||
|
||||
@@ -819,7 +819,7 @@ TEST_F(ResolverTest, Function_RegisterInputOutputVariables) {
|
||||
EXPECT_EQ(func_sem->Parameters().size(), 0u);
|
||||
EXPECT_TRUE(func_sem->ReturnType()->Is<sem::Void>());
|
||||
|
||||
const auto& vars = func_sem->ReferencedModuleVariables();
|
||||
const auto& vars = func_sem->TransitivelyReferencedGlobals();
|
||||
ASSERT_EQ(vars.size(), 3u);
|
||||
EXPECT_EQ(vars[0]->Declaration(), wg_var);
|
||||
EXPECT_EQ(vars[1]->Declaration(), sb_var);
|
||||
@@ -856,7 +856,7 @@ TEST_F(ResolverTest, Function_RegisterInputOutputVariables_SubFunction) {
|
||||
ASSERT_NE(func2_sem, nullptr);
|
||||
EXPECT_EQ(func2_sem->Parameters().size(), 0u);
|
||||
|
||||
const auto& vars = func2_sem->ReferencedModuleVariables();
|
||||
const auto& vars = func2_sem->TransitivelyReferencedGlobals();
|
||||
ASSERT_EQ(vars.size(), 3u);
|
||||
EXPECT_EQ(vars[0]->Declaration(), wg_var);
|
||||
EXPECT_EQ(vars[1]->Declaration(), sb_var);
|
||||
@@ -875,7 +875,7 @@ TEST_F(ResolverTest, Function_NotRegisterFunctionVariable) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->ReferencedModuleVariables().size(), 0u);
|
||||
EXPECT_EQ(func_sem->TransitivelyReferencedGlobals().size(), 0u);
|
||||
EXPECT_TRUE(func_sem->ReturnType()->Is<sem::Void>());
|
||||
}
|
||||
|
||||
@@ -890,7 +890,7 @@ TEST_F(ResolverTest, Function_NotRegisterFunctionConstant) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->ReferencedModuleVariables().size(), 0u);
|
||||
EXPECT_EQ(func_sem->TransitivelyReferencedGlobals().size(), 0u);
|
||||
EXPECT_TRUE(func_sem->ReturnType()->Is<sem::Void>());
|
||||
}
|
||||
|
||||
@@ -902,34 +902,10 @@ TEST_F(ResolverTest, Function_NotRegisterFunctionParams) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->ReferencedModuleVariables().size(), 0u);
|
||||
EXPECT_EQ(func_sem->TransitivelyReferencedGlobals().size(), 0u);
|
||||
EXPECT_TRUE(func_sem->ReturnType()->Is<sem::Void>());
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_ReturnStatements) {
|
||||
auto* var = Var("foo", ty.f32());
|
||||
|
||||
auto* ret_1 = Return(1.f);
|
||||
auto* ret_foo = Return("foo");
|
||||
auto* func = Func("my_func", ast::VariableList{}, ty.f32(),
|
||||
{
|
||||
Decl(var),
|
||||
If(true, Block(ret_1)),
|
||||
ret_foo,
|
||||
});
|
||||
|
||||
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
||||
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
EXPECT_EQ(func_sem->Parameters().size(), 0u);
|
||||
|
||||
EXPECT_EQ(func_sem->ReturnStatements().size(), 2u);
|
||||
EXPECT_EQ(func_sem->ReturnStatements()[0], ret_1);
|
||||
EXPECT_EQ(func_sem->ReturnStatements()[1], ret_foo);
|
||||
EXPECT_TRUE(func_sem->ReturnType()->Is<sem::F32>());
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_CallSites) {
|
||||
auto* foo = Func("foo", ast::VariableList{}, ty.void_(), {});
|
||||
|
||||
@@ -964,12 +940,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_NotSet) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 1u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 1u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 1u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 1u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 1u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 1u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, nullptr);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_Literals) {
|
||||
@@ -984,12 +960,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_Literals) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 2u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 3u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 2u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 3u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, nullptr);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_Consts) {
|
||||
@@ -1010,12 +986,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_Consts) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 16u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 8u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 2u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 16u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 8u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 2u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, nullptr);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_Consts_NestedInitializer) {
|
||||
@@ -1036,12 +1012,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_Consts_NestedInitializer) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 4u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 1u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 4u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 1u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, nullptr);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_OverridableConsts) {
|
||||
@@ -1062,12 +1038,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_OverridableConsts) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 16u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 8u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 2u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, width);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, depth);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 16u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 8u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 2u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, width);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, depth);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_OverridableConsts_NoInit) {
|
||||
@@ -1088,12 +1064,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_OverridableConsts_NoInit) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 0u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 0u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 0u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, width);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, depth);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 0u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 0u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 0u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, width);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, depth);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Function_WorkgroupSize_Mixed) {
|
||||
@@ -1112,12 +1088,12 @@ TEST_F(ResolverTest, Function_WorkgroupSize_Mixed) {
|
||||
auto* func_sem = Sem().Get(func);
|
||||
ASSERT_NE(func_sem, nullptr);
|
||||
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].value, 2u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].value, 3u);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->workgroup_size()[2].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].value, 8u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].value, 2u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].value, 3u);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[0].overridable_const, nullptr);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[1].overridable_const, height);
|
||||
EXPECT_EQ(func_sem->WorkgroupSize()[2].overridable_const, nullptr);
|
||||
}
|
||||
|
||||
TEST_F(ResolverTest, Expr_MemberAccessor_Struct) {
|
||||
|
||||
Reference in New Issue
Block a user