13af6ab5fSopenharmony_ci/*
23af6ab5fSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License.
53af6ab5fSopenharmony_ci * You may obtain a copy of the License at
63af6ab5fSopenharmony_ci *
73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
83af6ab5fSopenharmony_ci *
93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and
133af6ab5fSopenharmony_ci * limitations under the License.
143af6ab5fSopenharmony_ci */
153af6ab5fSopenharmony_ci
163af6ab5fSopenharmony_ci#ifndef ES2PANDA_EVALUATE_NON_RECURSIVE_IR_CHECKER_H
173af6ab5fSopenharmony_ci#define ES2PANDA_EVALUATE_NON_RECURSIVE_IR_CHECKER_H
183af6ab5fSopenharmony_ci
193af6ab5fSopenharmony_ci#include "libpandabase/mem/arena_allocator.h"
203af6ab5fSopenharmony_ci#include "libpandabase/utils/arena_containers.h"
213af6ab5fSopenharmony_ci
223af6ab5fSopenharmony_cinamespace ark::es2panda::checker {
233af6ab5fSopenharmony_ciclass ETSChecker;
243af6ab5fSopenharmony_ci}  // namespace ark::es2panda::checker
253af6ab5fSopenharmony_ci
263af6ab5fSopenharmony_cinamespace ark::es2panda::ir {
273af6ab5fSopenharmony_ciclass AstNode;
283af6ab5fSopenharmony_ci}  // namespace ark::es2panda::ir
293af6ab5fSopenharmony_ci
303af6ab5fSopenharmony_cinamespace ark::es2panda::parser {
313af6ab5fSopenharmony_ciclass Program;
323af6ab5fSopenharmony_ci}  // namespace ark::es2panda::parser
333af6ab5fSopenharmony_ci
343af6ab5fSopenharmony_cinamespace ark::es2panda::varbinder {
353af6ab5fSopenharmony_ciclass ETSBinder;
363af6ab5fSopenharmony_ciclass Scope;
373af6ab5fSopenharmony_ci}  // namespace ark::es2panda::varbinder
383af6ab5fSopenharmony_ci
393af6ab5fSopenharmony_cinamespace ark::es2panda::evaluate {
403af6ab5fSopenharmony_ci
413af6ab5fSopenharmony_ci/**
423af6ab5fSopenharmony_ci * @brief Helper class for running type checks
433af6ab5fSopenharmony_ci * All newly created IR nodes from debug-info must be checked through this class,
443af6ab5fSopenharmony_ci * otherwise recursive class creations can lead to varbinder scopes errors.
453af6ab5fSopenharmony_ci */
463af6ab5fSopenharmony_ciclass IrCheckHelper final {
473af6ab5fSopenharmony_cipublic:
483af6ab5fSopenharmony_ci    struct ScopedAstNode final {
493af6ab5fSopenharmony_ci        ScopedAstNode(parser::Program *p, varbinder::Scope *s, ir::AstNode *parent, ir::AstNode *n)
503af6ab5fSopenharmony_ci            : program(p), scope(s), parentClass(parent), node(n)
513af6ab5fSopenharmony_ci        {
523af6ab5fSopenharmony_ci        }
533af6ab5fSopenharmony_ci
543af6ab5fSopenharmony_ci        // NOLINTBEGIN(misc-non-private-member-variables-in-classes)
553af6ab5fSopenharmony_ci        parser::Program *program {nullptr};
563af6ab5fSopenharmony_ci        varbinder::Scope *scope {nullptr};
573af6ab5fSopenharmony_ci        ir::AstNode *parentClass {nullptr};
583af6ab5fSopenharmony_ci        ir::AstNode *node {nullptr};
593af6ab5fSopenharmony_ci        // NOLINTEND(misc-non-private-member-variables-in-classes)
603af6ab5fSopenharmony_ci    };
613af6ab5fSopenharmony_ci
623af6ab5fSopenharmony_cipublic:
633af6ab5fSopenharmony_ci    explicit IrCheckHelper(checker::ETSChecker *checker, varbinder::ETSBinder *varBinder);
643af6ab5fSopenharmony_ci    NO_COPY_SEMANTIC(IrCheckHelper);
653af6ab5fSopenharmony_ci    NO_MOVE_SEMANTIC(IrCheckHelper);
663af6ab5fSopenharmony_ci    ~IrCheckHelper() noexcept = default;
673af6ab5fSopenharmony_ci
683af6ab5fSopenharmony_ci    /**
693af6ab5fSopenharmony_ci     * @brief Runs scope and type checks on the given IR node
703af6ab5fSopenharmony_ci     * @param node to check, must not be null.
713af6ab5fSopenharmony_ci     * @param scope to which node is relative to - if null, current checker scope is taken.
723af6ab5fSopenharmony_ci     * @param parentClass class to use record table from, might be null.
733af6ab5fSopenharmony_ci     * @param program relative to node - if null, current varbinder program is taken;
743af6ab5fSopenharmony_ci     * either it or `scope` must be non-null.
753af6ab5fSopenharmony_ci     * @returns false if check was delayed until recursion end, true if check was done immediately.
763af6ab5fSopenharmony_ci     */
773af6ab5fSopenharmony_ci    bool CheckNewNode(ir::AstNode *node, varbinder::Scope *scope, ir::AstNode *parentClass, parser::Program *program);
783af6ab5fSopenharmony_ci
793af6ab5fSopenharmony_ci    void PreCheck();
803af6ab5fSopenharmony_ci
813af6ab5fSopenharmony_ci    void CheckGlobalEntity(parser::Program *program, ir::AstNode *node, bool mustCheck = true);
823af6ab5fSopenharmony_ci    void CheckLocalEntity(ir::AstNode *node);
833af6ab5fSopenharmony_ci
843af6ab5fSopenharmony_ci    checker::ETSChecker *GetChecker() const
853af6ab5fSopenharmony_ci    {
863af6ab5fSopenharmony_ci        return checker_;
873af6ab5fSopenharmony_ci    }
883af6ab5fSopenharmony_ci
893af6ab5fSopenharmony_ciprivate:
903af6ab5fSopenharmony_ci    void HandleCustomNodes();
913af6ab5fSopenharmony_ci    void CheckDecls();
923af6ab5fSopenharmony_ci
933af6ab5fSopenharmony_ciprivate:
943af6ab5fSopenharmony_ci    checker::ETSChecker *checker_ {nullptr};
953af6ab5fSopenharmony_ci    varbinder::ETSBinder *varBinder_ {nullptr};
963af6ab5fSopenharmony_ci
973af6ab5fSopenharmony_ci    bool isRecursive_ {false};
983af6ab5fSopenharmony_ci    // List is required due to possible push-backs during iteration.
993af6ab5fSopenharmony_ci    ArenaList<ScopedAstNode> recursiveDecls_;
1003af6ab5fSopenharmony_ci    // Indicates that PreCheck was called from ETSChecker::StartChecker()
1013af6ab5fSopenharmony_ci    bool isPrecheckPassed_ {false};
1023af6ab5fSopenharmony_ci};
1033af6ab5fSopenharmony_ci
1043af6ab5fSopenharmony_ci}  // namespace ark::es2panda::evaluate
1053af6ab5fSopenharmony_ci
1063af6ab5fSopenharmony_ci#endif  // ES2PANDA_EVALUATE_NON_RECURSIVE_IR_CHECKER_H
107