// 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 "src/ast/struct.h" #include "src/ast/struct_block_decoration.h" #include "src/clone_context.h" #include "src/program_builder.h" TINT_INSTANTIATE_CLASS_ID(tint::ast::Struct); namespace tint { namespace ast { Struct::Struct(const Source& source, StructMemberList members, StructDecorationList decorations) : Base(source), members_(std::move(members)), decorations_(std::move(decorations)) {} Struct::Struct(Struct&&) = default; Struct::~Struct() = default; StructMember* Struct::get_member(const Symbol& symbol) const { for (auto* mem : members_) { if (mem->symbol() == symbol) { return mem; } } return nullptr; } bool Struct::IsBlockDecorated() const { for (auto* deco : decorations_) { if (deco->Is()) { return true; } } return false; } Struct* Struct::Clone(CloneContext* ctx) const { return ctx->dst->create(ctx->Clone(source()), ctx->Clone(members_), ctx->Clone(decorations_)); } bool Struct::IsValid() const { for (auto* mem : members_) { if (mem == nullptr || !mem->IsValid()) { return false; } } return true; } void Struct::to_str(const semantic::Info& sem, std::ostream& out, size_t indent) const { out << "Struct{" << std::endl; for (auto* deco : decorations_) { make_indent(out, indent + 2); out << "[["; deco->to_str(sem, out, 0); out << "]]" << std::endl; } for (auto* member : members_) { member->to_str(sem, out, indent + 2); } make_indent(out, indent); out << "}" << std::endl; } } // namespace ast } // namespace tint