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_SCOPED_DEBUG_INFO_PLUGIN_H 173af6ab5fSopenharmony_ci#define ES2PANDA_EVALUATE_SCOPED_DEBUG_INFO_PLUGIN_H 183af6ab5fSopenharmony_ci 193af6ab5fSopenharmony_ci#include "evaluate/debugInfoStorage.h" 203af6ab5fSopenharmony_ci#include "evaluate/evaluateContext.h" 213af6ab5fSopenharmony_ci#include "evaluate/helpers.h" 223af6ab5fSopenharmony_ci#include "evaluate/irCheckHelper.h" 233af6ab5fSopenharmony_ci#include "evaluate/proxyProgramsCache.h" 243af6ab5fSopenharmony_ci#include "evaluate/pathResolver.h" 253af6ab5fSopenharmony_ci#include "evaluate/entityDeclarator.h" 263af6ab5fSopenharmony_ci#include "evaluate/debugInfoDeserialization/debugInfoDeserializer.h" 273af6ab5fSopenharmony_ci 283af6ab5fSopenharmony_cinamespace ark::es2panda::ir { 293af6ab5fSopenharmony_ciclass BlockStatement; 303af6ab5fSopenharmony_ciclass Statement; 313af6ab5fSopenharmony_ci} // namespace ark::es2panda::ir 323af6ab5fSopenharmony_ci 333af6ab5fSopenharmony_cinamespace ark::es2panda::varbinder { 343af6ab5fSopenharmony_ciclass ETSBinder; 353af6ab5fSopenharmony_ciclass Variable; 363af6ab5fSopenharmony_ci} // namespace ark::es2panda::varbinder 373af6ab5fSopenharmony_ci 383af6ab5fSopenharmony_cinamespace ark::es2panda::evaluate { 393af6ab5fSopenharmony_ci 403af6ab5fSopenharmony_ci/// @brief Context-dependent debug info plugin. Must be created before parsing phase. 413af6ab5fSopenharmony_ciclass ScopedDebugInfoPlugin final { 423af6ab5fSopenharmony_cipublic: 433af6ab5fSopenharmony_ci explicit ScopedDebugInfoPlugin(parser::Program *globalProgram, checker::ETSChecker *checker, 443af6ab5fSopenharmony_ci const CompilerOptions &options); 453af6ab5fSopenharmony_ci 463af6ab5fSopenharmony_ci NO_COPY_SEMANTIC(ScopedDebugInfoPlugin); 473af6ab5fSopenharmony_ci NO_MOVE_SEMANTIC(ScopedDebugInfoPlugin); 483af6ab5fSopenharmony_ci 493af6ab5fSopenharmony_ci ~ScopedDebugInfoPlugin() = default; 503af6ab5fSopenharmony_ci 513af6ab5fSopenharmony_ci /** 523af6ab5fSopenharmony_ci * @brief Searches debug-info for the given identifier 533af6ab5fSopenharmony_ci * @param ident node with name of either a local or global variable or a class 543af6ab5fSopenharmony_ci */ 553af6ab5fSopenharmony_ci varbinder::Variable *FindIdentifier(ir::Identifier *ident); 563af6ab5fSopenharmony_ci 573af6ab5fSopenharmony_ci /** 583af6ab5fSopenharmony_ci * @brief Searches debug-info for the given class 593af6ab5fSopenharmony_ci * On success creates IR for this and all dependencies. 603af6ab5fSopenharmony_ci */ 613af6ab5fSopenharmony_ci varbinder::Variable *FindClass(ir::Identifier *ident); 623af6ab5fSopenharmony_ci 633af6ab5fSopenharmony_ci /** 643af6ab5fSopenharmony_ci * @brief Adds collected prologue and epilogue statements in the block 653af6ab5fSopenharmony_ci * In effect, previously collected prologue-epilogue statements are dropped. 663af6ab5fSopenharmony_ci */ 673af6ab5fSopenharmony_ci void AddPrologueEpilogue(ir::BlockStatement *block); 683af6ab5fSopenharmony_ci 693af6ab5fSopenharmony_ci /** 703af6ab5fSopenharmony_ci * @brief Save \p stmt node to be pushed later at the beginning or end of the \p block depending on the IS_PROLOGUE 713af6ab5fSopenharmony_ci * parameter 723af6ab5fSopenharmony_ci */ 733af6ab5fSopenharmony_ci template <bool IS_PROLOGUE> 743af6ab5fSopenharmony_ci void RegisterPrologueEpilogue(ir::BlockStatement *block, ir::Statement *stmt); 753af6ab5fSopenharmony_ci 763af6ab5fSopenharmony_ci /** 773af6ab5fSopenharmony_ci * @brief Initialization before ETSChecker starts checking AST 783af6ab5fSopenharmony_ci * Since we can resolve references like `new A()`, that resolved before ETSChecker was started, 793af6ab5fSopenharmony_ci * we need such a precheck call. 803af6ab5fSopenharmony_ci */ 813af6ab5fSopenharmony_ci void PreCheck(); 823af6ab5fSopenharmony_ci 833af6ab5fSopenharmony_ci /** 843af6ab5fSopenharmony_ci * @brief Finalization after ETSChecker checks the main program 853af6ab5fSopenharmony_ci */ 863af6ab5fSopenharmony_ci void PostCheck(); 873af6ab5fSopenharmony_ci 883af6ab5fSopenharmony_ci PathResolver *GetPathResolver() 893af6ab5fSopenharmony_ci { 903af6ab5fSopenharmony_ci return &pathResolver_; 913af6ab5fSopenharmony_ci } 923af6ab5fSopenharmony_ci 933af6ab5fSopenharmony_ci const PathResolver *GetPathResolver() const 943af6ab5fSopenharmony_ci { 953af6ab5fSopenharmony_ci return &pathResolver_; 963af6ab5fSopenharmony_ci } 973af6ab5fSopenharmony_ci 983af6ab5fSopenharmony_ci IrCheckHelper *GetIrCheckHelper() 993af6ab5fSopenharmony_ci { 1003af6ab5fSopenharmony_ci return &irCheckHelper_; 1013af6ab5fSopenharmony_ci } 1023af6ab5fSopenharmony_ci 1033af6ab5fSopenharmony_ci const IrCheckHelper *GetIrCheckHelper() const 1043af6ab5fSopenharmony_ci { 1053af6ab5fSopenharmony_ci return &irCheckHelper_; 1063af6ab5fSopenharmony_ci } 1073af6ab5fSopenharmony_ci 1083af6ab5fSopenharmony_ci DebugInfoStorage *GetDebugInfoStorage() 1093af6ab5fSopenharmony_ci { 1103af6ab5fSopenharmony_ci return &debugInfoStorage_; 1113af6ab5fSopenharmony_ci } 1123af6ab5fSopenharmony_ci 1133af6ab5fSopenharmony_ci const DebugInfoStorage *GetDebugInfoStorage() const 1143af6ab5fSopenharmony_ci { 1153af6ab5fSopenharmony_ci return &debugInfoStorage_; 1163af6ab5fSopenharmony_ci } 1173af6ab5fSopenharmony_ci 1183af6ab5fSopenharmony_ci ProxyProgramsCache *GetProxyProgramsCache() 1193af6ab5fSopenharmony_ci { 1203af6ab5fSopenharmony_ci return &proxyProgramsCache_; 1213af6ab5fSopenharmony_ci } 1223af6ab5fSopenharmony_ci 1233af6ab5fSopenharmony_ci const ProxyProgramsCache *GetProxyProgramsCache() const 1243af6ab5fSopenharmony_ci { 1253af6ab5fSopenharmony_ci return &proxyProgramsCache_; 1263af6ab5fSopenharmony_ci } 1273af6ab5fSopenharmony_ci 1283af6ab5fSopenharmony_ci EntityDeclarator *GetEntityDeclarator() 1293af6ab5fSopenharmony_ci { 1303af6ab5fSopenharmony_ci return &entityDeclarator_; 1313af6ab5fSopenharmony_ci } 1323af6ab5fSopenharmony_ci 1333af6ab5fSopenharmony_ci const EntityDeclarator *GetEntityDeclarator() const 1343af6ab5fSopenharmony_ci { 1353af6ab5fSopenharmony_ci return &entityDeclarator_; 1363af6ab5fSopenharmony_ci } 1373af6ab5fSopenharmony_ci 1383af6ab5fSopenharmony_ci DebugInfoDeserializer *GetDebugInfoDeserializer() 1393af6ab5fSopenharmony_ci { 1403af6ab5fSopenharmony_ci return &debugInfoDeserializer_; 1413af6ab5fSopenharmony_ci } 1423af6ab5fSopenharmony_ci 1433af6ab5fSopenharmony_ci const DebugInfoDeserializer *GetDebugInfoDeserializer() const 1443af6ab5fSopenharmony_ci { 1453af6ab5fSopenharmony_ci return &debugInfoDeserializer_; 1463af6ab5fSopenharmony_ci } 1473af6ab5fSopenharmony_ci 1483af6ab5fSopenharmony_ci varbinder::ETSBinder *GetETSBinder(); 1493af6ab5fSopenharmony_ci 1503af6ab5fSopenharmony_ciprivate: 1513af6ab5fSopenharmony_ci using PrologueEpiloguePair = std::pair<ArenaVector<ir::Statement *>, ArenaVector<ir::Statement *>>; 1523af6ab5fSopenharmony_ci using PrologueEpilogueMap = ArenaUnorderedMap<ir::BlockStatement *, PrologueEpiloguePair>; 1533af6ab5fSopenharmony_ci 1543af6ab5fSopenharmony_ciprivate: 1553af6ab5fSopenharmony_ci /** 1563af6ab5fSopenharmony_ci * @brief Asserts correctness of input options. 1573af6ab5fSopenharmony_ci */ 1583af6ab5fSopenharmony_ci void ValidateEvaluationOptions(const CompilerOptions &options); 1593af6ab5fSopenharmony_ci 1603af6ab5fSopenharmony_ci /** 1613af6ab5fSopenharmony_ci * @brief Creates `Program` instances for each input context .abc file. 1623af6ab5fSopenharmony_ci */ 1633af6ab5fSopenharmony_ci void CreateContextPrograms(); 1643af6ab5fSopenharmony_ci 1653af6ab5fSopenharmony_ci /** 1663af6ab5fSopenharmony_ci * @brief Creates a program with the given package name and adds it as external for the given global program. 1673af6ab5fSopenharmony_ci * This method must be called once and before running any compiler phases. 1683af6ab5fSopenharmony_ci * @param sourceFilePath corresponding to source code of one of the provided .abc files. 1693af6ab5fSopenharmony_ci * @param moduleName of source file, extracted from .abc file encoding. 1703af6ab5fSopenharmony_ci * @returns pointer to initialized program. 1713af6ab5fSopenharmony_ci */ 1723af6ab5fSopenharmony_ci parser::Program *CreateEmptyProgram(std::string_view sourceFilePath, std::string_view moduleName); 1733af6ab5fSopenharmony_ci 1743af6ab5fSopenharmony_ci /** 1753af6ab5fSopenharmony_ci * @brief Returns non-null program for the given source file path. 1763af6ab5fSopenharmony_ci */ 1773af6ab5fSopenharmony_ci parser::Program *GetProgram(util::StringView fileName); 1783af6ab5fSopenharmony_ci 1793af6ab5fSopenharmony_ci parser::Program *GetEvaluatedExpressionProgram(); 1803af6ab5fSopenharmony_ci 1813af6ab5fSopenharmony_ci /// Search methods. 1823af6ab5fSopenharmony_ci varbinder::Variable *FindGlobalVariable(ir::Identifier *ident); 1833af6ab5fSopenharmony_ci varbinder::Variable *FindGlobalFunction(ir::Identifier *ident); 1843af6ab5fSopenharmony_ci varbinder::Variable *FindLocalVariable(ir::Identifier *ident); 1853af6ab5fSopenharmony_ci 1863af6ab5fSopenharmony_ci /** 1873af6ab5fSopenharmony_ci * @brief Pushes back return statement into the evaluation method 1883af6ab5fSopenharmony_ci * if its last statement potentially returns a primitive value. 1893af6ab5fSopenharmony_ci * @returns true if insertion took place, false otherwise. 1903af6ab5fSopenharmony_ci */ 1913af6ab5fSopenharmony_ci bool InsertReturnStatement(); 1923af6ab5fSopenharmony_ci 1933af6ab5fSopenharmony_ci ArenaAllocator *Allocator(); 1943af6ab5fSopenharmony_ci 1953af6ab5fSopenharmony_ciprivate: 1963af6ab5fSopenharmony_ci parser::Program *globalProgram_ {nullptr}; 1973af6ab5fSopenharmony_ci checker::ETSChecker *checker_ {nullptr}; 1983af6ab5fSopenharmony_ci 1993af6ab5fSopenharmony_ci EvaluateContext context_; 2003af6ab5fSopenharmony_ci 2013af6ab5fSopenharmony_ci IrCheckHelper irCheckHelper_; 2023af6ab5fSopenharmony_ci DebugInfoStorage debugInfoStorage_; 2033af6ab5fSopenharmony_ci DebugInfoDeserializer debugInfoDeserializer_; 2043af6ab5fSopenharmony_ci PathResolver pathResolver_; 2053af6ab5fSopenharmony_ci PrologueEpilogueMap prologueEpilogueMap_; 2063af6ab5fSopenharmony_ci ProxyProgramsCache proxyProgramsCache_; 2073af6ab5fSopenharmony_ci EntityDeclarator entityDeclarator_; 2083af6ab5fSopenharmony_ci}; 2093af6ab5fSopenharmony_ci 2103af6ab5fSopenharmony_ci} // namespace ark::es2panda::evaluate 2113af6ab5fSopenharmony_ci 2123af6ab5fSopenharmony_ci#endif // ES2PANDA_EVALUATE_SCOPED_DEBUG_INFO_PLUGIN_H 213