mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 19:20:30 +00:00 
			
		
		
		
	Replace Type::(Is|As)Array with Castable
Change-Id: I8d9b916f5977121380325d373c4e2f805b691fae Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/34264 Reviewed-by: dan sinclair <dsinclair@chromium.org>
This commit is contained in:
		
							parent
							
								
									67864267c2
								
							
						
					
					
						commit
						af37c4ae83
					
				| @ -50,7 +50,7 @@ TEST_F(AccessControlTypeTest, Is) { | |||||||
|   Type* ty = &at; |   Type* ty = &at; | ||||||
|   EXPECT_TRUE(ty->Is<AccessControlType>()); |   EXPECT_TRUE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -51,7 +51,7 @@ TEST_F(AliasTypeTest, Is) { | |||||||
|   Type* ty = &at; |   Type* ty = &at; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_TRUE(ty->Is<AliasType>()); |   EXPECT_TRUE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -32,10 +32,6 @@ ArrayType::ArrayType(ArrayType&&) = default; | |||||||
| 
 | 
 | ||||||
| ArrayType::~ArrayType() = default; | ArrayType::~ArrayType() = default; | ||||||
| 
 | 
 | ||||||
| bool ArrayType::IsArray() const { |  | ||||||
|   return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| uint64_t ArrayType::MinBufferBindingSize(MemoryLayout mem_layout) const { | uint64_t ArrayType::MinBufferBindingSize(MemoryLayout mem_layout) const { | ||||||
|   if (!has_array_stride()) { |   if (!has_array_stride()) { | ||||||
|     // Arrays in buffers are required to have a stride.
 |     // Arrays in buffers are required to have a stride.
 | ||||||
|  | |||||||
| @ -41,8 +41,6 @@ class ArrayType : public Castable<ArrayType, Type> { | |||||||
|   ArrayType(ArrayType&&); |   ArrayType(ArrayType&&); | ||||||
|   ~ArrayType() override; |   ~ArrayType() override; | ||||||
| 
 | 
 | ||||||
|   /// @returns true if the type is an array type
 |  | ||||||
|   bool IsArray() const override; |  | ||||||
|   /// @returns true if this is a runtime array.
 |   /// @returns true if this is a runtime array.
 | ||||||
|   /// i.e. the size is determined at runtime
 |   /// i.e. the size is determined at runtime
 | ||||||
|   bool IsRuntimeArray() const { return size_ == 0; } |   bool IsRuntimeArray() const { return size_ == 0; } | ||||||
|  | |||||||
| @ -35,7 +35,7 @@ TEST_F(ArrayTypeTest, CreateSizedArray) { | |||||||
|   ArrayType arr{&u32, 3}; |   ArrayType arr{&u32, 3}; | ||||||
|   EXPECT_EQ(arr.type(), &u32); |   EXPECT_EQ(arr.type(), &u32); | ||||||
|   EXPECT_EQ(arr.size(), 3u); |   EXPECT_EQ(arr.size(), 3u); | ||||||
|   EXPECT_TRUE(arr.IsArray()); |   EXPECT_TRUE(arr.Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(arr.IsRuntimeArray()); |   EXPECT_FALSE(arr.IsRuntimeArray()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -44,7 +44,7 @@ TEST_F(ArrayTypeTest, CreateRuntimeArray) { | |||||||
|   ArrayType arr{&u32}; |   ArrayType arr{&u32}; | ||||||
|   EXPECT_EQ(arr.type(), &u32); |   EXPECT_EQ(arr.type(), &u32); | ||||||
|   EXPECT_EQ(arr.size(), 0u); |   EXPECT_EQ(arr.size(), 0u); | ||||||
|   EXPECT_TRUE(arr.IsArray()); |   EXPECT_TRUE(arr.Is<ArrayType>()); | ||||||
|   EXPECT_TRUE(arr.IsRuntimeArray()); |   EXPECT_TRUE(arr.IsRuntimeArray()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -55,7 +55,7 @@ TEST_F(ArrayTypeTest, Is) { | |||||||
|   Type* ty = &arr; |   Type* ty = &arr; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_TRUE(ty->IsArray()); |   EXPECT_TRUE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -29,7 +30,7 @@ TEST_F(BoolTypeTest, Is) { | |||||||
|   Type* ty = &b; |   Type* ty = &b; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_TRUE(ty->IsBool()); |   EXPECT_TRUE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ | |||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| 
 | 
 | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -30,7 +31,7 @@ TEST_F(DepthTextureTypeTest, Is) { | |||||||
|   Type* ty = &d; |   Type* ty = &d; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -29,7 +30,7 @@ TEST_F(F32TypeTest, Is) { | |||||||
|   Type* ty = &f; |   Type* ty = &f; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_TRUE(ty->IsF32()); |   EXPECT_TRUE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -29,7 +30,7 @@ TEST_F(I32TypeTest, Is) { | |||||||
|   Type* ty = &i; |   Type* ty = &i; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_TRUE(ty->IsI32()); |   EXPECT_TRUE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/i32_type.h" | #include "src/ast/type/i32_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -39,7 +40,7 @@ TEST_F(MatrixTypeTest, Is) { | |||||||
|   Type* ty = &m; |   Type* ty = &m; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/f32_type.h" | #include "src/ast/type/f32_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -31,7 +32,7 @@ TEST_F(MultisampledTextureTypeTest, Is) { | |||||||
|   Type* ty = &s; |   Type* ty = &s; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/i32_type.h" | #include "src/ast/type/i32_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -38,7 +39,7 @@ TEST_F(PointerTypeTest, Is) { | |||||||
|   Type* ty = &p; |   Type* ty = &p; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/f32_type.h" | #include "src/ast/type/f32_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -31,7 +32,7 @@ TEST_F(SampledTextureTypeTest, Is) { | |||||||
|   Type* ty = &s; |   Type* ty = &s; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -40,7 +41,7 @@ TEST_F(SamplerTypeTest, Is) { | |||||||
|   Type* ty = &s; |   Type* ty = &s; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -19,6 +19,7 @@ | |||||||
| #include "src/ast/identifier_expression.h" | #include "src/ast/identifier_expression.h" | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/type_determiner.h" | #include "src/type_determiner.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -34,7 +35,7 @@ TEST_F(StorageTextureTypeTest, Is) { | |||||||
|   Type* ty = &s; |   Type* ty = &s; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -47,7 +47,7 @@ TEST_F(StructTypeTest, Is) { | |||||||
|   Type* ty = &s; |   Type* ty = &s; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -66,10 +66,6 @@ Type* Type::UnwrapAll() { | |||||||
|   return UnwrapIfNeeded()->UnwrapPtrIfNeeded()->UnwrapIfNeeded(); |   return UnwrapIfNeeded()->UnwrapPtrIfNeeded()->UnwrapIfNeeded(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool Type::IsArray() const { |  | ||||||
|   return false; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool Type::IsBool() const { | bool Type::IsBool() const { | ||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
| @ -166,11 +162,6 @@ bool Type::is_integer_scalar_or_vector() { | |||||||
|   return is_unsigned_scalar_or_vector() || is_signed_scalar_or_vector(); |   return is_unsigned_scalar_or_vector() || is_signed_scalar_or_vector(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const ArrayType* Type::AsArray() const { |  | ||||||
|   assert(IsArray()); |  | ||||||
|   return static_cast<const ArrayType*>(this); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const BoolType* Type::AsBool() const { | const BoolType* Type::AsBool() const { | ||||||
|   assert(IsBool()); |   assert(IsBool()); | ||||||
|   return static_cast<const BoolType*>(this); |   return static_cast<const BoolType*>(this); | ||||||
| @ -226,11 +217,6 @@ const VoidType* Type::AsVoid() const { | |||||||
|   return static_cast<const VoidType*>(this); |   return static_cast<const VoidType*>(this); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ArrayType* Type::AsArray() { |  | ||||||
|   assert(IsArray()); |  | ||||||
|   return static_cast<ArrayType*>(this); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| BoolType* Type::AsBool() { | BoolType* Type::AsBool() { | ||||||
|   assert(IsBool()); |   assert(IsBool()); | ||||||
|   return static_cast<BoolType*>(this); |   return static_cast<BoolType*>(this); | ||||||
|  | |||||||
| @ -23,7 +23,6 @@ namespace tint { | |||||||
| namespace ast { | namespace ast { | ||||||
| namespace type { | namespace type { | ||||||
| 
 | 
 | ||||||
| class ArrayType; |  | ||||||
| class BoolType; | class BoolType; | ||||||
| class F32Type; | class F32Type; | ||||||
| class I32Type; | class I32Type; | ||||||
| @ -46,8 +45,6 @@ class Type : public Castable<Type> { | |||||||
|   Type(Type&&); |   Type(Type&&); | ||||||
|   ~Type() override; |   ~Type() override; | ||||||
| 
 | 
 | ||||||
|   /// @returns true if the type is an array type
 |  | ||||||
|   virtual bool IsArray() const; |  | ||||||
|   /// @returns true if the type is a bool type
 |   /// @returns true if the type is a bool type
 | ||||||
|   virtual bool IsBool() const; |   virtual bool IsBool() const; | ||||||
|   /// @returns true if the type is an f32 type
 |   /// @returns true if the type is an f32 type
 | ||||||
| @ -125,8 +122,6 @@ class Type : public Castable<Type> { | |||||||
|   /// @returns true if this type is an integer scalar or vector
 |   /// @returns true if this type is an integer scalar or vector
 | ||||||
|   bool is_integer_scalar_or_vector(); |   bool is_integer_scalar_or_vector(); | ||||||
| 
 | 
 | ||||||
|   /// @returns the type as an array type
 |  | ||||||
|   const ArrayType* AsArray() const; |  | ||||||
|   /// @returns the type as a bool type
 |   /// @returns the type as a bool type
 | ||||||
|   const BoolType* AsBool() const; |   const BoolType* AsBool() const; | ||||||
|   /// @returns the type as a f32 type
 |   /// @returns the type as a f32 type
 | ||||||
| @ -150,8 +145,6 @@ class Type : public Castable<Type> { | |||||||
|   /// @returns the type as a void type
 |   /// @returns the type as a void type
 | ||||||
|   const VoidType* AsVoid() const; |   const VoidType* AsVoid() const; | ||||||
| 
 | 
 | ||||||
|   /// @returns the type as an array type
 |  | ||||||
|   ArrayType* AsArray(); |  | ||||||
|   /// @returns the type as a bool type
 |   /// @returns the type as a bool type
 | ||||||
|   BoolType* AsBool(); |   BoolType* AsBool(); | ||||||
|   /// @returns the type as a f32 type
 |   /// @returns the type as a f32 type
 | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| namespace ast { | namespace ast { | ||||||
| @ -29,7 +30,7 @@ TEST_F(U32TypeTest, Is) { | |||||||
|   Type* ty = &u; |   Type* ty = &u; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/ast/test_helper.h" | #include "src/ast/test_helper.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/i32_type.h" | #include "src/ast/type/i32_type.h" | ||||||
| 
 | 
 | ||||||
| namespace tint { | namespace tint { | ||||||
| @ -38,7 +39,7 @@ TEST_F(VectorTypeTest, Is) { | |||||||
|   Type* ty = &v; |   Type* ty = &v; | ||||||
|   EXPECT_FALSE(ty->Is<AccessControlType>()); |   EXPECT_FALSE(ty->Is<AccessControlType>()); | ||||||
|   EXPECT_FALSE(ty->Is<AliasType>()); |   EXPECT_FALSE(ty->Is<AliasType>()); | ||||||
|   EXPECT_FALSE(ty->IsArray()); |   EXPECT_FALSE(ty->Is<ArrayType>()); | ||||||
|   EXPECT_FALSE(ty->IsBool()); |   EXPECT_FALSE(ty->IsBool()); | ||||||
|   EXPECT_FALSE(ty->IsF32()); |   EXPECT_FALSE(ty->IsF32()); | ||||||
|   EXPECT_FALSE(ty->IsI32()); |   EXPECT_FALSE(ty->IsI32()); | ||||||
|  | |||||||
| @ -383,8 +383,8 @@ std::vector<ResourceBinding> Inspector::GetSampledTextureResourceBindingsImpl( | |||||||
|       base_type = texture_type->AsSampled()->type()->UnwrapIfNeeded(); |       base_type = texture_type->AsSampled()->type()->UnwrapIfNeeded(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (base_type->IsArray()) { |     if (base_type->Is<ast::type::ArrayType>()) { | ||||||
|       base_type = base_type->AsArray()->type(); |       base_type = base_type->As<ast::type::ArrayType>()->type(); | ||||||
|     } else if (base_type->IsMatrix()) { |     } else if (base_type->IsMatrix()) { | ||||||
|       base_type = base_type->AsMatrix()->type(); |       base_type = base_type->AsMatrix()->type(); | ||||||
|     } else if (base_type->IsVector()) { |     } else if (base_type->IsVector()) { | ||||||
|  | |||||||
| @ -1371,8 +1371,8 @@ ast::Expression* ParserImpl::MakeNullValue(ast::type::Type* type) { | |||||||
|     return create<ast::TypeConstructorExpression>(type, |     return create<ast::TypeConstructorExpression>(type, | ||||||
|                                                   std::move(ast_components)); |                                                   std::move(ast_components)); | ||||||
|   } |   } | ||||||
|   if (type->IsArray()) { |   if (type->Is<ast::type::ArrayType>()) { | ||||||
|     auto* arr_ty = type->AsArray(); |     auto* arr_ty = type->As<ast::type::ArrayType>(); | ||||||
|     ast::ExpressionList ast_components; |     ast::ExpressionList ast_components; | ||||||
|     for (size_t i = 0; i < arr_ty->size(); ++i) { |     for (size_t i = 0; i < arr_ty->size(); ++i) { | ||||||
|       ast_components.emplace_back(MakeNullValue(arr_ty->type())); |       ast_components.emplace_back(MakeNullValue(arr_ty->type())); | ||||||
|  | |||||||
| @ -35,6 +35,7 @@ | |||||||
| #include "src/ast/module.h" | #include "src/ast/module.h" | ||||||
| #include "src/ast/struct_member_decoration.h" | #include "src/ast/struct_member_decoration.h" | ||||||
| #include "src/ast/type/alias_type.h" | #include "src/ast/type/alias_type.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/type.h" | #include "src/ast/type/type.h" | ||||||
| #include "src/reader/reader.h" | #include "src/reader/reader.h" | ||||||
| #include "src/reader/spirv/entry_point_info.h" | #include "src/reader/spirv/entry_point_info.h" | ||||||
|  | |||||||
| @ -338,8 +338,8 @@ TEST_F(SpvParserTest, ConvertType_RuntimeArray) { | |||||||
| 
 | 
 | ||||||
|   auto* type = p->ConvertType(10); |   auto* type = p->ConvertType(10); | ||||||
|   ASSERT_NE(type, nullptr); |   ASSERT_NE(type, nullptr); | ||||||
|   EXPECT_TRUE(type->IsArray()); |   EXPECT_TRUE(type->Is<ast::type::ArrayType>()); | ||||||
|   auto* arr_type = type->AsArray(); |   auto* arr_type = type->As<ast::type::ArrayType>(); | ||||||
|   EXPECT_TRUE(arr_type->IsRuntimeArray()); |   EXPECT_TRUE(arr_type->IsRuntimeArray()); | ||||||
|   ASSERT_NE(arr_type, nullptr); |   ASSERT_NE(arr_type, nullptr); | ||||||
|   EXPECT_EQ(arr_type->size(), 0u); |   EXPECT_EQ(arr_type->size(), 0u); | ||||||
| @ -374,7 +374,7 @@ TEST_F(SpvParserTest, ConvertType_RuntimeArray_ArrayStride_Valid) { | |||||||
|   EXPECT_TRUE(p->BuildInternalModule()); |   EXPECT_TRUE(p->BuildInternalModule()); | ||||||
|   auto* type = p->ConvertType(10); |   auto* type = p->ConvertType(10); | ||||||
|   ASSERT_NE(type, nullptr); |   ASSERT_NE(type, nullptr); | ||||||
|   auto* arr_type = type->AsArray(); |   auto* arr_type = type->As<ast::type::ArrayType>(); | ||||||
|   EXPECT_TRUE(arr_type->IsRuntimeArray()); |   EXPECT_TRUE(arr_type->IsRuntimeArray()); | ||||||
|   ASSERT_NE(arr_type, nullptr); |   ASSERT_NE(arr_type, nullptr); | ||||||
|   EXPECT_EQ(arr_type->array_stride(), 64u); |   EXPECT_EQ(arr_type->array_stride(), 64u); | ||||||
| @ -420,8 +420,8 @@ TEST_F(SpvParserTest, ConvertType_Array) { | |||||||
| 
 | 
 | ||||||
|   auto* type = p->ConvertType(10); |   auto* type = p->ConvertType(10); | ||||||
|   ASSERT_NE(type, nullptr); |   ASSERT_NE(type, nullptr); | ||||||
|   EXPECT_TRUE(type->IsArray()); |   EXPECT_TRUE(type->Is<ast::type::ArrayType>()); | ||||||
|   auto* arr_type = type->AsArray(); |   auto* arr_type = type->As<ast::type::ArrayType>(); | ||||||
|   EXPECT_FALSE(arr_type->IsRuntimeArray()); |   EXPECT_FALSE(arr_type->IsRuntimeArray()); | ||||||
|   ASSERT_NE(arr_type, nullptr); |   ASSERT_NE(arr_type, nullptr); | ||||||
|   EXPECT_EQ(arr_type->size(), 42u); |   EXPECT_EQ(arr_type->size(), 42u); | ||||||
| @ -508,8 +508,8 @@ TEST_F(SpvParserTest, ConvertType_ArrayStride_Valid) { | |||||||
| 
 | 
 | ||||||
|   auto* type = p->ConvertType(10); |   auto* type = p->ConvertType(10); | ||||||
|   ASSERT_NE(type, nullptr); |   ASSERT_NE(type, nullptr); | ||||||
|   EXPECT_TRUE(type->IsArray()); |   EXPECT_TRUE(type->Is<ast::type::ArrayType>()); | ||||||
|   auto* arr_type = type->AsArray(); |   auto* arr_type = type->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_NE(arr_type, nullptr); |   ASSERT_NE(arr_type, nullptr); | ||||||
|   ASSERT_EQ(arr_type->array_stride(), 8u); |   ASSERT_EQ(arr_type->array_stride(), 8u); | ||||||
|   EXPECT_TRUE(arr_type->has_array_stride()); |   EXPECT_TRUE(arr_type->has_array_stride()); | ||||||
|  | |||||||
| @ -191,8 +191,8 @@ TEST_F(ParserImplTest, GlobalDecl_Struct_WithStride) { | |||||||
|   EXPECT_FALSE(str->IsBlockDecorated()); |   EXPECT_FALSE(str->IsBlockDecorated()); | ||||||
| 
 | 
 | ||||||
|   const auto* ty = str->impl()->members()[0]->type(); |   const auto* ty = str->impl()->members()[0]->type(); | ||||||
|   ASSERT_TRUE(ty->IsArray()); |   ASSERT_TRUE(ty->Is<ast::type::ArrayType>()); | ||||||
|   const auto* arr = ty->AsArray(); |   const auto* arr = ty->As<ast::type::ArrayType>(); | ||||||
|   EXPECT_TRUE(arr->has_array_stride()); |   EXPECT_TRUE(arr->has_array_stride()); | ||||||
|   EXPECT_EQ(arr->array_stride(), 4u); |   EXPECT_EQ(arr->array_stride(), 4u); | ||||||
| } | } | ||||||
|  | |||||||
| @ -351,9 +351,9 @@ TEST_F(ParserImplTest, TypeDecl_Array) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_FALSE(a->IsRuntimeArray()); |   ASSERT_FALSE(a->IsRuntimeArray()); | ||||||
|   ASSERT_EQ(a->size(), 5u); |   ASSERT_EQ(a->size(), 5u); | ||||||
|   ASSERT_TRUE(a->type()->IsF32()); |   ASSERT_TRUE(a->type()->IsF32()); | ||||||
| @ -367,9 +367,9 @@ TEST_F(ParserImplTest, TypeDecl_Array_Stride) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_FALSE(a->IsRuntimeArray()); |   ASSERT_FALSE(a->IsRuntimeArray()); | ||||||
|   ASSERT_EQ(a->size(), 5u); |   ASSERT_EQ(a->size(), 5u); | ||||||
|   ASSERT_TRUE(a->type()->IsF32()); |   ASSERT_TRUE(a->type()->IsF32()); | ||||||
| @ -384,9 +384,9 @@ TEST_F(ParserImplTest, TypeDecl_Array_Runtime_Stride) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_TRUE(a->IsRuntimeArray()); |   ASSERT_TRUE(a->IsRuntimeArray()); | ||||||
|   ASSERT_TRUE(a->type()->IsF32()); |   ASSERT_TRUE(a->type()->IsF32()); | ||||||
|   ASSERT_TRUE(a->has_array_stride()); |   ASSERT_TRUE(a->has_array_stride()); | ||||||
| @ -400,9 +400,9 @@ TEST_F(ParserImplTest, TypeDecl_Array_MultipleDecorations_OneBlock) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_TRUE(a->IsRuntimeArray()); |   ASSERT_TRUE(a->IsRuntimeArray()); | ||||||
|   ASSERT_TRUE(a->type()->IsF32()); |   ASSERT_TRUE(a->type()->IsF32()); | ||||||
| 
 | 
 | ||||||
| @ -421,9 +421,9 @@ TEST_F(ParserImplTest, TypeDecl_Array_MultipleDecorations_MultipleBlocks) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_TRUE(a->IsRuntimeArray()); |   ASSERT_TRUE(a->IsRuntimeArray()); | ||||||
|   ASSERT_TRUE(a->type()->IsF32()); |   ASSERT_TRUE(a->type()->IsF32()); | ||||||
| 
 | 
 | ||||||
| @ -524,9 +524,9 @@ TEST_F(ParserImplTest, TypeDecl_Array_Runtime) { | |||||||
|   EXPECT_FALSE(t.errored); |   EXPECT_FALSE(t.errored); | ||||||
|   ASSERT_NE(t.value, nullptr) << p->error(); |   ASSERT_NE(t.value, nullptr) << p->error(); | ||||||
|   ASSERT_FALSE(p->has_error()); |   ASSERT_FALSE(p->has_error()); | ||||||
|   ASSERT_TRUE(t->IsArray()); |   ASSERT_TRUE(t->Is<ast::type::ArrayType>()); | ||||||
| 
 | 
 | ||||||
|   auto* a = t->AsArray(); |   auto* a = t->As<ast::type::ArrayType>(); | ||||||
|   ASSERT_TRUE(a->IsRuntimeArray()); |   ASSERT_TRUE(a->IsRuntimeArray()); | ||||||
|   ASSERT_TRUE(a->type()->IsU32()); |   ASSERT_TRUE(a->type()->IsU32()); | ||||||
| } | } | ||||||
|  | |||||||
| @ -184,13 +184,15 @@ bool BoundArrayAccessorsTransform::ProcessArrayAccessor( | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   auto* ret_type = expr->array()->result_type()->UnwrapAll(); |   auto* ret_type = expr->array()->result_type()->UnwrapAll(); | ||||||
|   if (!ret_type->IsArray() && !ret_type->IsMatrix() && !ret_type->IsVector()) { |   if (!ret_type->Is<ast::type::ArrayType>() && !ret_type->IsMatrix() && | ||||||
|  |       !ret_type->IsVector()) { | ||||||
|     return true; |     return true; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (ret_type->IsVector() || ret_type->IsArray()) { |   if (ret_type->IsVector() || ret_type->Is<ast::type::ArrayType>()) { | ||||||
|     uint32_t size = ret_type->IsVector() ? ret_type->AsVector()->size() |     uint32_t size = ret_type->IsVector() | ||||||
|                                          : ret_type->AsArray()->size(); |                         ? ret_type->AsVector()->size() | ||||||
|  |                         : ret_type->As<ast::type::ArrayType>()->size(); | ||||||
|     if (size == 0) { |     if (size == 0) { | ||||||
|       error_ = "invalid 0 size for array or vector"; |       error_ = "invalid 0 size for array or vector"; | ||||||
|       return false; |       return false; | ||||||
|  | |||||||
| @ -333,8 +333,8 @@ bool TypeDeterminer::DetermineArrayAccessor( | |||||||
|   auto* res = expr->array()->result_type(); |   auto* res = expr->array()->result_type(); | ||||||
|   auto* parent_type = res->UnwrapAll(); |   auto* parent_type = res->UnwrapAll(); | ||||||
|   ast::type::Type* ret = nullptr; |   ast::type::Type* ret = nullptr; | ||||||
|   if (parent_type->IsArray()) { |   if (parent_type->Is<ast::type::ArrayType>()) { | ||||||
|     ret = parent_type->AsArray()->type(); |     ret = parent_type->As<ast::type::ArrayType>()->type(); | ||||||
|   } else if (parent_type->IsVector()) { |   } else if (parent_type->IsVector()) { | ||||||
|     ret = parent_type->AsVector()->type(); |     ret = parent_type->AsVector()->type(); | ||||||
|   } else if (parent_type->IsMatrix()) { |   } else if (parent_type->IsMatrix()) { | ||||||
| @ -351,8 +351,8 @@ bool TypeDeterminer::DetermineArrayAccessor( | |||||||
|   if (res->IsPointer()) { |   if (res->IsPointer()) { | ||||||
|     ret = mod_->create<ast::type::PointerType>( |     ret = mod_->create<ast::type::PointerType>( | ||||||
|         ret, res->AsPointer()->storage_class()); |         ret, res->AsPointer()->storage_class()); | ||||||
|   } else if (parent_type->IsArray() && |   } else if (parent_type->Is<ast::type::ArrayType>() && | ||||||
|              !parent_type->AsArray()->type()->is_scalar()) { |              !parent_type->As<ast::type::ArrayType>()->type()->is_scalar()) { | ||||||
|     // If we extract a non-scalar from an array then we also get a pointer. We
 |     // If we extract a non-scalar from an array then we also get a pointer. We
 | ||||||
|     // will generate a Function storage class variable to store this
 |     // will generate a Function storage class variable to store this
 | ||||||
|     // into.
 |     // into.
 | ||||||
|  | |||||||
| @ -86,8 +86,8 @@ bool ValidatorImpl::ValidateConstructedTypes( | |||||||
|     if (ct->IsStruct()) { |     if (ct->IsStruct()) { | ||||||
|       auto* st = ct->AsStruct(); |       auto* st = ct->AsStruct(); | ||||||
|       for (auto* member : st->impl()->members()) { |       for (auto* member : st->impl()->members()) { | ||||||
|         if (member->type()->UnwrapAll()->IsArray()) { |         if (member->type()->UnwrapAll()->Is<ast::type::ArrayType>()) { | ||||||
|           auto* r = member->type()->UnwrapAll()->AsArray(); |           auto* r = member->type()->UnwrapAll()->As<ast::type::ArrayType>(); | ||||||
|           if (r->IsRuntimeArray()) { |           if (r->IsRuntimeArray()) { | ||||||
|             if (member != st->impl()->members().back()) { |             if (member != st->impl()->members().back()) { | ||||||
|               add_error(member->source(), "v-0015", |               add_error(member->source(), "v-0015", | ||||||
| @ -263,8 +263,12 @@ bool ValidatorImpl::ValidateDeclStatement( | |||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|   variable_stack_.set(name, decl->variable()); |   variable_stack_.set(name, decl->variable()); | ||||||
|   if (decl->variable()->type()->UnwrapAll()->IsArray()) { |   if (decl->variable()->type()->UnwrapAll()->Is<ast::type::ArrayType>()) { | ||||||
|     if (decl->variable()->type()->UnwrapAll()->AsArray()->IsRuntimeArray()) { |     if (decl->variable() | ||||||
|  |             ->type() | ||||||
|  |             ->UnwrapAll() | ||||||
|  |             ->As<ast::type::ArrayType>() | ||||||
|  |             ->IsRuntimeArray()) { | ||||||
|       add_error(decl->source(), "v-0015", |       add_error(decl->source(), "v-0015", | ||||||
|                 "runtime arrays may only appear as the last " |                 "runtime arrays may only appear as the last " | ||||||
|                 "member of a struct: '" + |                 "member of a struct: '" + | ||||||
|  | |||||||
| @ -909,7 +909,7 @@ bool GeneratorImpl::EmitScalarConstructor( | |||||||
| bool GeneratorImpl::EmitTypeConstructor(std::ostream& pre, | bool GeneratorImpl::EmitTypeConstructor(std::ostream& pre, | ||||||
|                                         std::ostream& out, |                                         std::ostream& out, | ||||||
|                                         ast::TypeConstructorExpression* expr) { |                                         ast::TypeConstructorExpression* expr) { | ||||||
|   if (expr->type()->IsArray()) { |   if (expr->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out << "{"; |     out << "{"; | ||||||
|   } else { |   } else { | ||||||
|     if (!EmitType(out, expr->type(), "")) { |     if (!EmitType(out, expr->type(), "")) { | ||||||
| @ -938,7 +938,7 @@ bool GeneratorImpl::EmitTypeConstructor(std::ostream& pre, | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (expr->type()->IsArray()) { |   if (expr->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out << "}"; |     out << "}"; | ||||||
|   } else { |   } else { | ||||||
|     out << ")"; |     out << ")"; | ||||||
| @ -1219,7 +1219,7 @@ bool GeneratorImpl::EmitFunctionInternal(std::ostream& out, | |||||||
|       return false; |       return false; | ||||||
|     } |     } | ||||||
|     // Array name is output as part of the type
 |     // Array name is output as part of the type
 | ||||||
|     if (!v->type()->IsArray()) { |     if (!v->type()->Is<ast::type::ArrayType>()) { | ||||||
|       out << " " << v->name(); |       out << " " << v->name(); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -1718,8 +1718,8 @@ std::string GeneratorImpl::generate_storage_buffer_index_expression( | |||||||
|       auto* ary_type = ary->array()->result_type()->UnwrapAll(); |       auto* ary_type = ary->array()->result_type()->UnwrapAll(); | ||||||
| 
 | 
 | ||||||
|       out << "("; |       out << "("; | ||||||
|       if (ary_type->IsArray()) { |       if (ary_type->Is<ast::type::ArrayType>()) { | ||||||
|         out << ary_type->AsArray()->array_stride(); |         out << ary_type->As<ast::type::ArrayType>()->array_stride(); | ||||||
|       } else if (ary_type->IsVector()) { |       } else if (ary_type->IsVector()) { | ||||||
|         // TODO(dsinclair): This is a hack. Our vectors can only be f32, i32
 |         // TODO(dsinclair): This is a hack. Our vectors can only be f32, i32
 | ||||||
|         // or u32 which are all 4 bytes. When we get f16 or other types we'll
 |         // or u32 which are all 4 bytes. When we get f16 or other types we'll
 | ||||||
| @ -2032,21 +2032,21 @@ bool GeneratorImpl::EmitType(std::ostream& out, | |||||||
|   if (type->Is<ast::type::AliasType>()) { |   if (type->Is<ast::type::AliasType>()) { | ||||||
|     auto* alias = type->As<ast::type::AliasType>(); |     auto* alias = type->As<ast::type::AliasType>(); | ||||||
|     out << namer_.NameFor(alias->name()); |     out << namer_.NameFor(alias->name()); | ||||||
|   } else if (type->IsArray()) { |   } else if (type->Is<ast::type::ArrayType>()) { | ||||||
|     auto* ary = type->AsArray(); |     auto* ary = type->As<ast::type::ArrayType>(); | ||||||
| 
 | 
 | ||||||
|     ast::type::Type* base_type = ary; |     ast::type::Type* base_type = ary; | ||||||
|     std::vector<uint32_t> sizes; |     std::vector<uint32_t> sizes; | ||||||
|     while (base_type->IsArray()) { |     while (base_type->Is<ast::type::ArrayType>()) { | ||||||
|       if (base_type->AsArray()->IsRuntimeArray()) { |       if (base_type->As<ast::type::ArrayType>()->IsRuntimeArray()) { | ||||||
|         // TODO(dsinclair): Support runtime arrays
 |         // TODO(dsinclair): Support runtime arrays
 | ||||||
|         // https://bugs.chromium.org/p/tint/issues/detail?id=185
 |         // https://bugs.chromium.org/p/tint/issues/detail?id=185
 | ||||||
|         error_ = "runtime array not supported yet."; |         error_ = "runtime array not supported yet."; | ||||||
|         return false; |         return false; | ||||||
|       } else { |       } else { | ||||||
|         sizes.push_back(base_type->AsArray()->size()); |         sizes.push_back(base_type->As<ast::type::ArrayType>()->size()); | ||||||
|       } |       } | ||||||
|       base_type = base_type->AsArray()->type(); |       base_type = base_type->As<ast::type::ArrayType>()->type(); | ||||||
|     } |     } | ||||||
|     if (!EmitType(out, base_type, "")) { |     if (!EmitType(out, base_type, "")) { | ||||||
|       return false; |       return false; | ||||||
| @ -2163,7 +2163,7 @@ bool GeneratorImpl::EmitStructType(std::ostream& out, | |||||||
|       return false; |       return false; | ||||||
|     } |     } | ||||||
|     // Array member name will be output with the type
 |     // Array member name will be output with the type
 | ||||||
|     if (!mem->type()->IsArray()) { |     if (!mem->type()->Is<ast::type::ArrayType>()) { | ||||||
|       out << " " << namer_.NameFor(mem->name()); |       out << " " << namer_.NameFor(mem->name()); | ||||||
|     } |     } | ||||||
|     out << ";" << std::endl; |     out << ";" << std::endl; | ||||||
| @ -2226,7 +2226,7 @@ bool GeneratorImpl::EmitVariable(std::ostream& out, | |||||||
|   if (!EmitType(out, var->type(), var->name())) { |   if (!EmitType(out, var->type(), var->name())) { | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|   if (!var->type()->IsArray()) { |   if (!var->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out << " " << var->name(); |     out << " " << var->name(); | ||||||
|   } |   } | ||||||
|   out << constructor_out.str() << ";" << std::endl; |   out << constructor_out.str() << ";" << std::endl; | ||||||
| @ -2281,7 +2281,7 @@ bool GeneratorImpl::EmitProgramConstVariable(std::ostream& out, | |||||||
|     if (!EmitType(out, var->type(), var->name())) { |     if (!EmitType(out, var->type(), var->name())) { | ||||||
|       return false; |       return false; | ||||||
|     } |     } | ||||||
|     if (!var->type()->IsArray()) { |     if (!var->type()->Is<ast::type::ArrayType>()) { | ||||||
|       out << " " << var->name(); |       out << " " << var->name(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -188,8 +188,8 @@ uint32_t GeneratorImpl::calculate_alignment_size(ast::type::Type* type) { | |||||||
|   if (type->Is<ast::type::AliasType>()) { |   if (type->Is<ast::type::AliasType>()) { | ||||||
|     return calculate_alignment_size(type->As<ast::type::AliasType>()->type()); |     return calculate_alignment_size(type->As<ast::type::AliasType>()->type()); | ||||||
|   } |   } | ||||||
|   if (type->IsArray()) { |   if (type->Is<ast::type::ArrayType>()) { | ||||||
|     auto* ary = type->AsArray(); |     auto* ary = type->As<ast::type::ArrayType>(); | ||||||
|     // TODO(dsinclair): Handle array stride and adjust for alignment.
 |     // TODO(dsinclair): Handle array stride and adjust for alignment.
 | ||||||
|     uint32_t type_size = calculate_alignment_size(ary->type()); |     uint32_t type_size = calculate_alignment_size(ary->type()); | ||||||
|     return ary->size() * type_size; |     return ary->size() * type_size; | ||||||
| @ -890,7 +890,7 @@ bool GeneratorImpl::EmitContinue(ast::ContinueStatement*) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool GeneratorImpl::EmitTypeConstructor(ast::TypeConstructorExpression* expr) { | bool GeneratorImpl::EmitTypeConstructor(ast::TypeConstructorExpression* expr) { | ||||||
|   if (expr->type()->IsArray()) { |   if (expr->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out_ << "{"; |     out_ << "{"; | ||||||
|   } else { |   } else { | ||||||
|     if (!EmitType(expr->type(), "")) { |     if (!EmitType(expr->type(), "")) { | ||||||
| @ -919,7 +919,7 @@ bool GeneratorImpl::EmitTypeConstructor(ast::TypeConstructorExpression* expr) { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (expr->type()->IsArray()) { |   if (expr->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out_ << "}"; |     out_ << "}"; | ||||||
|   } else { |   } else { | ||||||
|     out_ << ")"; |     out_ << ")"; | ||||||
| @ -940,9 +940,9 @@ bool GeneratorImpl::EmitZeroValue(ast::type::Type* type) { | |||||||
|     return EmitZeroValue(type->AsVector()->type()); |     return EmitZeroValue(type->AsVector()->type()); | ||||||
|   } else if (type->IsMatrix()) { |   } else if (type->IsMatrix()) { | ||||||
|     return EmitZeroValue(type->AsMatrix()->type()); |     return EmitZeroValue(type->AsMatrix()->type()); | ||||||
|   } else if (type->IsArray()) { |   } else if (type->Is<ast::type::ArrayType>()) { | ||||||
|     out_ << "{"; |     out_ << "{"; | ||||||
|     if (!EmitZeroValue(type->AsArray()->type())) { |     if (!EmitZeroValue(type->As<ast::type::ArrayType>()->type())) { | ||||||
|       return false; |       return false; | ||||||
|     } |     } | ||||||
|     out_ << "}"; |     out_ << "}"; | ||||||
| @ -1308,7 +1308,7 @@ bool GeneratorImpl::EmitFunctionInternal(ast::Function* func, | |||||||
|       return false; |       return false; | ||||||
|     } |     } | ||||||
|     // Array name is output as part of the type
 |     // Array name is output as part of the type
 | ||||||
|     if (!v->type()->IsArray()) { |     if (!v->type()->Is<ast::type::ArrayType>()) { | ||||||
|       out_ << " " << v->name(); |       out_ << " " << v->name(); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -1790,18 +1790,18 @@ bool GeneratorImpl::EmitType(ast::type::Type* type, const std::string& name) { | |||||||
|   if (type->Is<ast::type::AliasType>()) { |   if (type->Is<ast::type::AliasType>()) { | ||||||
|     auto* alias = type->As<ast::type::AliasType>(); |     auto* alias = type->As<ast::type::AliasType>(); | ||||||
|     out_ << namer_.NameFor(alias->name()); |     out_ << namer_.NameFor(alias->name()); | ||||||
|   } else if (type->IsArray()) { |   } else if (type->Is<ast::type::ArrayType>()) { | ||||||
|     auto* ary = type->AsArray(); |     auto* ary = type->As<ast::type::ArrayType>(); | ||||||
| 
 | 
 | ||||||
|     ast::type::Type* base_type = ary; |     ast::type::Type* base_type = ary; | ||||||
|     std::vector<uint32_t> sizes; |     std::vector<uint32_t> sizes; | ||||||
|     while (base_type->IsArray()) { |     while (base_type->Is<ast::type::ArrayType>()) { | ||||||
|       if (base_type->AsArray()->IsRuntimeArray()) { |       if (base_type->As<ast::type::ArrayType>()->IsRuntimeArray()) { | ||||||
|         sizes.push_back(1); |         sizes.push_back(1); | ||||||
|       } else { |       } else { | ||||||
|         sizes.push_back(base_type->AsArray()->size()); |         sizes.push_back(base_type->As<ast::type::ArrayType>()->size()); | ||||||
|       } |       } | ||||||
|       base_type = base_type->AsArray()->type(); |       base_type = base_type->As<ast::type::ArrayType>()->type(); | ||||||
|     } |     } | ||||||
|     if (!EmitType(base_type, "")) { |     if (!EmitType(base_type, "")) { | ||||||
|       return false; |       return false; | ||||||
| @ -1964,7 +1964,7 @@ bool GeneratorImpl::EmitStructType(const ast::type::StructType* str) { | |||||||
|     current_offset += size; |     current_offset += size; | ||||||
| 
 | 
 | ||||||
|     // Array member name will be output with the type
 |     // Array member name will be output with the type
 | ||||||
|     if (!mem->type()->IsArray()) { |     if (!mem->type()->Is<ast::type::ArrayType>()) { | ||||||
|       out_ << " " << namer_.NameFor(mem->name()); |       out_ << " " << namer_.NameFor(mem->name()); | ||||||
|     } |     } | ||||||
|     out_ << ";" << std::endl; |     out_ << ";" << std::endl; | ||||||
| @ -2011,7 +2011,7 @@ bool GeneratorImpl::EmitVariable(ast::Variable* var, bool skip_constructor) { | |||||||
|   if (!EmitType(var->type(), var->name())) { |   if (!EmitType(var->type(), var->name())) { | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|   if (!var->type()->IsArray()) { |   if (!var->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out_ << " " << var->name(); |     out_ << " " << var->name(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| @ -2051,7 +2051,7 @@ bool GeneratorImpl::EmitProgramConstVariable(const ast::Variable* var) { | |||||||
|   if (!EmitType(var->type(), var->name())) { |   if (!EmitType(var->type(), var->name())) { | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|   if (!var->type()->IsArray()) { |   if (!var->type()->Is<ast::type::ArrayType>()) { | ||||||
|     out_ << " " << var->name(); |     out_ << " " << var->name(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -146,8 +146,8 @@ uint32_t IndexFromName(char name) { | |||||||
| /// @param type the given type, which must not be null
 | /// @param type the given type, which must not be null
 | ||||||
| /// @returns the nested matrix type, or nullptr if none
 | /// @returns the nested matrix type, or nullptr if none
 | ||||||
| ast::type::MatrixType* GetNestedMatrixType(ast::type::Type* type) { | ast::type::MatrixType* GetNestedMatrixType(ast::type::Type* type) { | ||||||
|   while (type->IsArray()) { |   while (type->Is<ast::type::ArrayType>()) { | ||||||
|     type = type->AsArray()->type(); |     type = type->As<ast::type::ArrayType>()->type(); | ||||||
|   } |   } | ||||||
|   return type->IsMatrix() ? type->AsMatrix() : nullptr; |   return type->IsMatrix() ? type->AsMatrix() : nullptr; | ||||||
| } | } | ||||||
| @ -818,8 +818,8 @@ bool Builder::GenerateArrayAccessor(ast::ArrayAccessorExpression* expr, | |||||||
|   // If the source is a pointer we access chain into it. We also access chain
 |   // If the source is a pointer we access chain into it. We also access chain
 | ||||||
|   // into an array of non-scalar types.
 |   // into an array of non-scalar types.
 | ||||||
|   if (info->source_type->IsPointer() || |   if (info->source_type->IsPointer() || | ||||||
|       (info->source_type->IsArray() && |       (info->source_type->Is<ast::type::ArrayType>() && | ||||||
|        !info->source_type->AsArray()->type()->is_scalar())) { |        !info->source_type->As<ast::type::ArrayType>()->type()->is_scalar())) { | ||||||
|     info->access_chain_indices.push_back(idx_id); |     info->access_chain_indices.push_back(idx_id); | ||||||
|     info->source_type = expr->result_type(); |     info->source_type = expr->result_type(); | ||||||
|     return true; |     return true; | ||||||
| @ -1008,8 +1008,8 @@ uint32_t Builder::GenerateAccessorExpression(ast::Expression* expr) { | |||||||
|         accessors[0]->AsArrayAccessor()->array()->result_type(); |         accessors[0]->AsArrayAccessor()->array()->result_type(); | ||||||
| 
 | 
 | ||||||
|     if (!ary_res_type->IsPointer() && |     if (!ary_res_type->IsPointer() && | ||||||
|         (ary_res_type->IsArray() && |         (ary_res_type->Is<ast::type::ArrayType>() && | ||||||
|          !ary_res_type->AsArray()->type()->is_scalar())) { |          !ary_res_type->As<ast::type::ArrayType>()->type()->is_scalar())) { | ||||||
|       ast::type::PointerType ptr(ary_res_type, ast::StorageClass::kFunction); |       ast::type::PointerType ptr(ary_res_type, ast::StorageClass::kFunction); | ||||||
|       auto result_type_id = GenerateTypeIfNeeded(&ptr); |       auto result_type_id = GenerateTypeIfNeeded(&ptr); | ||||||
|       if (result_type_id == 0) { |       if (result_type_id == 0) { | ||||||
| @ -1204,8 +1204,8 @@ bool Builder::is_constructor_const(ast::Expression* expr, bool is_global_init) { | |||||||
|       subtype = subtype->AsVector()->type()->UnwrapAll(); |       subtype = subtype->AsVector()->type()->UnwrapAll(); | ||||||
|     } else if (subtype->IsMatrix()) { |     } else if (subtype->IsMatrix()) { | ||||||
|       subtype = subtype->AsMatrix()->type()->UnwrapAll(); |       subtype = subtype->AsMatrix()->type()->UnwrapAll(); | ||||||
|     } else if (subtype->IsArray()) { |     } else if (subtype->Is<ast::type::ArrayType>()) { | ||||||
|       subtype = subtype->AsArray()->type()->UnwrapAll(); |       subtype = subtype->As<ast::type::ArrayType>()->type()->UnwrapAll(); | ||||||
|     } else if (subtype->IsStruct()) { |     } else if (subtype->IsStruct()) { | ||||||
|       subtype = subtype->AsStruct()->impl()->members()[i]->type()->UnwrapAll(); |       subtype = subtype->AsStruct()->impl()->members()[i]->type()->UnwrapAll(); | ||||||
|     } |     } | ||||||
| @ -1280,7 +1280,7 @@ uint32_t Builder::GenerateTypeConstructorExpression( | |||||||
|     // If the result is not a vector then we should have validated that the
 |     // If the result is not a vector then we should have validated that the
 | ||||||
|     // value type is a correctly sized vector so we can just use it directly.
 |     // value type is a correctly sized vector so we can just use it directly.
 | ||||||
|     if (result_type == value_type || result_type->IsMatrix() || |     if (result_type == value_type || result_type->IsMatrix() || | ||||||
|         result_type->IsArray() || result_type->IsStruct()) { |         result_type->Is<ast::type::ArrayType>() || result_type->IsStruct()) { | ||||||
|       out << "_" << id; |       out << "_" << id; | ||||||
| 
 | 
 | ||||||
|       ops.push_back(Operand::Int(id)); |       ops.push_back(Operand::Int(id)); | ||||||
| @ -2410,8 +2410,8 @@ uint32_t Builder::GenerateTypeIfNeeded(ast::type::Type* type) { | |||||||
|                             result)) { |                             result)) { | ||||||
|       return 0; |       return 0; | ||||||
|     } |     } | ||||||
|   } else if (type->IsArray()) { |   } else if (type->Is<ast::type::ArrayType>()) { | ||||||
|     if (!GenerateArrayType(type->AsArray(), result)) { |     if (!GenerateArrayType(type->As<ast::type::ArrayType>(), result)) { | ||||||
|       return 0; |       return 0; | ||||||
|     } |     } | ||||||
|   } else if (type->IsBool()) { |   } else if (type->IsBool()) { | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ | |||||||
| #include "src/ast/literal.h" | #include "src/ast/literal.h" | ||||||
| #include "src/ast/module.h" | #include "src/ast/module.h" | ||||||
| #include "src/ast/struct_member.h" | #include "src/ast/struct_member.h" | ||||||
|  | #include "src/ast/type/array_type.h" | ||||||
| #include "src/ast/type/access_control_type.h" | #include "src/ast/type/access_control_type.h" | ||||||
| #include "src/ast/type/storage_texture_type.h" | #include "src/ast/type/storage_texture_type.h" | ||||||
| #include "src/ast/type_constructor_expression.h" | #include "src/ast/type_constructor_expression.h" | ||||||
|  | |||||||
| @ -412,8 +412,8 @@ bool GeneratorImpl::EmitType(ast::type::Type* type) { | |||||||
|     } |     } | ||||||
|   } else if (type->Is<ast::type::AliasType>()) { |   } else if (type->Is<ast::type::AliasType>()) { | ||||||
|     out_ << type->As<ast::type::AliasType>()->name(); |     out_ << type->As<ast::type::AliasType>()->name(); | ||||||
|   } else if (type->IsArray()) { |   } else if (type->Is<ast::type::ArrayType>()) { | ||||||
|     auto* ary = type->AsArray(); |     auto* ary = type->As<ast::type::ArrayType>(); | ||||||
| 
 | 
 | ||||||
|     for (auto* deco : ary->decorations()) { |     for (auto* deco : ary->decorations()) { | ||||||
|       if (deco->IsStride()) { |       if (deco->IsStride()) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user