13af6ab5fSopenharmony_ci/*
23af6ab5fSopenharmony_ci * Copyright (c) 2021-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_COMPILER_CHECKER_ETS_BASE_ANALYZER_H
173af6ab5fSopenharmony_ci#define ES2PANDA_COMPILER_CHECKER_ETS_BASE_ANALYZER_H
183af6ab5fSopenharmony_ci
193af6ab5fSopenharmony_ci#include "utils/arena_containers.h"
203af6ab5fSopenharmony_ci#include "util/enumbitops.h"
213af6ab5fSopenharmony_ci
223af6ab5fSopenharmony_cinamespace ark::es2panda::ir {
233af6ab5fSopenharmony_ciclass AstNode;
243af6ab5fSopenharmony_cienum class AstNodeType;
253af6ab5fSopenharmony_ci}  // namespace ark::es2panda::ir
263af6ab5fSopenharmony_ci
273af6ab5fSopenharmony_cinamespace ark::es2panda::checker {
283af6ab5fSopenharmony_ciclass ETSChecker;
293af6ab5fSopenharmony_ci
303af6ab5fSopenharmony_ciusing ENUMBITOPS_OPERATORS;
313af6ab5fSopenharmony_ci
323af6ab5fSopenharmony_cienum class LivenessStatus { DEAD, ALIVE };
333af6ab5fSopenharmony_ci
343af6ab5fSopenharmony_ciclass PendingExit {
353af6ab5fSopenharmony_cipublic:
363af6ab5fSopenharmony_ci    using JumpResolver = std::function<void()>;
373af6ab5fSopenharmony_ci
383af6ab5fSopenharmony_ci    explicit PendingExit(
393af6ab5fSopenharmony_ci        const ir::AstNode *node, JumpResolver jumpResolver = [] {})
403af6ab5fSopenharmony_ci        : node_(node), jumpResolver_(std::move(jumpResolver))
413af6ab5fSopenharmony_ci    {
423af6ab5fSopenharmony_ci    }
433af6ab5fSopenharmony_ci    virtual ~PendingExit() = default;
443af6ab5fSopenharmony_ci
453af6ab5fSopenharmony_ci    DEFAULT_COPY_SEMANTIC(PendingExit);
463af6ab5fSopenharmony_ci    DEFAULT_NOEXCEPT_MOVE_SEMANTIC(PendingExit);
473af6ab5fSopenharmony_ci
483af6ab5fSopenharmony_ci    virtual void ResolveJump()
493af6ab5fSopenharmony_ci    {
503af6ab5fSopenharmony_ci        jumpResolver_();
513af6ab5fSopenharmony_ci    }
523af6ab5fSopenharmony_ci
533af6ab5fSopenharmony_ci    const ir::AstNode *Node() const
543af6ab5fSopenharmony_ci    {
553af6ab5fSopenharmony_ci        return node_;
563af6ab5fSopenharmony_ci    }
573af6ab5fSopenharmony_ci
583af6ab5fSopenharmony_ciprivate:
593af6ab5fSopenharmony_ci    const ir::AstNode *node_;
603af6ab5fSopenharmony_ci    JumpResolver jumpResolver_;
613af6ab5fSopenharmony_ci};
623af6ab5fSopenharmony_ci
633af6ab5fSopenharmony_citemplate <typename T>
643af6ab5fSopenharmony_ciclass BaseAnalyzer {
653af6ab5fSopenharmony_cipublic:
663af6ab5fSopenharmony_ci    using PendingExitsVector = std::vector<T>;
673af6ab5fSopenharmony_ci
683af6ab5fSopenharmony_ci    explicit BaseAnalyzer() = default;
693af6ab5fSopenharmony_ci
703af6ab5fSopenharmony_ci    virtual void MarkDead() = 0;
713af6ab5fSopenharmony_ci
723af6ab5fSopenharmony_ci    void RecordExit(const T &pe)
733af6ab5fSopenharmony_ci    {
743af6ab5fSopenharmony_ci        pendingExits_.push_back(pe);
753af6ab5fSopenharmony_ci        MarkDead();
763af6ab5fSopenharmony_ci    }
773af6ab5fSopenharmony_ci
783af6ab5fSopenharmony_ci    LivenessStatus From(bool value)
793af6ab5fSopenharmony_ci    {
803af6ab5fSopenharmony_ci        return value ? LivenessStatus::ALIVE : LivenessStatus::DEAD;
813af6ab5fSopenharmony_ci    }
823af6ab5fSopenharmony_ci
833af6ab5fSopenharmony_ci    LivenessStatus ResolveJump(const ir::AstNode *node, ir::AstNodeType jumpKind);
843af6ab5fSopenharmony_ci    LivenessStatus ResolveContinues(const ir::AstNode *node);
853af6ab5fSopenharmony_ci    LivenessStatus ResolveBreaks(const ir::AstNode *node);
863af6ab5fSopenharmony_ci    const ir::AstNode *GetJumpTarget(const ir::AstNode *node) const;
873af6ab5fSopenharmony_ci
883af6ab5fSopenharmony_ciprotected:
893af6ab5fSopenharmony_ci    void ClearPendingExits();
903af6ab5fSopenharmony_ci    PendingExitsVector &PendingExits();
913af6ab5fSopenharmony_ci    void SetPendingExits(const PendingExitsVector &pendingExits);
923af6ab5fSopenharmony_ci    PendingExitsVector &OldPendingExits();
933af6ab5fSopenharmony_ci    void SetOldPendingExits(const PendingExitsVector &oldPendingExits);
943af6ab5fSopenharmony_ci
953af6ab5fSopenharmony_ciprivate:
963af6ab5fSopenharmony_ci    PendingExitsVector pendingExits_;
973af6ab5fSopenharmony_ci    PendingExitsVector oldPendingExits_;
983af6ab5fSopenharmony_ci};
993af6ab5fSopenharmony_ci}  // namespace ark::es2panda::checker
1003af6ab5fSopenharmony_ci
1013af6ab5fSopenharmony_citemplate <>
1023af6ab5fSopenharmony_cistruct enumbitops::IsAllowedType<ark::es2panda::checker::LivenessStatus> : std::true_type {
1033af6ab5fSopenharmony_ci};
1043af6ab5fSopenharmony_ci
1053af6ab5fSopenharmony_ci#endif
106