/** * Copyright (c) 2021 Huawei Device Co., Ltd. * 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 "methodDefinition.h" #include #include #include #include #include #include #include #include namespace panda::es2panda::ir { const ScriptFunction *MethodDefinition::Function() const { return value_->Function(); } ScriptFunction *MethodDefinition::Function() { return value_->Function(); } void MethodDefinition::Iterate(const NodeTraverser &cb) const { cb(key_); cb(value_); for (auto *it : overloads_) { cb(it); } for (auto *it : decorators_) { cb(it); } for (auto *it : annotations_) { cb(it); } for (auto param : paramDecorators_) { for (auto *it : param.decorators) { cb(it); } } } void MethodDefinition::Dump(ir::AstDumper *dumper) const { const char *kind = nullptr; switch (kind_) { case MethodDefinitionKind::CONSTRUCTOR: { kind = "constructor"; break; } case MethodDefinitionKind::METHOD: { kind = "method"; break; } case MethodDefinitionKind::GET: { kind = "get"; break; } case MethodDefinitionKind::SET: { kind = "set"; break; } default: { UNREACHABLE(); } } dumper->Add({{"type", "MethodDefinition"}, {"key", key_}, {"kind", kind}, {"accessibility", AstDumper::Optional(AstDumper::ModifierToString(modifiers_))}, {"abstract", AstDumper::Optional((modifiers_ & ModifierFlags::ABSTRACT) != 0)}, {"static", (modifiers_ & ModifierFlags::STATIC) != 0}, {"optional", (modifiers_ & ModifierFlags::OPTIONAL) != 0}, {"override", AstDumper::Optional((modifiers_ & ModifierFlags::OVERRIDE) != 0)}, {"computed", isComputed_}, {"value", value_}, {"overloads", overloads_}, {"decorators", decorators_}, {"annotations", annotations_}}); } void MethodDefinition::Compile([[maybe_unused]] compiler::PandaGen *pg) const {} checker::Type *MethodDefinition::Check([[maybe_unused]] checker::Checker *checker) const { return nullptr; } void MethodDefinition::UpdateSelf(const NodeUpdater &cb, [[maybe_unused]] binder::Binder *binder) { key_ = std::get(cb(key_))->AsExpression(); value_ = std::get(cb(value_))->AsFunctionExpression(); for (auto iter = overloads_.begin(); iter != overloads_.end(); iter++) { *iter = std::get(cb(*iter))->AsMethodDefinition(); } for (auto iter = decorators_.begin(); iter != decorators_.end(); iter++) { *iter = std::get(cb(*iter))->AsDecorator(); } for (auto param : paramDecorators_) { for (auto iter = param.decorators.begin(); iter != param.decorators.end(); iter++) { *iter = std::get(cb(*iter))->AsDecorator(); } } } } // namespace panda::es2panda::ir