Remove suppressing [chromium-style] errors

Lots of little style nits needed to be fixed for this work.

BUG=tint:44

Change-Id: Ibb45d9e3f6795ee0c09f5eca994bb28e20979d97
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/19221
Reviewed-by: dan sinclair <dsinclair@google.com>
This commit is contained in:
Ryan Harrison 2020-04-09 18:52:06 +00:00 committed by dan sinclair
parent 1234633b32
commit 4d32be4f1b
122 changed files with 725 additions and 224 deletions

View File

@ -34,8 +34,8 @@ source_set("libtint") {
"src/ast/binary_expression.h", "src/ast/binary_expression.h",
"src/ast/binding_decoration.cc", "src/ast/binding_decoration.cc",
"src/ast/binding_decoration.h", "src/ast/binding_decoration.h",
"src/ast/bool_literal.h",
"src/ast/bool_literal.cc", "src/ast/bool_literal.cc",
"src/ast/bool_literal.h",
"src/ast/break_statement.cc", "src/ast/break_statement.cc",
"src/ast/break_statement.h", "src/ast/break_statement.h",
"src/ast/builtin.cc", "src/ast/builtin.cc",
@ -78,8 +78,8 @@ source_set("libtint") {
"src/ast/int_literal.h", "src/ast/int_literal.h",
"src/ast/kill_statement.cc", "src/ast/kill_statement.cc",
"src/ast/kill_statement.h", "src/ast/kill_statement.h",
"src/ast/literal.h",
"src/ast/literal.cc", "src/ast/literal.cc",
"src/ast/literal.h",
"src/ast/location_decoration.cc", "src/ast/location_decoration.cc",
"src/ast/location_decoration.h", "src/ast/location_decoration.h",
"src/ast/loop_statement.cc", "src/ast/loop_statement.cc",
@ -108,10 +108,10 @@ source_set("libtint") {
"src/ast/statement_condition.h", "src/ast/statement_condition.h",
"src/ast/storage_class.cc", "src/ast/storage_class.cc",
"src/ast/storage_class.h", "src/ast/storage_class.h",
"src/ast/struct_decoration.cc",
"src/ast/struct_decoration.h",
"src/ast/struct.cc", "src/ast/struct.cc",
"src/ast/struct.h", "src/ast/struct.h",
"src/ast/struct_decoration.cc",
"src/ast/struct_decoration.h",
"src/ast/struct_member.cc", "src/ast/struct_member.cc",
"src/ast/struct_member.h", "src/ast/struct_member.h",
"src/ast/struct_member_decoration.cc", "src/ast/struct_member_decoration.cc",
@ -120,8 +120,6 @@ source_set("libtint") {
"src/ast/struct_member_offset_decoration.h", "src/ast/struct_member_offset_decoration.h",
"src/ast/switch_statement.cc", "src/ast/switch_statement.cc",
"src/ast/switch_statement.h", "src/ast/switch_statement.h",
"src/ast/type_constructor_expression.h",
"src/ast/type_constructor_expression.cc",
"src/ast/type/alias_type.cc", "src/ast/type/alias_type.cc",
"src/ast/type/alias_type.h", "src/ast/type/alias_type.h",
"src/ast/type/array_type.cc", "src/ast/type/array_type.cc",
@ -146,6 +144,8 @@ source_set("libtint") {
"src/ast/type/vector_type.h", "src/ast/type/vector_type.h",
"src/ast/type/void_type.cc", "src/ast/type/void_type.cc",
"src/ast/type/void_type.h", "src/ast/type/void_type.h",
"src/ast/type_constructor_expression.cc",
"src/ast/type_constructor_expression.h",
"src/ast/uint_literal.cc", "src/ast/uint_literal.cc",
"src/ast/uint_literal.h", "src/ast/uint_literal.h",
"src/ast/unary_derivative.cc", "src/ast/unary_derivative.cc",
@ -164,12 +164,12 @@ source_set("libtint") {
"src/ast/unless_statement.h", "src/ast/unless_statement.h",
"src/ast/variable.cc", "src/ast/variable.cc",
"src/ast/variable.h", "src/ast/variable.h",
"src/ast/variable_decoration.cc",
"src/ast/variable_decoration.h",
"src/ast/variable_decl_statement.cc", "src/ast/variable_decl_statement.cc",
"src/ast/variable_decl_statement.h", "src/ast/variable_decl_statement.h",
"src/context.h", "src/ast/variable_decoration.cc",
"src/ast/variable_decoration.h",
"src/context.cc", "src/context.cc",
"src/context.h",
"src/reader/reader.cc", "src/reader/reader.cc",
"src/reader/reader.h", "src/reader/reader.h",
"src/scope_stack.h", "src/scope_stack.h",
@ -186,34 +186,26 @@ source_set("libtint") {
"src/writer/writer.h", "src/writer/writer.h",
] ]
configs += [ ":tint_common_config" ]
if (build_with_chromium) { if (build_with_chromium) {
configs -= [ "//build/config/compiler:chromium_code" ] configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ] configs += [ "//build/config/compiler:no_chromium_code" ]
} }
# Suppress warnings from the Chromium Clang plugin
configs -= [ "//build/config/clang:find_bad_constructs" ]
} }
executable("tint") { executable("tint") {
sources = [ sources = [ "samples/main.cc" ]
"samples/main.cc", deps = [ ":libtint" ]
]
deps = [ configs += [ ":tint_common_config" ]
":libtint",
]
if (build_with_chromium) { if (build_with_chromium) {
configs -= [ "//build/config/compiler:chromium_code" ] configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ] configs += [ "//build/config/compiler:no_chromium_code" ]
} }
# Suppress warnings from the Chromium Clang plugin
configs -= [ "//build/config/clang:find_bad_constructs" ]
} }
group("tint_all") { group("tint_all") {
deps = [ deps = [ ":tint" ]
":tint",
]
} }

View File

@ -32,8 +32,15 @@ ArrayAccessorExpression::ArrayAccessorExpression(
array_(std::move(array)), array_(std::move(array)),
idx_expr_(std::move(idx_expr)) {} idx_expr_(std::move(idx_expr)) {}
ArrayAccessorExpression::ArrayAccessorExpression(ArrayAccessorExpression&&) =
default;
ArrayAccessorExpression::~ArrayAccessorExpression() = default; ArrayAccessorExpression::~ArrayAccessorExpression() = default;
bool ArrayAccessorExpression::IsArrayAccessor() const {
return true;
}
bool ArrayAccessorExpression::IsValid() const { bool ArrayAccessorExpression::IsValid() const {
if (array_ == nullptr || !array_->IsValid()) if (array_ == nullptr || !array_->IsValid())
return false; return false;

View File

@ -42,7 +42,7 @@ class ArrayAccessorExpression : public Expression {
std::unique_ptr<Expression> array, std::unique_ptr<Expression> array,
std::unique_ptr<Expression> idx_expr); std::unique_ptr<Expression> idx_expr);
/// Move constructor /// Move constructor
ArrayAccessorExpression(ArrayAccessorExpression&&) = default; ArrayAccessorExpression(ArrayAccessorExpression&&);
~ArrayAccessorExpression() override; ~ArrayAccessorExpression() override;
/// Sets the array /// Sets the array
@ -62,7 +62,7 @@ class ArrayAccessorExpression : public Expression {
Expression* idx_expr() const { return idx_expr_.get(); } Expression* idx_expr() const { return idx_expr_.get(); }
/// @returns true if this is an array accessor expression /// @returns true if this is an array accessor expression
bool IsArrayAccessor() const override { return true; } bool IsArrayAccessor() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -27,8 +27,13 @@ AsExpression::AsExpression(const Source& source,
std::unique_ptr<Expression> expr) std::unique_ptr<Expression> expr)
: Expression(source), type_(type), expr_(std::move(expr)) {} : Expression(source), type_(type), expr_(std::move(expr)) {}
AsExpression::AsExpression(AsExpression&&) = default;
AsExpression::~AsExpression() = default; AsExpression::~AsExpression() = default;
bool AsExpression::IsAs() const {
return true;
}
bool AsExpression::IsValid() const { bool AsExpression::IsValid() const {
if (expr_ == nullptr || !expr_->IsValid()) if (expr_ == nullptr || !expr_->IsValid())
return false; return false;

View File

@ -42,7 +42,7 @@ class AsExpression : public Expression {
type::Type* type, type::Type* type,
std::unique_ptr<Expression> expr); std::unique_ptr<Expression> expr);
/// Move constructor /// Move constructor
AsExpression(AsExpression&&) = default; AsExpression(AsExpression&&);
~AsExpression() override; ~AsExpression() override;
/// Sets the type /// Sets the type
@ -58,7 +58,7 @@ class AsExpression : public Expression {
Expression* expr() const { return expr_.get(); } Expression* expr() const { return expr_.get(); }
/// @returns true if this is an as expression /// @returns true if this is an as expression
bool IsAs() const override { return true; } bool IsAs() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -28,8 +28,14 @@ AssignmentStatement::AssignmentStatement(const Source& source,
std::unique_ptr<Expression> rhs) std::unique_ptr<Expression> rhs)
: Statement(source), lhs_(std::move(lhs)), rhs_(std::move(rhs)) {} : Statement(source), lhs_(std::move(lhs)), rhs_(std::move(rhs)) {}
AssignmentStatement::AssignmentStatement(AssignmentStatement&&) = default;
AssignmentStatement::~AssignmentStatement() = default; AssignmentStatement::~AssignmentStatement() = default;
bool AssignmentStatement::IsAssign() const {
return true;
}
bool AssignmentStatement::IsValid() const { bool AssignmentStatement::IsValid() const {
if (lhs_ == nullptr || !lhs_->IsValid()) if (lhs_ == nullptr || !lhs_->IsValid())
return false; return false;

View File

@ -43,7 +43,7 @@ class AssignmentStatement : public Statement {
std::unique_ptr<Expression> lhs, std::unique_ptr<Expression> lhs,
std::unique_ptr<Expression> rhs); std::unique_ptr<Expression> rhs);
/// Move constructor /// Move constructor
AssignmentStatement(AssignmentStatement&&) = default; AssignmentStatement(AssignmentStatement&&);
~AssignmentStatement() override; ~AssignmentStatement() override;
/// Sets the left side of the statement /// Sets the left side of the statement
@ -59,7 +59,7 @@ class AssignmentStatement : public Statement {
Expression* rhs() const { return rhs_.get(); } Expression* rhs() const { return rhs_.get(); }
/// @returns true if this is an assignment statement /// @returns true if this is an assignment statement
bool IsAssign() const override { return true; } bool IsAssign() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -30,8 +30,14 @@ BinaryExpression::BinaryExpression(const Source& source,
std::unique_ptr<Expression> rhs) std::unique_ptr<Expression> rhs)
: Expression(source), op_(op), lhs_(std::move(lhs)), rhs_(std::move(rhs)) {} : Expression(source), op_(op), lhs_(std::move(lhs)), rhs_(std::move(rhs)) {}
BinaryExpression::BinaryExpression(BinaryExpression&&) = default;
BinaryExpression::~BinaryExpression() = default; BinaryExpression::~BinaryExpression() = default;
bool BinaryExpression::IsBinary() const {
return true;
}
bool BinaryExpression::IsValid() const { bool BinaryExpression::IsValid() const {
if (lhs_ == nullptr || !lhs_->IsValid()) { if (lhs_ == nullptr || !lhs_->IsValid()) {
return false; return false;

View File

@ -70,7 +70,7 @@ class BinaryExpression : public Expression {
std::unique_ptr<Expression> lhs, std::unique_ptr<Expression> lhs,
std::unique_ptr<Expression> rhs); std::unique_ptr<Expression> rhs);
/// Move constructor /// Move constructor
BinaryExpression(BinaryExpression&&) = default; BinaryExpression(BinaryExpression&&);
~BinaryExpression() override; ~BinaryExpression() override;
/// Sets the binary op type /// Sets the binary op type
@ -131,7 +131,7 @@ class BinaryExpression : public Expression {
Expression* rhs() const { return rhs_.get(); } Expression* rhs() const { return rhs_.get(); }
/// @returns true if this is a op expression /// @returns true if this is a op expression
bool IsBinary() const override { return true; } bool IsBinary() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -21,6 +21,10 @@ BindingDecoration::BindingDecoration(uint32_t val) : value_(val) {}
BindingDecoration::~BindingDecoration() = default; BindingDecoration::~BindingDecoration() = default;
bool BindingDecoration::IsBinding() const {
return true;
}
void BindingDecoration::to_str(std::ostream& out) const { void BindingDecoration::to_str(std::ostream& out) const {
out << "BindingDecoration{" << value_ << "}" << std::endl; out << "BindingDecoration{" << value_ << "}" << std::endl;
} }

View File

@ -31,7 +31,7 @@ class BindingDecoration : public VariableDecoration {
~BindingDecoration() override; ~BindingDecoration() override;
/// @returns true if this is a binding decoration /// @returns true if this is a binding decoration
bool IsBinding() const override { return true; } bool IsBinding() const override;
/// @returns the binding value /// @returns the binding value
uint32_t value() const { return value_; } uint32_t value() const { return value_; }

View File

@ -22,6 +22,10 @@ BoolLiteral::BoolLiteral(ast::type::Type* type, bool value)
BoolLiteral::~BoolLiteral() = default; BoolLiteral::~BoolLiteral() = default;
bool BoolLiteral::IsBool() const {
return true;
}
std::string BoolLiteral::to_str() const { std::string BoolLiteral::to_str() const {
return value_ ? "true" : "false"; return value_ ? "true" : "false";
} }

View File

@ -32,7 +32,7 @@ class BoolLiteral : public Literal {
~BoolLiteral() override; ~BoolLiteral() override;
/// @returns true if this is a bool literal /// @returns true if this is a bool literal
bool IsBool() const override { return true; } bool IsBool() const override;
/// @returns true if the bool literal is true /// @returns true if the bool literal is true
bool IsTrue() const { return value_; } bool IsTrue() const { return value_; }

View File

@ -34,8 +34,14 @@ BreakStatement::BreakStatement(const Source& source,
condition_(condition), condition_(condition),
conditional_(std::move(conditional)) {} conditional_(std::move(conditional)) {}
BreakStatement::BreakStatement(BreakStatement&&) = default;
BreakStatement::~BreakStatement() = default; BreakStatement::~BreakStatement() = default;
bool BreakStatement::IsBreak() const {
return true;
}
bool BreakStatement::IsValid() const { bool BreakStatement::IsValid() const {
if (condition_ == StatementCondition::kNone) if (condition_ == StatementCondition::kNone)
return conditional_ == nullptr; return conditional_ == nullptr;

View File

@ -46,7 +46,7 @@ class BreakStatement : public Statement {
StatementCondition condition, StatementCondition condition,
std::unique_ptr<Expression> conditional); std::unique_ptr<Expression> conditional);
/// Move constructor /// Move constructor
BreakStatement(BreakStatement&&) = default; BreakStatement(BreakStatement&&);
~BreakStatement() override; ~BreakStatement() override;
/// Sets the condition type /// Sets the condition type
@ -64,7 +64,7 @@ class BreakStatement : public Statement {
Expression* conditional() const { return conditional_.get(); } Expression* conditional() const { return conditional_.get(); }
/// @returns true if this is an break statement /// @returns true if this is an break statement
bool IsBreak() const override { return true; } bool IsBreak() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -21,6 +21,10 @@ BuiltinDecoration::BuiltinDecoration(Builtin builtin) : builtin_(builtin) {}
BuiltinDecoration::~BuiltinDecoration() = default; BuiltinDecoration::~BuiltinDecoration() = default;
bool BuiltinDecoration::IsBuiltin() const {
return true;
}
void BuiltinDecoration::to_str(std::ostream& out) const { void BuiltinDecoration::to_str(std::ostream& out) const {
out << "BuiltinDecoration{" << builtin_ << "}" << std::endl; out << "BuiltinDecoration{" << builtin_ << "}" << std::endl;
} }

View File

@ -30,7 +30,7 @@ class BuiltinDecoration : public VariableDecoration {
~BuiltinDecoration() override; ~BuiltinDecoration() override;
/// @returns true if this is a builtin decoration /// @returns true if this is a builtin decoration
bool IsBuiltin() const override { return true; } bool IsBuiltin() const override;
/// @returns the builtin value /// @returns the builtin value
Builtin value() const { return builtin_; } Builtin value() const { return builtin_; }

View File

@ -28,8 +28,14 @@ CallExpression::CallExpression(const Source& source,
ExpressionList params) ExpressionList params)
: Expression(source), func_(std::move(func)), params_(std::move(params)) {} : Expression(source), func_(std::move(func)), params_(std::move(params)) {}
CallExpression::CallExpression(CallExpression&&) = default;
CallExpression::~CallExpression() = default; CallExpression::~CallExpression() = default;
bool CallExpression::IsCall() const {
return true;
}
bool CallExpression::IsValid() const { bool CallExpression::IsValid() const {
if (func_ == nullptr || !func_->IsValid()) if (func_ == nullptr || !func_->IsValid())
return false; return false;

View File

@ -41,7 +41,7 @@ class CallExpression : public Expression {
std::unique_ptr<Expression> func, std::unique_ptr<Expression> func,
ExpressionList params); ExpressionList params);
/// Move constructor /// Move constructor
CallExpression(CallExpression&&) = default; CallExpression(CallExpression&&);
~CallExpression() override; ~CallExpression() override;
/// Sets the func /// Sets the func
@ -57,7 +57,7 @@ class CallExpression : public Expression {
const ExpressionList& params() const { return params_; } const ExpressionList& params() const { return params_; }
/// @returns true if this is a call expression /// @returns true if this is a call expression
bool IsCall() const override { return true; } bool IsCall() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -30,8 +30,14 @@ CaseStatement::CaseStatement(const Source& source,
condition_(std::move(condition)), condition_(std::move(condition)),
body_(std::move(body)) {} body_(std::move(body)) {}
CaseStatement::CaseStatement(CaseStatement&&) = default;
CaseStatement::~CaseStatement() = default; CaseStatement::~CaseStatement() = default;
bool CaseStatement::IsCase() const {
return true;
}
bool CaseStatement::IsValid() const { bool CaseStatement::IsValid() const {
for (const auto& stmt : body_) { for (const auto& stmt : body_) {
if (stmt == nullptr || !stmt->IsValid()) if (stmt == nullptr || !stmt->IsValid())

View File

@ -44,7 +44,7 @@ class CaseStatement : public Statement {
std::unique_ptr<Literal> condition, std::unique_ptr<Literal> condition,
StatementList body); StatementList body);
/// Move constructor /// Move constructor
CaseStatement(CaseStatement&&) = default; CaseStatement(CaseStatement&&);
~CaseStatement() override; ~CaseStatement() override;
/// Sets the condition for the case statement /// Sets the condition for the case statement
@ -64,7 +64,7 @@ class CaseStatement : public Statement {
const StatementList& body() const { return body_; } const StatementList& body() const { return body_; }
/// @returns true if this is a case statement /// @returns true if this is a case statement
bool IsCase() const override { return true; } bool IsCase() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -28,8 +28,14 @@ CastExpression::CastExpression(const Source& source,
std::unique_ptr<Expression> expr) std::unique_ptr<Expression> expr)
: Expression(source), type_(type), expr_(std::move(expr)) {} : Expression(source), type_(type), expr_(std::move(expr)) {}
CastExpression::CastExpression(CastExpression&&) = default;
CastExpression::~CastExpression() = default; CastExpression::~CastExpression() = default;
bool CastExpression::IsCast() const {
return true;
}
bool CastExpression::IsValid() const { bool CastExpression::IsValid() const {
if (expr_ == nullptr || !expr_->IsValid()) if (expr_ == nullptr || !expr_->IsValid())
return false; return false;

View File

@ -42,7 +42,7 @@ class CastExpression : public Expression {
type::Type* type, type::Type* type,
std::unique_ptr<Expression> expr); std::unique_ptr<Expression> expr);
/// Move constructor /// Move constructor
CastExpression(CastExpression&&) = default; CastExpression(CastExpression&&);
~CastExpression() override; ~CastExpression() override;
/// Sets the type /// Sets the type
@ -58,7 +58,7 @@ class CastExpression : public Expression {
Expression* expr() const { return expr_.get(); } Expression* expr() const { return expr_.get(); }
/// @returns true if this is a cast expression /// @returns true if this is a cast expression
bool IsCast() const override { return true; } bool IsCast() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -29,6 +29,18 @@ ConstructorExpression::~ConstructorExpression() = default;
ConstructorExpression::ConstructorExpression(const Source& source) ConstructorExpression::ConstructorExpression(const Source& source)
: Expression(source) {} : Expression(source) {}
bool ConstructorExpression::IsConstructor() const {
return true;
}
bool ConstructorExpression::IsScalarConstructor() const {
return false;
}
bool ConstructorExpression::IsTypeConstructor() const {
return false;
}
ScalarConstructorExpression* ConstructorExpression::AsScalarConstructor() { ScalarConstructorExpression* ConstructorExpression::AsScalarConstructor() {
assert(IsScalarConstructor()); assert(IsScalarConstructor());
return static_cast<ScalarConstructorExpression*>(this); return static_cast<ScalarConstructorExpression*>(this);

View File

@ -29,12 +29,12 @@ class ConstructorExpression : public Expression {
~ConstructorExpression() override; ~ConstructorExpression() override;
/// @returns true if this is an constructor expression /// @returns true if this is an constructor expression
bool IsConstructor() const override { return true; } bool IsConstructor() const override;
/// @returns true if this is a scalar constructor /// @returns true if this is a scalar constructor
virtual bool IsScalarConstructor() const { return false; } virtual bool IsScalarConstructor() const;
/// @returns true if this is a type constructor /// @returns true if this is a type constructor
virtual bool IsTypeConstructor() const { return false; } virtual bool IsTypeConstructor() const;
/// @returns this as a scalar constructor expression /// @returns this as a scalar constructor expression
ScalarConstructorExpression* AsScalarConstructor(); ScalarConstructorExpression* AsScalarConstructor();

View File

@ -35,8 +35,14 @@ ContinueStatement::ContinueStatement(const Source& source,
condition_(condition), condition_(condition),
conditional_(std::move(conditional)) {} conditional_(std::move(conditional)) {}
ContinueStatement::ContinueStatement(ContinueStatement&&) = default;
ContinueStatement::~ContinueStatement() = default; ContinueStatement::~ContinueStatement() = default;
bool ContinueStatement::IsContinue() const {
return true;
}
bool ContinueStatement::IsValid() const { bool ContinueStatement::IsValid() const {
if (condition_ == StatementCondition::kNone) if (condition_ == StatementCondition::kNone)
return conditional_ == nullptr; return conditional_ == nullptr;

View File

@ -46,7 +46,7 @@ class ContinueStatement : public Statement {
StatementCondition condition, StatementCondition condition,
std::unique_ptr<Expression> conditional); std::unique_ptr<Expression> conditional);
/// Move constructor /// Move constructor
ContinueStatement(ContinueStatement&&) = default; ContinueStatement(ContinueStatement&&);
~ContinueStatement() override; ~ContinueStatement() override;
/// Sets the condition type /// Sets the condition type
@ -64,7 +64,7 @@ class ContinueStatement : public Statement {
Expression* conditional() const { return conditional_.get(); } Expression* conditional() const { return conditional_.get(); }
/// @returns true if this is an continue statement /// @returns true if this is an continue statement
bool IsContinue() const override { return true; } bool IsContinue() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -26,6 +26,10 @@ DecoratedVariable::DecoratedVariable(DecoratedVariable&&) = default;
DecoratedVariable::~DecoratedVariable() = default; DecoratedVariable::~DecoratedVariable() = default;
bool DecoratedVariable::IsDecorated() const {
return true;
}
bool DecoratedVariable::IsValid() const { bool DecoratedVariable::IsValid() const {
return Variable::IsValid(); return Variable::IsValid();
} }

View File

@ -46,7 +46,7 @@ class DecoratedVariable : public Variable {
const VariableDecorationList& decorations() const { return decorations_; } const VariableDecorationList& decorations() const { return decorations_; }
/// @returns true if this is a decorated variable /// @returns true if this is a decorated variable
bool IsDecorated() const override { return true; } bool IsDecorated() const override;
/// @returns true if the name and path are both present /// @returns true if the name and path are both present
bool IsValid() const override; bool IsValid() const override;

View File

@ -36,8 +36,14 @@ ElseStatement::ElseStatement(const Source& source,
condition_(std::move(condition)), condition_(std::move(condition)),
body_(std::move(body)) {} body_(std::move(body)) {}
ElseStatement::ElseStatement(ElseStatement&&) = default;
ElseStatement::~ElseStatement() = default; ElseStatement::~ElseStatement() = default;
bool ElseStatement::IsElse() const {
return true;
}
bool ElseStatement::IsValid() const { bool ElseStatement::IsValid() const {
for (const auto& stmt : body_) { for (const auto& stmt : body_) {
if (stmt == nullptr || !stmt->IsValid()) if (stmt == nullptr || !stmt->IsValid())

View File

@ -49,7 +49,7 @@ class ElseStatement : public Statement {
std::unique_ptr<Expression> condition, std::unique_ptr<Expression> condition,
StatementList body); StatementList body);
/// Move constructor /// Move constructor
ElseStatement(ElseStatement&&) = default; ElseStatement(ElseStatement&&);
~ElseStatement() override; ~ElseStatement() override;
/// Sets the condition for the else statement /// Sets the condition for the else statement
@ -69,7 +69,7 @@ class ElseStatement : public Statement {
const StatementList& body() const { return body_; } const StatementList& body() const { return body_; }
/// @returns true if this is a else statement /// @returns true if this is a else statement
bool IsElse() const override { return true; } bool IsElse() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -37,6 +37,50 @@ Expression::Expression(const Source& source) : Node(source) {}
Expression::~Expression() = default; Expression::~Expression() = default;
bool Expression::IsArrayAccessor() const {
return false;
}
bool Expression::IsAs() const {
return false;
}
bool Expression::IsCall() const {
return false;
}
bool Expression::IsCast() const {
return false;
}
bool Expression::IsIdentifier() const {
return false;
}
bool Expression::IsConstructor() const {
return false;
}
bool Expression::IsMemberAccessor() const {
return false;
}
bool Expression::IsBinary() const {
return false;
}
bool Expression::IsUnaryDerivative() const {
return false;
}
bool Expression::IsUnaryMethod() const {
return false;
}
bool Expression::IsUnaryOp() const {
return false;
}
ArrayAccessorExpression* Expression::AsArrayAccessor() { ArrayAccessorExpression* Expression::AsArrayAccessor() {
assert(IsArrayAccessor()); assert(IsArrayAccessor());
return static_cast<ArrayAccessorExpression*>(this); return static_cast<ArrayAccessorExpression*>(this);

View File

@ -48,27 +48,27 @@ class Expression : public Node {
type::Type* result_type() const { return result_type_; } type::Type* result_type() const { return result_type_; }
/// @returns true if this is an array accessor expression /// @returns true if this is an array accessor expression
virtual bool IsArrayAccessor() const { return false; } virtual bool IsArrayAccessor() const;
/// @returns true if this is an as expression /// @returns true if this is an as expression
virtual bool IsAs() const { return false; } virtual bool IsAs() const;
/// @returns true if this is a call expression /// @returns true if this is a call expression
virtual bool IsCall() const { return false; } virtual bool IsCall() const;
/// @returns true if this is a cast expression /// @returns true if this is a cast expression
virtual bool IsCast() const { return false; } virtual bool IsCast() const;
/// @returns true if this is an identifier expression /// @returns true if this is an identifier expression
virtual bool IsIdentifier() const { return false; } virtual bool IsIdentifier() const;
/// @returns true if this is an constructor expression /// @returns true if this is an constructor expression
virtual bool IsConstructor() const { return false; } virtual bool IsConstructor() const;
/// @returns true if this is a member accessor expression /// @returns true if this is a member accessor expression
virtual bool IsMemberAccessor() const { return false; } virtual bool IsMemberAccessor() const;
/// @returns true if this is a binary expression /// @returns true if this is a binary expression
virtual bool IsBinary() const { return false; } virtual bool IsBinary() const;
/// @returns true if this is a unary derivative expression /// @returns true if this is a unary derivative expression
virtual bool IsUnaryDerivative() const { return false; } virtual bool IsUnaryDerivative() const;
/// @returns true if this is a unary method expression /// @returns true if this is a unary method expression
virtual bool IsUnaryMethod() const { return false; } virtual bool IsUnaryMethod() const;
/// @returns true if this is a unary op expression /// @returns true if this is a unary op expression
virtual bool IsUnaryOp() const { return false; } virtual bool IsUnaryOp() const;
/// @returns the expression as an array accessor /// @returns the expression as an array accessor
ArrayAccessorExpression* AsArrayAccessor(); ArrayAccessorExpression* AsArrayAccessor();

View File

@ -24,6 +24,10 @@ FallthroughStatement::FallthroughStatement(const Source& source)
FallthroughStatement::~FallthroughStatement() = default; FallthroughStatement::~FallthroughStatement() = default;
bool FallthroughStatement::IsFallthrough() const {
return true;
}
bool FallthroughStatement::IsValid() const { bool FallthroughStatement::IsValid() const {
return true; return true;
} }

View File

@ -35,7 +35,7 @@ class FallthroughStatement : public Statement {
~FallthroughStatement() override; ~FallthroughStatement() override;
/// @returns true if this is an fallthrough statement /// @returns true if this is an fallthrough statement
bool IsFallthrough() const override { return true; } bool IsFallthrough() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -25,6 +25,10 @@ FloatLiteral::FloatLiteral(ast::type::Type* type, float value)
FloatLiteral::~FloatLiteral() = default; FloatLiteral::~FloatLiteral() = default;
bool FloatLiteral::IsFloat() const {
return true;
}
std::string FloatLiteral::to_str() const { std::string FloatLiteral::to_str() const {
return std::to_string(value_); return std::to_string(value_);
} }

View File

@ -32,7 +32,7 @@ class FloatLiteral : public Literal {
~FloatLiteral() override; ~FloatLiteral() override;
/// @returns true if this is a float literal /// @returns true if this is a float literal
bool IsFloat() const override { return true; } bool IsFloat() const override;
/// @returns the float literal value /// @returns the float literal value
float value() const { return value_; } float value() const { return value_; }

View File

@ -19,6 +19,8 @@
namespace tint { namespace tint {
namespace ast { namespace ast {
Function::Function() = default;
Function::Function(const std::string& name, Function::Function(const std::string& name,
VariableList params, VariableList params,
type::Type* return_type) type::Type* return_type)
@ -36,6 +38,8 @@ Function::Function(const Source& source,
params_(std::move(params)), params_(std::move(params)),
return_type_(return_type) {} return_type_(return_type) {}
Function::Function(Function&&) = default;
Function::~Function() = default; Function::~Function() = default;
bool Function::IsValid() const { bool Function::IsValid() const {

View File

@ -34,7 +34,7 @@ namespace ast {
class Function : public Node { class Function : public Node {
public: public:
/// Create a new empty function statement /// Create a new empty function statement
Function() = default; Function();
/// Create a function /// Create a function
/// @param name the function name /// @param name the function name
/// @param params the function parameters /// @param params the function parameters
@ -52,7 +52,7 @@ class Function : public Node {
VariableList params, VariableList params,
type::Type* return_type); type::Type* return_type);
/// Move constructor /// Move constructor
Function(Function&&) = default; Function(Function&&);
~Function() override; ~Function() override;

View File

@ -31,8 +31,14 @@ IdentifierExpression::IdentifierExpression(const Source& source,
std::vector<std::string> name) std::vector<std::string> name)
: Expression(source), name_(std::move(name)) {} : Expression(source), name_(std::move(name)) {}
IdentifierExpression::IdentifierExpression(IdentifierExpression&&) = default;
IdentifierExpression::~IdentifierExpression() = default; IdentifierExpression::~IdentifierExpression() = default;
bool IdentifierExpression::IsIdentifier() const {
return true;
}
bool IdentifierExpression::IsValid() const { bool IdentifierExpression::IsValid() const {
if (name_.size() == 0) if (name_.size() == 0)
return false; return false;

View File

@ -42,7 +42,7 @@ class IdentifierExpression : public Expression {
/// @param name the name /// @param name the name
IdentifierExpression(const Source& source, std::vector<std::string> name); IdentifierExpression(const Source& source, std::vector<std::string> name);
/// Move constructor /// Move constructor
IdentifierExpression(IdentifierExpression&&) = default; IdentifierExpression(IdentifierExpression&&);
~IdentifierExpression() override; ~IdentifierExpression() override;
/// Sets the name /// Sets the name
@ -52,7 +52,7 @@ class IdentifierExpression : public Expression {
std::vector<std::string> name() const { return name_; } std::vector<std::string> name() const { return name_; }
/// @returns true if this is an identifier expression /// @returns true if this is an identifier expression
bool IsIdentifier() const override { return true; } bool IsIdentifier() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -32,8 +32,14 @@ IfStatement::IfStatement(const Source& source,
condition_(std::move(condition)), condition_(std::move(condition)),
body_(std::move(body)) {} body_(std::move(body)) {}
IfStatement::IfStatement(IfStatement&&) = default;
IfStatement::~IfStatement() = default; IfStatement::~IfStatement() = default;
bool IfStatement::IsIf() const {
return true;
}
bool IfStatement::IsValid() const { bool IfStatement::IsValid() const {
if (condition_ == nullptr || !condition_->IsValid()) if (condition_ == nullptr || !condition_->IsValid())
return false; return false;

View File

@ -1,4 +1,4 @@
// Copyright 2020 The Tint Authors. // Copyright 2020 The Tint Authors.
// //
// Licensed under the Apache License, Version 2.0 (the "License"); // Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License. // you may not use this file except in compliance with the License.
@ -42,7 +42,7 @@ class IfStatement : public Statement {
std::unique_ptr<Expression> condition, std::unique_ptr<Expression> condition,
StatementList body); StatementList body);
/// Move constructor /// Move constructor
IfStatement(IfStatement&&) = default; IfStatement(IfStatement&&);
~IfStatement() override; ~IfStatement() override;
/// Sets the condition for the if statement /// Sets the condition for the if statement
@ -74,7 +74,7 @@ class IfStatement : public Statement {
const StatementList& premerge() const { return premerge_; } 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 { return true; } bool IsIf() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -22,6 +22,10 @@ IntLiteral::IntLiteral(ast::type::Type* type, int32_t value)
IntLiteral::~IntLiteral() = default; IntLiteral::~IntLiteral() = default;
bool IntLiteral::IsInt() const {
return true;
}
std::string IntLiteral::to_str() const { std::string IntLiteral::to_str() const {
return std::to_string(value_); return std::to_string(value_);
} }

View File

@ -32,7 +32,7 @@ class IntLiteral : public Literal {
~IntLiteral() override; ~IntLiteral() override;
/// @returns true if this is a int literal /// @returns true if this is a int literal
bool IsInt() const override { return true; } bool IsInt() const override;
/// @returns the int literal value /// @returns the int literal value
int32_t value() const { return value_; } int32_t value() const { return value_; }

View File

@ -23,6 +23,10 @@ KillStatement::KillStatement(const Source& source) : Statement(source) {}
KillStatement::~KillStatement() = default; KillStatement::~KillStatement() = default;
bool KillStatement::IsKill() const {
return true;
}
bool KillStatement::IsValid() const { bool KillStatement::IsValid() const {
return true; return true;
} }

View File

@ -33,7 +33,7 @@ class KillStatement : public Statement {
~KillStatement() override; ~KillStatement() override;
/// @returns true if this is a kill statement /// @returns true if this is a kill statement
bool IsKill() const override { return true; } bool IsKill() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -28,6 +28,22 @@ Literal::Literal(ast::type::Type* type) : type_(type) {}
Literal::~Literal() = default; Literal::~Literal() = default;
bool Literal::IsBool() const {
return false;
}
bool Literal::IsFloat() const {
return false;
}
bool Literal::IsInt() const {
return false;
}
bool Literal::IsUint() const {
return false;
}
BoolLiteral* Literal::AsBool() { BoolLiteral* Literal::AsBool() {
assert(IsBool()); assert(IsBool());
return static_cast<BoolLiteral*>(this); return static_cast<BoolLiteral*>(this);

View File

@ -33,13 +33,13 @@ class Literal {
virtual ~Literal(); virtual ~Literal();
/// @returns true if this is a bool literal /// @returns true if this is a bool literal
virtual bool IsBool() const { return false; } virtual bool IsBool() const;
/// @returns true if this is a float literal /// @returns true if this is a float literal
virtual bool IsFloat() const { return false; } virtual bool IsFloat() const;
/// @returns true if this is a signed int literal /// @returns true if this is a signed int literal
virtual bool IsInt() const { return false; } virtual bool IsInt() const;
/// @returns true if this is a unsigned int literal /// @returns true if this is a unsigned int literal
virtual bool IsUint() const { return false; } virtual bool IsUint() const;
/// @returns the literal as a boolean literal /// @returns the literal as a boolean literal
BoolLiteral* AsBool(); BoolLiteral* AsBool();

View File

@ -21,6 +21,10 @@ LocationDecoration::LocationDecoration(uint32_t val) : value_(val) {}
LocationDecoration::~LocationDecoration() = default; LocationDecoration::~LocationDecoration() = default;
bool LocationDecoration::IsLocation() const {
return true;
}
void LocationDecoration::to_str(std::ostream& out) const { void LocationDecoration::to_str(std::ostream& out) const {
out << "LocationDecoration{" << value_ << "}" << std::endl; out << "LocationDecoration{" << value_ << "}" << std::endl;
} }

View File

@ -31,7 +31,7 @@ class LocationDecoration : public VariableDecoration {
~LocationDecoration() override; ~LocationDecoration() override;
/// @returns true if this is a location decoration /// @returns true if this is a location decoration
bool IsLocation() const override { return true; } bool IsLocation() const override;
/// @returns the location value /// @returns the location value
uint32_t value() const { return value_; } uint32_t value() const { return value_; }

View File

@ -29,8 +29,14 @@ LoopStatement::LoopStatement(const Source& source,
body_(std::move(body)), body_(std::move(body)),
continuing_(std::move(continuing)) {} continuing_(std::move(continuing)) {}
LoopStatement::LoopStatement(LoopStatement&&) = default;
LoopStatement::~LoopStatement() = default; LoopStatement::~LoopStatement() = default;
bool LoopStatement::IsLoop() const {
return true;
}
bool LoopStatement::IsValid() const { bool LoopStatement::IsValid() const {
for (const auto& stmt : body_) { for (const auto& stmt : body_) {
if (stmt == nullptr || !stmt->IsValid()) if (stmt == nullptr || !stmt->IsValid())

View File

@ -39,7 +39,7 @@ class LoopStatement : public Statement {
StatementList body, StatementList body,
StatementList continuing); StatementList continuing);
/// Move constructor /// Move constructor
LoopStatement(LoopStatement&&) = default; LoopStatement(LoopStatement&&);
~LoopStatement() override; ~LoopStatement() override;
/// Sets the body statements /// Sets the body statements
@ -59,7 +59,7 @@ class LoopStatement : public Statement {
bool has_continuing() const { return !continuing_.empty(); } bool has_continuing() const { return !continuing_.empty(); }
/// @returns true if this is a loop statement /// @returns true if this is a loop statement
bool IsLoop() const override { return true; } bool IsLoop() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -32,8 +32,15 @@ MemberAccessorExpression::MemberAccessorExpression(
struct_(std::move(structure)), struct_(std::move(structure)),
member_(std::move(member)) {} member_(std::move(member)) {}
MemberAccessorExpression::MemberAccessorExpression(MemberAccessorExpression&&) =
default;
MemberAccessorExpression::~MemberAccessorExpression() = default; MemberAccessorExpression::~MemberAccessorExpression() = default;
bool MemberAccessorExpression::IsMemberAccessor() const {
return true;
}
bool MemberAccessorExpression::IsValid() const { bool MemberAccessorExpression::IsValid() const {
if (struct_ == nullptr || !struct_->IsValid()) { if (struct_ == nullptr || !struct_->IsValid()) {
return false; return false;

View File

@ -44,7 +44,7 @@ class MemberAccessorExpression : public Expression {
std::unique_ptr<Expression> structure, std::unique_ptr<Expression> structure,
std::unique_ptr<IdentifierExpression> member); std::unique_ptr<IdentifierExpression> member);
/// Move constructor /// Move constructor
MemberAccessorExpression(MemberAccessorExpression&&) = default; MemberAccessorExpression(MemberAccessorExpression&&);
~MemberAccessorExpression() override; ~MemberAccessorExpression() override;
/// Sets the structure /// Sets the structure
@ -64,7 +64,7 @@ class MemberAccessorExpression : public Expression {
IdentifierExpression* member() const { return member_.get(); } IdentifierExpression* member() const { return member_.get(); }
/// @returns true if this is a member accessor expression /// @returns true if this is a member accessor expression
bool IsMemberAccessor() const override { return true; } bool IsMemberAccessor() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -19,6 +19,12 @@
namespace tint { namespace tint {
namespace ast { namespace ast {
Module::Module() = default;
Module::Module(Module&&) = default;
Module::~Module() = default;
const Import* Module::FindImportByName(const std::string& name) { const Import* Module::FindImportByName(const std::string& name) {
for (const auto& import : imports_) { for (const auto& import : imports_) {
if (import->name() == name) if (import->name() == name)
@ -43,7 +49,7 @@ bool Module::IsValid() const {
return false; return false;
} }
} }
for (const auto& alias : alias_types_) { for (auto* const alias : alias_types_) {
if (alias == nullptr) { if (alias == nullptr) {
return false; return false;
} }
@ -70,7 +76,7 @@ std::string Module::to_str() const {
for (const auto& ep : entry_points_) { for (const auto& ep : entry_points_) {
ep->to_str(out, indent); ep->to_str(out, indent);
} }
for (const auto& alias : alias_types_) { for (auto* const alias : alias_types_) {
out << alias->name() << " -> " << alias->type()->type_name() << std::endl; out << alias->name() << " -> " << alias->type()->type_name() << std::endl;
} }
for (const auto& func : functions_) { for (const auto& func : functions_) {

View File

@ -32,10 +32,10 @@ namespace ast {
/// Represents all the source in a given program. /// Represents all the source in a given program.
class Module { class Module {
public: public:
Module() = default; Module();
/// Move constructor /// Move constructor
Module(Module&&) = default; Module(Module&&);
~Module() = default; ~Module();
/// Add the given import to the module /// Add the given import to the module
/// @param import The import to add. /// @param import The import to add.

View File

@ -23,6 +23,10 @@ NopStatement::NopStatement(const Source& source) : Statement(source) {}
NopStatement::~NopStatement() = default; NopStatement::~NopStatement() = default;
bool NopStatement::IsNop() const {
return true;
}
bool NopStatement::IsValid() const { bool NopStatement::IsValid() const {
return true; return true;
} }

View File

@ -33,7 +33,7 @@ class NopStatement : public Statement {
~NopStatement() override; ~NopStatement() override;
/// @returns true if this is a nop statement /// @returns true if this is a nop statement
bool IsNop() const override { return true; } bool IsNop() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -30,8 +30,13 @@ RegardlessStatement::RegardlessStatement(const Source& source,
condition_(std::move(condition)), condition_(std::move(condition)),
body_(std::move(body)) {} body_(std::move(body)) {}
RegardlessStatement::RegardlessStatement(RegardlessStatement&&) = default;
RegardlessStatement::~RegardlessStatement() = default; RegardlessStatement::~RegardlessStatement() = default;
bool RegardlessStatement::IsRegardless() const {
return true;
}
bool RegardlessStatement::IsValid() const { bool RegardlessStatement::IsValid() const {
if (condition_ == nullptr || !condition_->IsValid()) { if (condition_ == nullptr || !condition_->IsValid()) {
return false; return false;

View File

@ -42,7 +42,7 @@ class RegardlessStatement : public Statement {
std::unique_ptr<Expression> condition, std::unique_ptr<Expression> condition,
StatementList body); StatementList body);
/// Move constructor /// Move constructor
RegardlessStatement(RegardlessStatement&&) = default; RegardlessStatement(RegardlessStatement&&);
~RegardlessStatement() override; ~RegardlessStatement() override;
/// Sets the condition expression /// Sets the condition expression
@ -60,7 +60,7 @@ class RegardlessStatement : public Statement {
const StatementList& body() const { return body_; } const StatementList& body() const { return body_; }
/// @returns true if this is an regardless statement /// @returns true if this is an regardless statement
bool IsRegardless() const override { return true; } bool IsRegardless() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -28,8 +28,14 @@ ReturnStatement::ReturnStatement(const Source& source,
std::unique_ptr<Expression> value) std::unique_ptr<Expression> value)
: Statement(source), value_(std::move(value)) {} : Statement(source), value_(std::move(value)) {}
ReturnStatement::ReturnStatement(ReturnStatement&&) = default;
ReturnStatement::~ReturnStatement() = default; ReturnStatement::~ReturnStatement() = default;
bool ReturnStatement::IsReturn() const {
return true;
}
bool ReturnStatement::IsValid() const { bool ReturnStatement::IsValid() const {
if (value_ != nullptr) { if (value_ != nullptr) {
return value_->IsValid(); return value_->IsValid();

View File

@ -40,7 +40,7 @@ class ReturnStatement : public Statement {
/// @param value the return value /// @param value the return value
ReturnStatement(const Source& source, std::unique_ptr<Expression> value); ReturnStatement(const Source& source, std::unique_ptr<Expression> value);
/// Move constructor /// Move constructor
ReturnStatement(ReturnStatement&&) = default; ReturnStatement(ReturnStatement&&);
~ReturnStatement() override; ~ReturnStatement() override;
/// Sets the value /// Sets the value
@ -54,7 +54,7 @@ class ReturnStatement : public Statement {
bool has_value() const { return value_ != nullptr; } bool has_value() const { return value_ != nullptr; }
/// @returns true if this is a return statement /// @returns true if this is a return statement
bool IsReturn() const override { return true; } bool IsReturn() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -29,8 +29,15 @@ ScalarConstructorExpression::ScalarConstructorExpression(
std::unique_ptr<Literal> litearl) std::unique_ptr<Literal> litearl)
: ConstructorExpression(source), literal_(std::move(litearl)) {} : ConstructorExpression(source), literal_(std::move(litearl)) {}
ScalarConstructorExpression::ScalarConstructorExpression(
ScalarConstructorExpression&&) = default;
ScalarConstructorExpression::~ScalarConstructorExpression() = default; ScalarConstructorExpression::~ScalarConstructorExpression() = default;
bool ScalarConstructorExpression::IsScalarConstructor() const {
return true;
}
bool ScalarConstructorExpression::IsValid() const { bool ScalarConstructorExpression::IsValid() const {
return literal_ != nullptr; return literal_ != nullptr;
} }

View File

@ -38,11 +38,11 @@ class ScalarConstructorExpression : public ConstructorExpression {
ScalarConstructorExpression(const Source& source, ScalarConstructorExpression(const Source& source,
std::unique_ptr<Literal> literal); std::unique_ptr<Literal> literal);
/// Move constructor /// Move constructor
ScalarConstructorExpression(ScalarConstructorExpression&&) = default; ScalarConstructorExpression(ScalarConstructorExpression&&);
~ScalarConstructorExpression() override; ~ScalarConstructorExpression() override;
/// @returns true if this is a scalar constructor /// @returns true if this is a scalar constructor
bool IsScalarConstructor() const override { return true; } bool IsScalarConstructor() const override;
/// Set the literal value /// Set the literal value
/// @param literal the literal /// @param literal the literal

View File

@ -21,6 +21,10 @@ SetDecoration::SetDecoration(uint32_t val) : value_(val) {}
SetDecoration::~SetDecoration() = default; SetDecoration::~SetDecoration() = default;
bool SetDecoration::IsSet() const {
return true;
}
void SetDecoration::to_str(std::ostream& out) const { void SetDecoration::to_str(std::ostream& out) const {
out << "SetDecoration{" << value_ << "}" << std::endl; out << "SetDecoration{" << value_ << "}" << std::endl;
} }

View File

@ -31,7 +31,7 @@ class SetDecoration : public VariableDecoration {
~SetDecoration() override; ~SetDecoration() override;
/// @returns true if this is a set decoration /// @returns true if this is a set decoration
bool IsSet() const override { return true; } bool IsSet() const override;
/// @returns the set value /// @returns the set value
uint32_t value() const { return value_; } uint32_t value() const { return value_; }

View File

@ -39,8 +39,70 @@ Statement::Statement() = default;
Statement::Statement(const Source& source) : Node(source) {} Statement::Statement(const Source& source) : Node(source) {}
Statement::Statement(Statement&&) = default;
Statement::~Statement() = default; Statement::~Statement() = default;
bool Statement::IsAssign() const {
return false;
}
bool Statement::IsBreak() const {
return false;
}
bool Statement::IsCase() const {
return false;
}
bool Statement::IsContinue() const {
return false;
}
bool Statement::IsElse() const {
return false;
}
bool Statement::IsFallthrough() const {
return false;
}
bool Statement::IsIf() const {
return false;
}
bool Statement::IsKill() const {
return false;
}
bool Statement::IsLoop() const {
return false;
}
bool Statement::IsNop() const {
return false;
}
bool Statement::IsRegardless() const {
return false;
}
bool Statement::IsReturn() const {
return false;
}
bool Statement::IsSwitch() const {
return false;
}
bool Statement::IsUnless() const {
return false;
}
bool Statement::IsVariableDecl() const {
return false;
}
AssignmentStatement* Statement::AsAssign() { AssignmentStatement* Statement::AsAssign() {
assert(IsAssign()); assert(IsAssign());
return static_cast<AssignmentStatement*>(this); return static_cast<AssignmentStatement*>(this);

View File

@ -45,35 +45,35 @@ class Statement : public Node {
~Statement() override; ~Statement() override;
/// @returns true if this is an assign statement /// @returns true if this is an assign statement
virtual bool IsAssign() const { return false; } virtual bool IsAssign() const;
/// @returns true if this is a break statement /// @returns true if this is a break statement
virtual bool IsBreak() const { return false; } virtual bool IsBreak() const;
/// @returns true if this is a case statement /// @returns true if this is a case statement
virtual bool IsCase() const { return false; } virtual bool IsCase() const;
/// @returns true if this is a continue statement /// @returns true if this is a continue statement
virtual bool IsContinue() const { return false; } virtual bool IsContinue() const;
/// @returns true if this is an else statement /// @returns true if this is an else statement
virtual bool IsElse() const { return false; } virtual bool IsElse() const;
/// @returns true if this is a fallthrough statement /// @returns true if this is a fallthrough statement
virtual bool IsFallthrough() const { return false; } virtual bool IsFallthrough() const;
/// @returns true if this is an if statement /// @returns true if this is an if statement
virtual bool IsIf() const { return false; } virtual bool IsIf() const;
/// @returns true if this is a kill statement /// @returns true if this is a kill statement
virtual bool IsKill() const { return false; } virtual bool IsKill() const;
/// @returns true if this is a loop statement /// @returns true if this is a loop statement
virtual bool IsLoop() const { return false; } virtual bool IsLoop() const;
/// @returns true if this is a nop statement /// @returns true if this is a nop statement
virtual bool IsNop() const { return false; } virtual bool IsNop() const;
/// @returns true if this is an regardless statement /// @returns true if this is an regardless statement
virtual bool IsRegardless() const { return false; } virtual bool IsRegardless() const;
/// @returns true if this is a return statement /// @returns true if this is a return statement
virtual bool IsReturn() const { return false; } virtual bool IsReturn() const;
/// @returns true if this is a switch statement /// @returns true if this is a switch statement
virtual bool IsSwitch() const { return false; } virtual bool IsSwitch() const;
/// @returns true if this is an unless statement /// @returns true if this is an unless statement
virtual bool IsUnless() const { return false; } virtual bool IsUnless() const;
/// @returns true if this is an variable statement /// @returns true if this is an variable statement
virtual bool IsVariableDecl() const { return false; } virtual bool IsVariableDecl() const;
/// @returns the statement as an assign statement /// @returns the statement as an assign statement
AssignmentStatement* AsAssign(); AssignmentStatement* AsAssign();
@ -113,7 +113,7 @@ class Statement : public Node {
/// @param source the source of the expression /// @param source the source of the expression
explicit Statement(const Source& source); explicit Statement(const Source& source);
/// Move constructor /// Move constructor
Statement(Statement&&) = default; Statement(Statement&&);
private: private:
Statement(const Statement&) = delete; Statement(const Statement&) = delete;

View File

@ -27,6 +27,8 @@ Struct::Struct(const Source& source,
StructMemberList members) StructMemberList members)
: Node(source), decoration_(decoration), members_(std::move(members)) {} : Node(source), decoration_(decoration), members_(std::move(members)) {}
Struct::Struct(Struct&&) = default;
Struct::~Struct() = default; Struct::~Struct() = default;
bool Struct::IsValid() const { bool Struct::IsValid() const {

View File

@ -43,7 +43,7 @@ class Struct : public Node {
StructDecoration decoration, StructDecoration decoration,
StructMemberList members); StructMemberList members);
/// Move constructor /// Move constructor
Struct(Struct&&) = default; Struct(Struct&&);
~Struct() override; ~Struct() override;

View File

@ -17,6 +17,8 @@
namespace tint { namespace tint {
namespace ast { namespace ast {
StructMember::StructMember() = default;
StructMember::StructMember(const std::string& name, StructMember::StructMember(const std::string& name,
type::Type* type, type::Type* type,
StructMemberDecorationList decorations) StructMemberDecorationList decorations)
@ -31,6 +33,8 @@ StructMember::StructMember(const Source& source,
type_(type), type_(type),
decorations_(std::move(decorations)) {} decorations_(std::move(decorations)) {}
StructMember::StructMember(StructMember&&) = default;
StructMember::~StructMember() = default; StructMember::~StructMember() = default;
bool StructMember::IsValid() const { bool StructMember::IsValid() const {

View File

@ -32,7 +32,7 @@ namespace ast {
class StructMember : public Node { class StructMember : public Node {
public: public:
/// Create a new empty struct member statement /// Create a new empty struct member statement
StructMember() = default; StructMember();
/// Create a new struct member statement /// Create a new struct member statement
/// @param name The struct member name /// @param name The struct member name
/// @param type The struct member type /// @param type The struct member type
@ -50,7 +50,7 @@ class StructMember : public Node {
type::Type* type, type::Type* type,
StructMemberDecorationList decorations); StructMemberDecorationList decorations);
/// Move constructor /// Move constructor
StructMember(StructMember&&) = default; StructMember(StructMember&&);
~StructMember() override; ~StructMember() override;

View File

@ -25,6 +25,10 @@ StructMemberDecoration::StructMemberDecoration() = default;
StructMemberDecoration::~StructMemberDecoration() = default; StructMemberDecoration::~StructMemberDecoration() = default;
bool StructMemberDecoration::IsOffset() const {
return false;
}
StructMemberOffsetDecoration* StructMemberDecoration::AsOffset() { StructMemberOffsetDecoration* StructMemberDecoration::AsOffset() {
assert(IsOffset()); assert(IsOffset());
return static_cast<StructMemberOffsetDecoration*>(this); return static_cast<StructMemberOffsetDecoration*>(this);

View File

@ -30,7 +30,7 @@ class StructMemberDecoration {
virtual ~StructMemberDecoration(); virtual ~StructMemberDecoration();
/// @returns true if this is an offset decoration /// @returns true if this is an offset decoration
virtual bool IsOffset() const { return false; } virtual bool IsOffset() const;
/// @returns the decoration as an offset decoration /// @returns the decoration as an offset decoration
StructMemberOffsetDecoration* AsOffset(); StructMemberOffsetDecoration* AsOffset();

View File

@ -20,6 +20,10 @@ namespace ast {
StructMemberOffsetDecoration::StructMemberOffsetDecoration(uint32_t offset) StructMemberOffsetDecoration::StructMemberOffsetDecoration(uint32_t offset)
: offset_(offset) {} : offset_(offset) {}
bool StructMemberOffsetDecoration::IsOffset() const {
return true;
}
StructMemberOffsetDecoration::~StructMemberOffsetDecoration() = default; StructMemberOffsetDecoration::~StructMemberOffsetDecoration() = default;
std::string StructMemberOffsetDecoration::to_str() const { std::string StructMemberOffsetDecoration::to_str() const {

View File

@ -33,7 +33,7 @@ class StructMemberOffsetDecoration : public StructMemberDecoration {
~StructMemberOffsetDecoration() override; ~StructMemberOffsetDecoration() override;
/// @returns true if this is an offset decoration /// @returns true if this is an offset decoration
bool IsOffset() const override { return true; } bool IsOffset() const override;
/// @returns the offset value /// @returns the offset value
uint32_t offset() const { return offset_; } uint32_t offset() const { return offset_; }

View File

@ -32,6 +32,12 @@ SwitchStatement::SwitchStatement(const Source& source,
condition_(std::move(condition)), condition_(std::move(condition)),
body_(std::move(body)) {} body_(std::move(body)) {}
bool SwitchStatement::IsSwitch() const {
return true;
}
SwitchStatement::SwitchStatement(SwitchStatement&&) = default;
SwitchStatement::~SwitchStatement() = default; SwitchStatement::~SwitchStatement() = default;
bool SwitchStatement::IsValid() const { bool SwitchStatement::IsValid() const {

View File

@ -45,7 +45,7 @@ class SwitchStatement : public Statement {
std::unique_ptr<Expression> condition, std::unique_ptr<Expression> condition,
CaseStatementList body); CaseStatementList body);
/// Move constructor /// Move constructor
SwitchStatement(SwitchStatement&&) = default; SwitchStatement(SwitchStatement&&);
~SwitchStatement() override; ~SwitchStatement() override;
/// Sets the condition for the switch statement /// Sets the condition for the switch statement
@ -65,7 +65,7 @@ class SwitchStatement : public Statement {
const CaseStatementList& body() const { return body_; } const CaseStatementList& body() const { return body_; }
/// @returns true if this is a switch statement /// @returns true if this is a switch statement
bool IsSwitch() const override { return true; } bool IsSwitch() const override;
/// @returns true if the node is valid /// @returns true if the node is valid
bool IsValid() const override; bool IsValid() const override;

View File

@ -27,6 +27,14 @@ AliasType::AliasType(const std::string& name, Type* subtype)
AliasType::~AliasType() = default; AliasType::~AliasType() = default;
bool AliasType::IsAlias() const {
return true;
}
std::string AliasType::type_name() const {
return "__alias_" + name_ + subtype_->type_name();
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -35,7 +35,7 @@ class AliasType : public Type {
~AliasType() override; ~AliasType() override;
/// @returns true if the type is an alias type /// @returns true if the type is an alias type
bool IsAlias() const override { return true; } bool IsAlias() const override;
/// @returns the alias name /// @returns the alias name
const std::string& name() const { return name_; } const std::string& name() const { return name_; }
@ -43,9 +43,7 @@ class AliasType : public Type {
Type* type() const { return subtype_; } Type* type() const { return subtype_; }
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { std::string type_name() const override;
return "__alias_" + name_ + subtype_->type_name();
}
private: private:
std::string name_; std::string name_;

View File

@ -23,8 +23,24 @@ ArrayType::ArrayType(Type* subtype) : subtype_(subtype) {}
ArrayType::ArrayType(Type* subtype, uint32_t size) ArrayType::ArrayType(Type* subtype, uint32_t size)
: subtype_(subtype), size_(size) {} : subtype_(subtype), size_(size) {}
ArrayType::ArrayType(ArrayType&&) = default;
ArrayType::~ArrayType() = default; ArrayType::~ArrayType() = default;
bool ArrayType::IsArray() const {
return true;
}
std::string ArrayType::type_name() const {
assert(subtype_);
std::string type_name = "__array" + subtype_->type_name();
if (!IsRuntimeArray())
type_name += "_" + std::to_string(size_);
return type_name;
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -36,11 +36,11 @@ class ArrayType : public Type {
/// @param size the number of elements in the array /// @param size the number of elements in the array
ArrayType(Type* subtype, uint32_t size); ArrayType(Type* subtype, uint32_t size);
/// Move constructor /// Move constructor
ArrayType(ArrayType&&) = default; ArrayType(ArrayType&&);
~ArrayType() override; ~ArrayType() override;
/// @returns true if the type is an array type /// @returns true if the type is an array type
bool IsArray() const override { return true; } 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; }
@ -51,15 +51,7 @@ class ArrayType : public Type {
uint32_t size() const { return size_; } uint32_t size() const { return size_; }
/// @returns the name for the type /// @returns the name for the type
std::string type_name() const override { std::string type_name() const override;
assert(subtype_);
std::string type_name = "__array" + subtype_->type_name();
if (!IsRuntimeArray())
type_name += "_" + std::to_string(size_);
return type_name;
}
private: private:
Type* subtype_ = nullptr; Type* subtype_ = nullptr;

View File

@ -22,6 +22,14 @@ BoolType::BoolType() = default;
BoolType::~BoolType() = default; BoolType::~BoolType() = default;
bool BoolType::IsBool() const {
return true;
}
std::string BoolType::type_name() const {
return "__bool";
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -33,10 +33,10 @@ class BoolType : public Type {
~BoolType() override; ~BoolType() override;
/// @returns true if the type is a bool type /// @returns true if the type is a bool type
bool IsBool() const override { return true; } bool IsBool() const override;
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { return "__bool"; } std::string type_name() const override;
}; };
} // namespace type } // namespace type

View File

@ -22,6 +22,14 @@ F32Type::F32Type() = default;
F32Type::~F32Type() = default; F32Type::~F32Type() = default;
bool F32Type::IsF32() const {
return true;
}
std::string F32Type::type_name() const {
return "__f32";
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -33,10 +33,10 @@ class F32Type : public Type {
~F32Type() override; ~F32Type() override;
/// @returns true if the type is an f32 type /// @returns true if the type is an f32 type
bool IsF32() const override { return true; } bool IsF32() const override;
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { return "__f32"; } std::string type_name() const override;
}; };
} // namespace type } // namespace type

View File

@ -22,6 +22,14 @@ I32Type::I32Type() = default;
I32Type::~I32Type() = default; I32Type::~I32Type() = default;
bool I32Type::IsI32() const {
return true;
}
std::string I32Type::type_name() const {
return "__i32";
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -33,10 +33,10 @@ class I32Type : public Type {
~I32Type() override; ~I32Type() override;
/// @returns true if the type is an i32 type /// @returns true if the type is an i32 type
bool IsI32() const override { return true; } bool IsI32() const override;
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { return "__i32"; } std::string type_name() const override;
}; };
} // namespace type } // namespace type

View File

@ -28,6 +28,15 @@ MatrixType::MatrixType(Type* subtype, uint32_t rows, uint32_t columns)
assert(columns < 5); assert(columns < 5);
} }
bool MatrixType::IsMatrix() const {
return true;
}
std::string MatrixType::type_name() const {
return "__mat_" + std::to_string(rows_) + "_" + std::to_string(columns_) +
subtype_->type_name();
}
MatrixType::~MatrixType() = default; MatrixType::~MatrixType() = default;
} // namespace type } // namespace type

View File

@ -36,7 +36,7 @@ class MatrixType : public Type {
~MatrixType() override; ~MatrixType() override;
/// @returns true if the type is a matrix type /// @returns true if the type is a matrix type
bool IsMatrix() const override { return true; } bool IsMatrix() const override;
/// @returns the type of the matrix /// @returns the type of the matrix
Type* type() const { return subtype_; } Type* type() const { return subtype_; }
@ -46,10 +46,7 @@ class MatrixType : public Type {
uint32_t columns() const { return columns_; } uint32_t columns() const { return columns_; }
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { std::string type_name() const override;
return "__mat_" + std::to_string(rows_) + "_" + std::to_string(columns_) +
subtype_->type_name();
}
private: private:
Type* subtype_ = nullptr; Type* subtype_ = nullptr;

View File

@ -21,6 +21,16 @@ namespace type {
PointerType::PointerType(Type* subtype, StorageClass storage_class) PointerType::PointerType(Type* subtype, StorageClass storage_class)
: subtype_(subtype), storage_class_(storage_class) {} : subtype_(subtype), storage_class_(storage_class) {}
bool PointerType::IsPointer() const {
return true;
}
std::string PointerType::type_name() const {
std::ostringstream out;
out << "__ptr_" << storage_class_ << subtype_->type_name();
return out.str();
}
PointerType::~PointerType() = default; PointerType::~PointerType() = default;
} // namespace type } // namespace type

View File

@ -37,7 +37,7 @@ class PointerType : public Type {
~PointerType() override; ~PointerType() override;
/// @returns true if the type is a pointer type /// @returns true if the type is a pointer type
bool IsPointer() const override { return true; } bool IsPointer() const override;
/// @returns the pointee type /// @returns the pointee type
Type* type() const { return subtype_; } Type* type() const { return subtype_; }
@ -45,11 +45,7 @@ class PointerType : public Type {
StorageClass storage_class() const { return storage_class_; } StorageClass storage_class() const { return storage_class_; }
/// @returns the name for this type /// @returns the name for this type
std::string type_name() const override { std::string type_name() const override;
std::ostringstream out;
out << "__ptr_" << storage_class_ << subtype_->type_name();
return out.str();
}
private: private:
Type* subtype_; Type* subtype_;

View File

@ -23,6 +23,16 @@ namespace type {
StructType::StructType(std::unique_ptr<Struct> impl) StructType::StructType(std::unique_ptr<Struct> impl)
: struct_(std::move(impl)) {} : struct_(std::move(impl)) {}
StructType::StructType(StructType&&) = default;
bool StructType::IsStruct() const {
return true;
}
std::string StructType::type_name() const {
return "__struct_" + name_;
}
StructType::~StructType() = default; StructType::~StructType() = default;
} // namespace type } // namespace type

View File

@ -32,7 +32,7 @@ class StructType : public Type {
/// @param impl the struct data /// @param impl the struct data
explicit StructType(std::unique_ptr<Struct> impl); explicit StructType(std::unique_ptr<Struct> impl);
/// Move constructor /// Move constructor
StructType(StructType&&) = default; StructType(StructType&&);
~StructType() override; ~StructType() override;
/// Sets the name of the struct /// Sets the name of the struct
@ -42,13 +42,13 @@ class StructType : public Type {
const std::string& name() const { return name_; } const std::string& name() const { return name_; }
/// @returns true if the type is a struct type /// @returns true if the type is a struct type
bool IsStruct() const override { return true; } bool IsStruct() const override;
/// @returns the struct name /// @returns the struct name
Struct* impl() const { return struct_.get(); } Struct* impl() const { return struct_.get(); }
/// @returns the name for th type /// @returns the name for th type
std::string type_name() const override { return "__struct_" + name_; } std::string type_name() const override;
private: private:
std::string name_; std::string name_;

View File

@ -36,6 +36,50 @@ Type::Type() = default;
Type::~Type() = default; Type::~Type() = default;
bool Type::IsAlias() const {
return false;
}
bool Type::IsArray() const {
return false;
}
bool Type::IsBool() const {
return false;
}
bool Type::IsF32() const {
return false;
}
bool Type::IsI32() const {
return false;
}
bool Type::IsMatrix() const {
return false;
}
bool Type::IsPointer() const {
return false;
}
bool Type::IsStruct() const {
return false;
}
bool Type::IsU32() const {
return false;
}
bool Type::IsVector() const {
return false;
}
bool Type::IsVoid() const {
return false;
}
AliasType* Type::AsAlias() { AliasType* Type::AsAlias() {
assert(IsAlias()); assert(IsAlias());
return static_cast<AliasType*>(this); return static_cast<AliasType*>(this);

View File

@ -41,27 +41,27 @@ class Type {
virtual ~Type(); virtual ~Type();
/// @returns true if the type is an alias type /// @returns true if the type is an alias type
virtual bool IsAlias() const { return false; } virtual bool IsAlias() const;
/// @returns true if the type is an array type /// @returns true if the type is an array type
virtual bool IsArray() const { return false; } 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 { return false; } virtual bool IsBool() const;
/// @returns true if the type is an f32 type /// @returns true if the type is an f32 type
virtual bool IsF32() const { return false; } virtual bool IsF32() const;
/// @returns true if the type is an i32 type /// @returns true if the type is an i32 type
virtual bool IsI32() const { return false; } virtual bool IsI32() const;
/// @returns true if the type is a matrix type /// @returns true if the type is a matrix type
virtual bool IsMatrix() const { return false; } virtual bool IsMatrix() const;
/// @returns true if the type is a ptr type /// @returns true if the type is a ptr type
virtual bool IsPointer() const { return false; } virtual bool IsPointer() const;
/// @returns true if the type is a struct type /// @returns true if the type is a struct type
virtual bool IsStruct() const { return false; } virtual bool IsStruct() const;
/// @returns true if the type is a u32 type /// @returns true if the type is a u32 type
virtual bool IsU32() const { return false; } virtual bool IsU32() const;
/// @returns true if the type is a vec type /// @returns true if the type is a vec type
virtual bool IsVector() const { return false; } virtual bool IsVector() const;
/// @returns true if the type is a void type /// @returns true if the type is a void type
virtual bool IsVoid() const { return false; } virtual bool IsVoid() const;
/// @returns the name for this type. The |type_name| is unique over all types. /// @returns the name for this type. The |type_name| is unique over all types.
virtual std::string type_name() const = 0; virtual std::string type_name() const = 0;

View File

@ -22,6 +22,16 @@ U32Type::U32Type() = default;
U32Type::~U32Type() = default; U32Type::~U32Type() = default;
U32Type::U32Type(U32Type&&) = default;
bool U32Type::IsU32() const {
return true;
}
std::string U32Type::type_name() const {
return "__u32";
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

View File

@ -29,14 +29,14 @@ class U32Type : public Type {
/// Constructor /// Constructor
U32Type(); U32Type();
/// Move constructor /// Move constructor
U32Type(U32Type&&) = default; U32Type(U32Type&&);
~U32Type() override; ~U32Type() override;
/// @returns true if the type is a u32 type /// @returns true if the type is a u32 type
bool IsU32() const override { return true; } bool IsU32() const override;
/// @returns the name for th type /// @returns the name for th type
std::string type_name() const override { return "__u32"; } std::string type_name() const override;
}; };
} // namespace type } // namespace type

View File

@ -26,8 +26,18 @@ VectorType::VectorType(Type* subtype, uint32_t size)
assert(size_ < 5); assert(size_ < 5);
} }
VectorType::VectorType(VectorType&&) = default;
VectorType::~VectorType() = default; VectorType::~VectorType() = default;
bool VectorType::IsVector() const {
return true;
}
std::string VectorType::type_name() const {
return "__vec_" + std::to_string(size_) + subtype_->type_name();
}
} // namespace type } // namespace type
} // namespace ast } // namespace ast
} // namespace tint } // namespace tint

Some files were not shown because too many files have changed in this diff Show More