// Copyright 2021 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/resolver/resolver.h" #include "gmock/gmock.h" #include "src/resolver/resolver_test_helper.h" #include "src/sem/atomic_type.h" namespace tint { namespace resolver { namespace { using ResolverIsStorableTest = ResolverTest; TEST_F(ResolverIsStorableTest, Void) { EXPECT_FALSE(r()->IsStorable(create())); } TEST_F(ResolverIsStorableTest, Scalar) { EXPECT_TRUE(r()->IsStorable(create())); EXPECT_TRUE(r()->IsStorable(create())); EXPECT_TRUE(r()->IsStorable(create())); EXPECT_TRUE(r()->IsStorable(create())); } TEST_F(ResolverIsStorableTest, Vector) { EXPECT_TRUE(r()->IsStorable(create(create(), 2))); EXPECT_TRUE(r()->IsStorable(create(create(), 3))); EXPECT_TRUE(r()->IsStorable(create(create(), 4))); EXPECT_TRUE(r()->IsStorable(create(create(), 2))); EXPECT_TRUE(r()->IsStorable(create(create(), 3))); EXPECT_TRUE(r()->IsStorable(create(create(), 4))); EXPECT_TRUE(r()->IsStorable(create(create(), 2))); EXPECT_TRUE(r()->IsStorable(create(create(), 3))); EXPECT_TRUE(r()->IsStorable(create(create(), 4))); } TEST_F(ResolverIsStorableTest, Matrix) { auto* vec2 = create(create(), 2); auto* vec3 = create(create(), 3); auto* vec4 = create(create(), 4); EXPECT_TRUE(r()->IsStorable(create(vec2, 2))); EXPECT_TRUE(r()->IsStorable(create(vec2, 3))); EXPECT_TRUE(r()->IsStorable(create(vec2, 4))); EXPECT_TRUE(r()->IsStorable(create(vec3, 2))); EXPECT_TRUE(r()->IsStorable(create(vec3, 3))); EXPECT_TRUE(r()->IsStorable(create(vec3, 4))); EXPECT_TRUE(r()->IsStorable(create(vec4, 2))); EXPECT_TRUE(r()->IsStorable(create(vec4, 3))); EXPECT_TRUE(r()->IsStorable(create(vec4, 4))); } TEST_F(ResolverIsStorableTest, Pointer) { auto* ptr = create( create(), ast::StorageClass::kPrivate, ast::Access::kReadWrite); EXPECT_FALSE(r()->IsStorable(ptr)); } TEST_F(ResolverIsStorableTest, Atomic) { EXPECT_TRUE(r()->IsStorable(create(create()))); EXPECT_TRUE(r()->IsStorable(create(create()))); } TEST_F(ResolverIsStorableTest, ArraySizedOfStorable) { auto* arr = create(create(), 5, 4, 20, 4, 4); EXPECT_TRUE(r()->IsStorable(arr)); } TEST_F(ResolverIsStorableTest, ArrayUnsizedOfStorable) { auto* arr = create(create(), 0, 4, 4, 4, 4); EXPECT_TRUE(r()->IsStorable(arr)); } TEST_F(ResolverIsStorableTest, Struct_AllMembersStorable) { Structure("S", { Member("a", ty.i32()), Member("b", ty.f32()), }); ASSERT_TRUE(r()->Resolve()) << r()->error(); } TEST_F(ResolverIsStorableTest, Struct_SomeMembersNonStorable) { Structure("S", { Member("a", ty.i32()), Member("b", ty.pointer(ast::StorageClass::kPrivate)), }); EXPECT_FALSE(r()->Resolve()); EXPECT_EQ( r()->error(), R"(error: ptr cannot be used as the type of a structure member)"); } TEST_F(ResolverIsStorableTest, Struct_NestedStorable) { auto* storable = Structure("Storable", { Member("a", ty.i32()), Member("b", ty.f32()), }); Structure("S", { Member("a", ty.i32()), Member("b", ty.Of(storable)), }); ASSERT_TRUE(r()->Resolve()) << r()->error(); } TEST_F(ResolverIsStorableTest, Struct_NestedNonStorable) { auto* non_storable = Structure("nonstorable", { Member("a", ty.i32()), Member("b", ty.pointer(ast::StorageClass::kPrivate)), }); Structure("S", { Member("a", ty.i32()), Member("b", ty.Of(non_storable)), }); EXPECT_FALSE(r()->Resolve()); EXPECT_EQ( r()->error(), R"(error: ptr cannot be used as the type of a structure member)"); } } // namespace } // namespace resolver } // namespace tint