mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-06-05 14:13:39 +00:00
Remove premerge.
This CL removes the premerge statement and replaces it with a `premerge` reserved word. Change-Id: Ic9bc13878ed26e1733eb65dd1ba30d9bef095cb6 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/19380 Reviewed-by: Ryan Harrison <rharrison@chromium.org>
This commit is contained in:
parent
efb5d4e10f
commit
a28bcceb15
@ -385,7 +385,6 @@ if(${TINT_BUILD_WGSL_READER})
|
|||||||
reader/wgsl/parser_impl_paren_rhs_stmt_test.cc
|
reader/wgsl/parser_impl_paren_rhs_stmt_test.cc
|
||||||
reader/wgsl/parser_impl_pipeline_stage_test.cc
|
reader/wgsl/parser_impl_pipeline_stage_test.cc
|
||||||
reader/wgsl/parser_impl_postfix_expression_test.cc
|
reader/wgsl/parser_impl_postfix_expression_test.cc
|
||||||
reader/wgsl/parser_impl_premerge_stmt_test.cc
|
|
||||||
reader/wgsl/parser_impl_primary_expression_test.cc
|
reader/wgsl/parser_impl_primary_expression_test.cc
|
||||||
reader/wgsl/parser_impl_relational_expression_test.cc
|
reader/wgsl/parser_impl_relational_expression_test.cc
|
||||||
reader/wgsl/parser_impl_shift_expression_test.cc
|
reader/wgsl/parser_impl_shift_expression_test.cc
|
||||||
|
@ -62,20 +62,6 @@ bool IfStatement::IsValid() const {
|
|||||||
found_else = true;
|
found_else = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& stmt : premerge_) {
|
|
||||||
if (stmt == nullptr || !stmt->IsValid())
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (premerge_.size() > 0) {
|
|
||||||
// Premerge only with a single else statement
|
|
||||||
if (else_statements_.size() != 1)
|
|
||||||
return false;
|
|
||||||
// Must be an else, not an elseif
|
|
||||||
if (else_statements_[0]->condition() != nullptr)
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,18 +94,8 @@ void IfStatement::to_str(std::ostream& out, size_t indent) const {
|
|||||||
make_indent(out, indent);
|
make_indent(out, indent);
|
||||||
out << "}" << std::endl;
|
out << "}" << std::endl;
|
||||||
|
|
||||||
for (const auto& e : else_statements_)
|
for (const auto& e : else_statements_) {
|
||||||
e->to_str(out, indent);
|
e->to_str(out, indent);
|
||||||
|
|
||||||
if (premerge_.size() > 0) {
|
|
||||||
make_indent(out, indent);
|
|
||||||
out << "premerge{" << std::endl;
|
|
||||||
|
|
||||||
for (const auto& stmt : premerge_)
|
|
||||||
stmt->to_str(out, indent + 2);
|
|
||||||
|
|
||||||
make_indent(out, indent);
|
|
||||||
out << "}" << std::endl;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,12 +67,6 @@ class IfStatement : public Statement {
|
|||||||
/// @returns the else statements
|
/// @returns the else statements
|
||||||
const ElseStatementList& else_statements() const { return else_statements_; }
|
const ElseStatementList& else_statements() const { return else_statements_; }
|
||||||
|
|
||||||
/// Sets the premerge statements
|
|
||||||
/// @param premerge the premerge statements
|
|
||||||
void set_premerge(StatementList premerge) { premerge_ = std::move(premerge); }
|
|
||||||
/// @returns the premerge statements
|
|
||||||
const StatementList& premerge() const { return premerge_; }
|
|
||||||
|
|
||||||
/// @returns true if this is a if statement
|
/// @returns true if this is a if statement
|
||||||
bool IsIf() const override;
|
bool IsIf() const override;
|
||||||
|
|
||||||
@ -90,7 +84,6 @@ class IfStatement : public Statement {
|
|||||||
std::unique_ptr<Expression> condition_;
|
std::unique_ptr<Expression> condition_;
|
||||||
StatementList body_;
|
StatementList body_;
|
||||||
ElseStatementList else_statements_;
|
ElseStatementList else_statements_;
|
||||||
StatementList premerge_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace ast
|
} // namespace ast
|
||||||
|
@ -79,23 +79,6 @@ TEST_F(IfStatementTest, IsValid_WithElseStatements) {
|
|||||||
EXPECT_TRUE(stmt.IsValid());
|
EXPECT_TRUE(stmt.IsValid());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_WithPremerge) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
ElseStatementList else_stmts;
|
|
||||||
else_stmts.push_back(std::make_unique<ElseStatement>());
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_else_statements(std::move(else_stmts));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
EXPECT_TRUE(stmt.IsValid());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_MissingCondition) {
|
TEST_F(IfStatementTest, IsValid_MissingCondition) {
|
||||||
StatementList body;
|
StatementList body;
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
body.push_back(std::make_unique<NopStatement>());
|
||||||
@ -163,72 +146,6 @@ TEST_F(IfStatementTest, IsValid_InvalidElseStatement) {
|
|||||||
EXPECT_FALSE(stmt.IsValid());
|
EXPECT_FALSE(stmt.IsValid());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_NullPremergeStatement) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
ElseStatementList else_stmts;
|
|
||||||
else_stmts.push_back(std::make_unique<ElseStatement>());
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<NopStatement>());
|
|
||||||
premerge.push_back(nullptr);
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_else_statements(std::move(else_stmts));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
EXPECT_FALSE(stmt.IsValid());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_InvalidPremergeStatement) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
ElseStatementList else_stmts;
|
|
||||||
else_stmts.push_back(std::make_unique<ElseStatement>());
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<IfStatement>());
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_else_statements(std::move(else_stmts));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
EXPECT_FALSE(stmt.IsValid());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_PremergeWithElseIf) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
ElseStatementList else_stmts;
|
|
||||||
else_stmts.push_back(std::make_unique<ElseStatement>());
|
|
||||||
else_stmts[0]->set_condition(std::make_unique<IdentifierExpression>("ident"));
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_else_statements(std::move(else_stmts));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
EXPECT_FALSE(stmt.IsValid());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_PremergeWithoutElse) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
EXPECT_FALSE(stmt.IsValid());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(IfStatementTest, IsValid_MultipleElseWiththoutCondition) {
|
TEST_F(IfStatementTest, IsValid_MultipleElseWiththoutCondition) {
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
auto cond = std::make_unique<IdentifierExpression>("cond");
|
||||||
StatementList body;
|
StatementList body;
|
||||||
@ -327,41 +244,6 @@ TEST_F(IfStatementTest, ToStr_WithElseStatements) {
|
|||||||
)");
|
)");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(IfStatementTest, ToStr_WithPremerge) {
|
|
||||||
auto cond = std::make_unique<IdentifierExpression>("cond");
|
|
||||||
StatementList body;
|
|
||||||
body.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
ElseStatementList else_stmts;
|
|
||||||
else_stmts.push_back(std::make_unique<ElseStatement>());
|
|
||||||
|
|
||||||
StatementList premerge;
|
|
||||||
premerge.push_back(std::make_unique<NopStatement>());
|
|
||||||
|
|
||||||
IfStatement stmt(std::move(cond), std::move(body));
|
|
||||||
stmt.set_else_statements(std::move(else_stmts));
|
|
||||||
stmt.set_premerge(std::move(premerge));
|
|
||||||
|
|
||||||
std::ostringstream out;
|
|
||||||
stmt.to_str(out, 2);
|
|
||||||
EXPECT_EQ(out.str(), R"( If{
|
|
||||||
(
|
|
||||||
Identifier{cond}
|
|
||||||
)
|
|
||||||
{
|
|
||||||
Nop{}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Else{
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
premerge{
|
|
||||||
Nop{}
|
|
||||||
}
|
|
||||||
)");
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
} // namespace ast
|
} // namespace ast
|
||||||
} // namespace tint
|
} // namespace tint
|
||||||
|
@ -598,8 +598,6 @@ Token Lexer::check_keyword(const Source& source, const std::string& str) {
|
|||||||
return {Token::Type::kOuterProduct, source, "outer_product"};
|
return {Token::Type::kOuterProduct, source, "outer_product"};
|
||||||
if (str == "position")
|
if (str == "position")
|
||||||
return {Token::Type::kPosition, source, "position"};
|
return {Token::Type::kPosition, source, "position"};
|
||||||
if (str == "premerge")
|
|
||||||
return {Token::Type::kPremerge, source, "premerge"};
|
|
||||||
if (str == "private")
|
if (str == "private")
|
||||||
return {Token::Type::kPrivate, source, "private"};
|
return {Token::Type::kPrivate, source, "private"};
|
||||||
if (str == "ptr")
|
if (str == "ptr")
|
||||||
@ -673,6 +671,8 @@ Token Lexer::check_reserved(const Source& source, const std::string& str) {
|
|||||||
return {Token::Type::kReservedKeyword, source, "i64"};
|
return {Token::Type::kReservedKeyword, source, "i64"};
|
||||||
if (str == "let")
|
if (str == "let")
|
||||||
return {Token::Type::kReservedKeyword, source, "let"};
|
return {Token::Type::kReservedKeyword, source, "let"};
|
||||||
|
if (str == "premerge")
|
||||||
|
return {Token::Type::kReservedKeyword, source, "premerge"};
|
||||||
if (str == "typedef")
|
if (str == "typedef")
|
||||||
return {Token::Type::kReservedKeyword, source, "typedef"};
|
return {Token::Type::kReservedKeyword, source, "typedef"};
|
||||||
if (str == "u8")
|
if (str == "u8")
|
||||||
|
@ -474,7 +474,6 @@ INSTANTIATE_TEST_SUITE_P(
|
|||||||
TokenData{"out", Token::Type::kOut},
|
TokenData{"out", Token::Type::kOut},
|
||||||
TokenData{"outer_product", Token::Type::kOuterProduct},
|
TokenData{"outer_product", Token::Type::kOuterProduct},
|
||||||
TokenData{"position", Token::Type::kPosition},
|
TokenData{"position", Token::Type::kPosition},
|
||||||
TokenData{"premerge", Token::Type::kPremerge},
|
|
||||||
TokenData{"private", Token::Type::kPrivate},
|
TokenData{"private", Token::Type::kPrivate},
|
||||||
TokenData{"ptr", Token::Type::kPtr},
|
TokenData{"ptr", Token::Type::kPtr},
|
||||||
TokenData{"push_constant", Token::Type::kPushConstant},
|
TokenData{"push_constant", Token::Type::kPushConstant},
|
||||||
@ -521,6 +520,7 @@ INSTANTIATE_TEST_SUITE_P(LexerTest,
|
|||||||
"i16",
|
"i16",
|
||||||
"i64",
|
"i64",
|
||||||
"let",
|
"let",
|
||||||
|
"premerge",
|
||||||
"typedef",
|
"typedef",
|
||||||
"u8",
|
"u8",
|
||||||
"u16",
|
"u16",
|
||||||
|
@ -1720,7 +1720,7 @@ std::unique_ptr<ast::VariableDeclStatement> ParserImpl::variable_stmt() {
|
|||||||
|
|
||||||
// if_stmt
|
// if_stmt
|
||||||
// : IF paren_rhs_stmt body_stmt
|
// : IF paren_rhs_stmt body_stmt
|
||||||
// {(elseif_stmt else_stmt?) | (else_stmt premerge_stmt?)}
|
// {(elseif_stmt else_stmt?) | (else_stmt?)}
|
||||||
std::unique_ptr<ast::IfStatement> ParserImpl::if_stmt() {
|
std::unique_ptr<ast::IfStatement> ParserImpl::if_stmt() {
|
||||||
auto t = peek();
|
auto t = peek();
|
||||||
if (!t.IsIf())
|
if (!t.IsIf())
|
||||||
@ -1758,13 +1758,6 @@ std::unique_ptr<ast::IfStatement> ParserImpl::if_stmt() {
|
|||||||
auto stmt = std::make_unique<ast::IfStatement>(source, std::move(condition),
|
auto stmt = std::make_unique<ast::IfStatement>(source, std::move(condition),
|
||||||
std::move(body));
|
std::move(body));
|
||||||
if (el != nullptr) {
|
if (el != nullptr) {
|
||||||
if (elseif.size() == 0) {
|
|
||||||
auto premerge = premerge_stmt();
|
|
||||||
if (has_error())
|
|
||||||
return nullptr;
|
|
||||||
|
|
||||||
stmt->set_premerge(std::move(premerge));
|
|
||||||
}
|
|
||||||
elseif.push_back(std::move(el));
|
elseif.push_back(std::move(el));
|
||||||
}
|
}
|
||||||
stmt->set_else_statements(std::move(elseif));
|
stmt->set_else_statements(std::move(elseif));
|
||||||
@ -1836,17 +1829,6 @@ std::unique_ptr<ast::ElseStatement> ParserImpl::else_stmt() {
|
|||||||
return std::make_unique<ast::ElseStatement>(source, std::move(body));
|
return std::make_unique<ast::ElseStatement>(source, std::move(body));
|
||||||
}
|
}
|
||||||
|
|
||||||
// premerge_stmt
|
|
||||||
// : PREMERGE body_stmt
|
|
||||||
ast::StatementList ParserImpl::premerge_stmt() {
|
|
||||||
auto t = peek();
|
|
||||||
if (!t.IsPremerge())
|
|
||||||
return {};
|
|
||||||
|
|
||||||
next(); // Consume the peek
|
|
||||||
return body_stmt();
|
|
||||||
}
|
|
||||||
|
|
||||||
// unless_stmt
|
// unless_stmt
|
||||||
// : UNLESS paren_rhs_stmt body_stmt
|
// : UNLESS paren_rhs_stmt body_stmt
|
||||||
std::unique_ptr<ast::UnlessStatement> ParserImpl::unless_stmt() {
|
std::unique_ptr<ast::UnlessStatement> ParserImpl::unless_stmt() {
|
||||||
|
@ -208,9 +208,6 @@ class ParserImpl {
|
|||||||
/// Parses a `else_stmt` grammar element
|
/// Parses a `else_stmt` grammar element
|
||||||
/// @returns the parsed statement or nullptr
|
/// @returns the parsed statement or nullptr
|
||||||
std::unique_ptr<ast::ElseStatement> else_stmt();
|
std::unique_ptr<ast::ElseStatement> else_stmt();
|
||||||
/// Parses a `premerge_stmt` grammar element
|
|
||||||
/// @returns the parsed statements
|
|
||||||
ast::StatementList premerge_stmt();
|
|
||||||
/// Parses a `unless_stmt` grammar element
|
/// Parses a `unless_stmt` grammar element
|
||||||
/// @returns the parsed element or nullptr
|
/// @returns the parsed element or nullptr
|
||||||
std::unique_ptr<ast::UnlessStatement> unless_stmt();
|
std::unique_ptr<ast::UnlessStatement> unless_stmt();
|
||||||
|
@ -34,7 +34,6 @@ TEST_F(ParserImplTest, IfStmt) {
|
|||||||
ASSERT_TRUE(e->condition()->IsBinary());
|
ASSERT_TRUE(e->condition()->IsBinary());
|
||||||
EXPECT_EQ(e->body().size(), 2);
|
EXPECT_EQ(e->body().size(), 2);
|
||||||
EXPECT_EQ(e->else_statements().size(), 0);
|
EXPECT_EQ(e->else_statements().size(), 0);
|
||||||
EXPECT_EQ(e->premerge().size(), 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ParserImplTest, IfStmt_WithElse) {
|
TEST_F(ParserImplTest, IfStmt_WithElse) {
|
||||||
@ -57,31 +56,6 @@ TEST_F(ParserImplTest, IfStmt_WithElse) {
|
|||||||
EXPECT_EQ(e->else_statements()[1]->body().size(), 0);
|
EXPECT_EQ(e->else_statements()[1]->body().size(), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ParserImplTest, IfStmt_WithPremerge) {
|
|
||||||
auto p = parser(R"(if (a == 4) {
|
|
||||||
a = b;
|
|
||||||
c = d;
|
|
||||||
} else {
|
|
||||||
d = 2;
|
|
||||||
} premerge {
|
|
||||||
a = 2;
|
|
||||||
})");
|
|
||||||
auto e = p->if_stmt();
|
|
||||||
ASSERT_FALSE(p->has_error()) << p->error();
|
|
||||||
ASSERT_NE(e, nullptr);
|
|
||||||
|
|
||||||
ASSERT_TRUE(e->IsIf());
|
|
||||||
ASSERT_NE(e->condition(), nullptr);
|
|
||||||
ASSERT_TRUE(e->condition()->IsBinary());
|
|
||||||
EXPECT_EQ(e->body().size(), 2);
|
|
||||||
|
|
||||||
ASSERT_EQ(e->else_statements().size(), 1);
|
|
||||||
ASSERT_EQ(e->else_statements()[0]->condition(), nullptr);
|
|
||||||
EXPECT_EQ(e->else_statements()[0]->body().size(), 1);
|
|
||||||
|
|
||||||
ASSERT_EQ(e->premerge().size(), 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(ParserImplTest, IfStmt_InvalidCondition) {
|
TEST_F(ParserImplTest, IfStmt_InvalidCondition) {
|
||||||
auto p = parser("if (a = 3) {}");
|
auto p = parser("if (a = 3) {}");
|
||||||
auto e = p->if_stmt();
|
auto e = p->if_stmt();
|
||||||
@ -130,14 +104,6 @@ TEST_F(ParserImplTest, IfStmt_InvalidElse) {
|
|||||||
EXPECT_EQ(p->error(), "1:18: missing }");
|
EXPECT_EQ(p->error(), "1:18: missing }");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ParserImplTest, IfStmt_InvalidPremerge) {
|
|
||||||
auto p = parser("if (a) {} else {} premerge { fn main() -> a{}}");
|
|
||||||
auto e = p->if_stmt();
|
|
||||||
ASSERT_TRUE(p->has_error());
|
|
||||||
ASSERT_EQ(e, nullptr);
|
|
||||||
EXPECT_EQ(p->error(), "1:30: missing }");
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
} // namespace wgsl
|
} // namespace wgsl
|
||||||
} // namespace reader
|
} // namespace reader
|
||||||
|
@ -1,43 +0,0 @@
|
|||||||
// Copyright 2020 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 "gtest/gtest.h"
|
|
||||||
#include "src/reader/wgsl/parser_impl.h"
|
|
||||||
#include "src/reader/wgsl/parser_impl_test_helper.h"
|
|
||||||
|
|
||||||
namespace tint {
|
|
||||||
namespace reader {
|
|
||||||
namespace wgsl {
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
TEST_F(ParserImplTest, PremergeStmt) {
|
|
||||||
auto p = parser("premerge { nop; }");
|
|
||||||
auto e = p->premerge_stmt();
|
|
||||||
ASSERT_FALSE(p->has_error()) << p->error();
|
|
||||||
ASSERT_EQ(e.size(), 1);
|
|
||||||
ASSERT_TRUE(e[0]->IsNop());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(ParserImplTest, PremergeStmt_InvalidBody) {
|
|
||||||
auto p = parser("premerge { nop }");
|
|
||||||
auto e = p->premerge_stmt();
|
|
||||||
ASSERT_TRUE(p->has_error());
|
|
||||||
ASSERT_EQ(e.size(), 0);
|
|
||||||
EXPECT_EQ(p->error(), "1:16: missing ;");
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
||||||
} // namespace wgsl
|
|
||||||
} // namespace reader
|
|
||||||
} // namespace tint
|
|
@ -561,8 +561,6 @@ class Token {
|
|||||||
bool IsOuterProduct() const { return type_ == Type::kOuterProduct; }
|
bool IsOuterProduct() const { return type_ == Type::kOuterProduct; }
|
||||||
/// @returns true if token is a 'position'
|
/// @returns true if token is a 'position'
|
||||||
bool IsPosition() const { return type_ == Type::kPosition; }
|
bool IsPosition() const { return type_ == Type::kPosition; }
|
||||||
/// @returns true if token is a 'premerge'
|
|
||||||
bool IsPremerge() const { return type_ == Type::kPremerge; }
|
|
||||||
/// @returns true if token is a 'private'
|
/// @returns true if token is a 'private'
|
||||||
bool IsPrivate() const { return type_ == Type::kPrivate; }
|
bool IsPrivate() const { return type_ == Type::kPrivate; }
|
||||||
/// @returns true if token is a 'ptr'
|
/// @returns true if token is a 'ptr'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user