mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-05-15 20:01:22 +00:00
Deep-clones all `Node`s and `Type`s into a new module. Instead of writing a million standalone tests that'll only ever test the existing fields of each type, I've opted to write the tests using wgsl<->ast<->wgsl conversion. This means the tests require the enabling of TINT_BUILD_WGSL_READER and TINT_BUILD_WGSL_WRITER, but I believe this is much easier to maintain. I'm aware there are probably gaps in the tests, and that even full coverage is likely to rapidly rot, so I've also added fuzzers/tint_ast_clone_fuzzer.cc - a fuzzer based test that ensures that all AST modules can be cloned with identical reproduction. I've run this across 100 cores of a 3990x for 4 hours, fixing the single issue it detected. Note: Expressions do not currently clone their `TypeManager` determined types. This is for two reasons: (a) This initial CL is mahoosive enough. (b) I'm uncertain whether we actually want to clone this info, or to re-run the `TypeDeterminer` after each AST transform. Maybe it should be optional. Time will tell. Fixed: tint:307 Change-Id: Id90fab06aaa740c805d12b66f3f11d1f452c6805 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/33300 Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: dan sinclair <dsinclair@chromium.org> Reviewed-by: David Neto <dneto@google.com>
85 lines
2.8 KiB
C++
85 lines
2.8 KiB
C++
// 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.
|
|
|
|
#ifndef SRC_AST_ASSIGNMENT_STATEMENT_H_
|
|
#define SRC_AST_ASSIGNMENT_STATEMENT_H_
|
|
|
|
#include <memory>
|
|
#include <utility>
|
|
|
|
#include "src/ast/expression.h"
|
|
#include "src/ast/literal.h"
|
|
#include "src/ast/statement.h"
|
|
|
|
namespace tint {
|
|
namespace ast {
|
|
|
|
/// An assignment statement
|
|
class AssignmentStatement : public Castable<AssignmentStatement, Statement> {
|
|
public:
|
|
/// Constructor
|
|
AssignmentStatement();
|
|
/// Constructor
|
|
/// @param lhs the left side of the expression
|
|
/// @param rhs the right side of the expression
|
|
AssignmentStatement(Expression* lhs, Expression* rhs);
|
|
/// Constructor
|
|
/// @param source the assignment statement source
|
|
/// @param lhs the left side of the expression
|
|
/// @param rhs the right side of the expression
|
|
AssignmentStatement(const Source& source, Expression* lhs, Expression* rhs);
|
|
/// Move constructor
|
|
AssignmentStatement(AssignmentStatement&&);
|
|
~AssignmentStatement() override;
|
|
|
|
/// Sets the left side of the statement
|
|
/// @param lhs the left side to set
|
|
void set_lhs(Expression* lhs) { lhs_ = lhs; }
|
|
/// @returns the left side expression
|
|
Expression* lhs() const { return lhs_; }
|
|
|
|
/// Sets the right side of the statement
|
|
/// @param rhs the right side to set
|
|
void set_rhs(Expression* rhs) { rhs_ = rhs; }
|
|
/// @returns the right side expression
|
|
Expression* rhs() const { return rhs_; }
|
|
|
|
/// Clones this node and all transitive child nodes using the `CloneContext`
|
|
/// `ctx`.
|
|
/// @note Semantic information such as resolved expression type and intrinsic
|
|
/// information is not cloned.
|
|
/// @param ctx the clone context
|
|
/// @return the newly cloned node
|
|
AssignmentStatement* Clone(CloneContext* ctx) const override;
|
|
|
|
/// @returns true if the node is valid
|
|
bool IsValid() const override;
|
|
|
|
/// Writes a representation of the node to the output stream
|
|
/// @param out the stream to write to
|
|
/// @param indent number of spaces to indent the node when writing
|
|
void to_str(std::ostream& out, size_t indent) const override;
|
|
|
|
private:
|
|
AssignmentStatement(const AssignmentStatement&) = delete;
|
|
|
|
Expression* lhs_ = nullptr;
|
|
Expression* rhs_ = nullptr;
|
|
};
|
|
|
|
} // namespace ast
|
|
} // namespace tint
|
|
|
|
#endif // SRC_AST_ASSIGNMENT_STATEMENT_H_
|