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