tint/resolver: Clean up workgroup-size error diagnostic
Change-Id: I09cc3e15c1f62d7a104e9727a104f3b2bfc9c973 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/94607 Reviewed-by: David Neto <dneto@google.com> Commit-Queue: Ben Clayton <bclayton@google.com>
This commit is contained in:
parent
410a3bd19a
commit
511529f082
|
@ -241,8 +241,8 @@ TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsAInt) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'abstract-int', expected 'void'");
|
"'abstract-int', expected 'void'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsAFloat) {
|
TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsAFloat) {
|
||||||
|
@ -251,8 +251,8 @@ TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsAFloat) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'abstract-float', expected 'void'");
|
"'abstract-float', expected 'void'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsI32) {
|
TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsI32) {
|
||||||
|
@ -261,8 +261,8 @@ TEST_F(ResolverFunctionValidationTest, VoidFunctionReturnsI32) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'i32', expected 'void'");
|
"'i32', expected 'void'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementType_void_fail) {
|
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementType_void_fail) {
|
||||||
|
@ -287,8 +287,8 @@ TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeM
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'void', expected 'f32'");
|
"'void', expected 'f32'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF32_pass) {
|
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF32_pass) {
|
||||||
|
@ -310,8 +310,8 @@ TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'i32', expected 'f32'");
|
"'i32', expected 'f32'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF32Alias_pass) {
|
TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF32Alias_pass) {
|
||||||
|
@ -337,8 +337,8 @@ TEST_F(ResolverFunctionValidationTest, FunctionTypeMustMatchReturnStatementTypeF
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: return statement type must match its function return "
|
"12:34 error: return statement type must match its function return type, returned "
|
||||||
"type, returned 'u32', expected 'f32'");
|
"'u32', expected 'f32'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, CannotCallEntryPoint) {
|
TEST_F(ResolverFunctionValidationTest, CannotCallEntryPoint) {
|
||||||
|
@ -638,8 +638,8 @@ TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Literal_BadType) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: workgroup_size argument must be either literal or "
|
"12:34 error: workgroup_size argument must be either a literal, constant, or "
|
||||||
"module-scope constant of type i32 or u32");
|
"overridable of type abstract-integer, i32 or u32");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Literal_Negative) {
|
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Literal_Negative) {
|
||||||
|
@ -674,8 +674,8 @@ TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Const_BadType) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: workgroup_size argument must be either literal or "
|
"12:34 error: workgroup_size argument must be either a literal, constant, or "
|
||||||
"module-scope constant of type i32 or u32");
|
"overridable of type abstract-integer, i32 or u32");
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(crbug.com/tint/1580): Remove when module-scope 'let' is removed
|
// TODO(crbug.com/tint/1580): Remove when module-scope 'let' is removed
|
||||||
|
@ -689,8 +689,8 @@ TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Let_BadType) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: workgroup_size argument must be either literal or "
|
"12:34 error: workgroup_size argument must be either a literal, constant, or "
|
||||||
"module-scope constant of type i32 or u32");
|
"overridable of type abstract-integer, i32 or u32");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Const_Negative) {
|
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_Const_Negative) {
|
||||||
|
@ -778,8 +778,8 @@ TEST_F(ResolverFunctionValidationTest, WorkgroupSize_NonConst) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: workgroup_size argument must be either literal or "
|
"12:34 error: workgroup_size argument must be either a literal, constant, or "
|
||||||
"module-scope constant of type i32 or u32");
|
"overridable of type abstract-integer, i32 or u32");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_InvalidExpr) {
|
TEST_F(ResolverFunctionValidationTest, WorkgroupSize_InvalidExpr) {
|
||||||
|
@ -791,8 +791,8 @@ TEST_F(ResolverFunctionValidationTest, WorkgroupSize_InvalidExpr) {
|
||||||
|
|
||||||
EXPECT_FALSE(r()->Resolve());
|
EXPECT_FALSE(r()->Resolve());
|
||||||
EXPECT_EQ(r()->error(),
|
EXPECT_EQ(r()->error(),
|
||||||
"12:34 error: workgroup_size argument must be either a literal or "
|
"12:34 error: workgroup_size argument must be either a literal, constant, or "
|
||||||
"a module-scope constant");
|
"overridable of type abstract-integer, i32 or u32");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverFunctionValidationTest, ReturnIsConstructible_NonPlain) {
|
TEST_F(ResolverFunctionValidationTest, ReturnIsConstructible_NonPlain) {
|
||||||
|
|
|
@ -885,9 +885,9 @@ bool Resolver::WorkgroupSize(const ast::Function* func) {
|
||||||
std::array<const sem::Type*, 3> arg_tys = {};
|
std::array<const sem::Type*, 3> arg_tys = {};
|
||||||
size_t arg_count = 0;
|
size_t arg_count = 0;
|
||||||
|
|
||||||
constexpr const char* kErrBadType =
|
constexpr const char* kErrBadExpr =
|
||||||
"workgroup_size argument must be either literal or module-scope constant of type i32 "
|
"workgroup_size argument must be either a literal, constant, or overridable of type "
|
||||||
"or u32";
|
"abstract-integer, i32 or u32";
|
||||||
|
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
// Each argument to this attribute can either be a literal, an identifier for a module-scope
|
// Each argument to this attribute can either be a literal, an identifier for a module-scope
|
||||||
|
@ -902,7 +902,7 @@ bool Resolver::WorkgroupSize(const ast::Function* func) {
|
||||||
}
|
}
|
||||||
auto* ty = expr->Type();
|
auto* ty = expr->Type();
|
||||||
if (!ty->IsAnyOf<sem::I32, sem::U32, sem::AbstractInt>()) {
|
if (!ty->IsAnyOf<sem::I32, sem::U32, sem::AbstractInt>()) {
|
||||||
AddError(kErrBadType, value->source);
|
AddError(kErrBadExpr, value->source);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -935,7 +935,7 @@ bool Resolver::WorkgroupSize(const ast::Function* func) {
|
||||||
// We have an variable of a module-scope constant.
|
// We have an variable of a module-scope constant.
|
||||||
auto* decl = user->Variable()->Declaration();
|
auto* decl = user->Variable()->Declaration();
|
||||||
if (!decl->IsAnyOf<ast::Let, ast::Const, ast::Override>()) {
|
if (!decl->IsAnyOf<ast::Let, ast::Const, ast::Override>()) {
|
||||||
AddError(kErrBadType, values[i]->source);
|
AddError(kErrBadExpr, values[i]->source);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// Capture the constant if it is pipeline-overridable.
|
// Capture the constant if it is pipeline-overridable.
|
||||||
|
@ -953,10 +953,7 @@ bool Resolver::WorkgroupSize(const ast::Function* func) {
|
||||||
} else if (values[i]->Is<ast::LiteralExpression>()) {
|
} else if (values[i]->Is<ast::LiteralExpression>()) {
|
||||||
value = materialized->ConstantValue();
|
value = materialized->ConstantValue();
|
||||||
} else {
|
} else {
|
||||||
AddError(
|
AddError(kErrBadExpr, values[i]->source);
|
||||||
"workgroup_size argument must be either a literal or a "
|
|
||||||
"module-scope constant",
|
|
||||||
values[i]->source);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue