arkanalyzer 1.0.85 → 1.0.87
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.en.md +69 -65
- package/README.md +56 -70
- package/config/arkanalyzer.json +7 -2
- package/docs/cppFrontend/ArkAnalyzer-cpp_usage_guide.md +245 -0
- package/docs/cppFrontend/cpp_frontend_build_guide.md +126 -0
- package/docs/cppFrontend/cpp_frontend_user_guide.md +175 -0
- package/docs/cppFrontend/img.png +0 -0
- package/docs/cppFrontend/img_1.png +0 -0
- package/docs/cppFrontend/img_10.png +0 -0
- package/docs/cppFrontend/img_11.png +0 -0
- package/docs/cppFrontend/img_12.png +0 -0
- package/docs/cppFrontend/img_13.png +0 -0
- package/docs/cppFrontend/img_14.png +0 -0
- package/docs/cppFrontend/img_15.png +0 -0
- package/docs/cppFrontend/img_16.png +0 -0
- package/docs/cppFrontend/img_17.png +0 -0
- package/docs/cppFrontend/img_18.png +0 -0
- package/docs/cppFrontend/img_19.png +0 -0
- package/docs/cppFrontend/img_2.png +0 -0
- package/docs/cppFrontend/img_20.png +0 -0
- package/docs/cppFrontend/img_21.png +0 -0
- package/docs/cppFrontend/img_22.png +0 -0
- package/docs/cppFrontend/img_23.png +0 -0
- package/docs/cppFrontend/img_3.png +0 -0
- package/docs/cppFrontend/img_4.png +0 -0
- package/docs/cppFrontend/img_5.png +0 -0
- package/docs/cppFrontend/img_6.png +0 -0
- package/docs/cppFrontend/img_7.png +0 -0
- package/docs/cppFrontend/img_8.png +0 -0
- package/docs/cppFrontend/img_9.png +0 -0
- package/docs/sig_programanalysis.en.md +66 -0
- package/docs/sig_programanalysis.md +73 -0
- package/lib/Config.d.ts +32 -1
- package/lib/Config.d.ts.map +1 -1
- package/lib/Config.js +76 -2
- package/lib/Scene.d.ts +25 -2
- package/lib/Scene.d.ts.map +1 -1
- package/lib/Scene.js +148 -40
- package/lib/callgraph/algorithm/AbstractAnalysis.d.ts +4 -3
- package/lib/callgraph/algorithm/AbstractAnalysis.d.ts.map +1 -1
- package/lib/callgraph/algorithm/AbstractAnalysis.js +17 -17
- package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts +6 -1
- package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts.map +1 -1
- package/lib/callgraph/algorithm/RapidTypeAnalysis.js +117 -14
- package/lib/callgraph/common/Statistics.d.ts +4 -2
- package/lib/callgraph/common/Statistics.d.ts.map +1 -1
- package/lib/callgraph/common/Statistics.js +14 -2
- package/lib/callgraph/model/CallGraph.d.ts +12 -8
- package/lib/callgraph/model/CallGraph.d.ts.map +1 -1
- package/lib/callgraph/model/CallGraph.js +53 -29
- package/lib/callgraph/model/builder/CallGraphBuilder.d.ts +1 -0
- package/lib/callgraph/model/builder/CallGraphBuilder.d.ts.map +1 -1
- package/lib/callgraph/model/builder/CallGraphBuilder.js +5 -1
- package/lib/callgraph/pointerAnalysis/Pag.d.ts.map +1 -1
- package/lib/callgraph/pointerAnalysis/Pag.js +3 -0
- package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +4 -2
- package/lib/cli/cli.d.ts +3 -0
- package/lib/cli/cli.d.ts.map +1 -0
- package/lib/cli/cli.js +82 -0
- package/lib/cli/commands/cg.d.ts +32 -0
- package/lib/cli/commands/cg.d.ts.map +1 -0
- package/lib/cli/commands/cg.js +401 -0
- package/lib/cli/commands/index.d.ts +6 -0
- package/lib/cli/commands/index.d.ts.map +1 -0
- package/lib/cli/commands/index.js +64 -0
- package/lib/cli/commands/ir.d.ts +26 -0
- package/lib/cli/commands/ir.d.ts.map +1 -0
- package/lib/cli/commands/ir.js +94 -0
- package/lib/core/base/Constant.d.ts +1 -1
- package/lib/core/base/Constant.d.ts.map +1 -1
- package/lib/core/base/Constant.js +1 -1
- package/lib/core/base/Expr.d.ts +29 -5
- package/lib/core/base/Expr.d.ts.map +1 -1
- package/lib/core/base/Expr.js +144 -22
- package/lib/core/base/Position.d.ts +14 -0
- package/lib/core/base/Position.d.ts.map +1 -1
- package/lib/core/base/Position.js +27 -0
- package/lib/core/base/Ref.d.ts +1 -0
- package/lib/core/base/Ref.d.ts.map +1 -1
- package/lib/core/base/Ref.js +4 -1
- package/lib/core/base/Type.d.ts +64 -24
- package/lib/core/base/Type.d.ts.map +1 -1
- package/lib/core/base/Type.js +144 -49
- package/lib/core/common/ArkError.d.ts +26 -2
- package/lib/core/common/ArkError.d.ts.map +1 -1
- package/lib/core/common/ArkError.js +56 -2
- package/lib/core/common/ArkIRTransformer.d.ts +11 -10
- package/lib/core/common/ArkIRTransformer.d.ts.map +1 -1
- package/lib/core/common/ArkIRTransformer.js +1 -1
- package/lib/core/common/ArkValueTransformer.d.ts +14 -12
- package/lib/core/common/ArkValueTransformer.d.ts.map +1 -1
- package/lib/core/common/ArkValueTransformer.js +1 -5
- package/lib/core/common/Const.d.ts +3 -0
- package/lib/core/common/Const.d.ts.map +1 -1
- package/lib/core/common/Const.js +4 -1
- package/lib/core/common/DummyMainCreater.d.ts +23 -13
- package/lib/core/common/DummyMainCreater.d.ts.map +1 -1
- package/lib/core/common/DummyMainCreater.js +66 -43
- package/lib/core/common/EtsConst.d.ts +11 -0
- package/lib/core/common/EtsConst.d.ts.map +1 -1
- package/lib/core/common/EtsConst.js +12 -1
- package/lib/core/common/IRInference.d.ts.map +1 -1
- package/lib/core/common/IRInference.js +5 -1
- package/lib/core/common/ModelUtils.d.ts +4 -7
- package/lib/core/common/ModelUtils.d.ts.map +1 -1
- package/lib/core/common/ModelUtils.js +77 -110
- package/lib/core/common/SdkUtils.d.ts +1 -1
- package/lib/core/common/SdkUtils.d.ts.map +1 -1
- package/lib/core/common/SdkUtils.js +14 -5
- package/lib/core/common/TypeInference.d.ts.map +1 -1
- package/lib/core/common/TypeInference.js +9 -3
- package/lib/core/graph/BaseExplicitGraph.d.ts +4 -4
- package/lib/core/graph/BaseExplicitGraph.d.ts.map +1 -1
- package/lib/core/graph/BaseExplicitGraph.js +15 -8
- package/lib/core/graph/BasicBlock.d.ts.map +1 -1
- package/lib/core/graph/Scc.d.ts.map +1 -1
- package/lib/core/graph/Scc.js +7 -2
- package/lib/core/graph/builder/CfgBuilder.d.ts +10 -7
- package/lib/core/graph/builder/CfgBuilder.d.ts.map +1 -1
- package/lib/core/graph/builder/CfgBuilder.js +12 -5
- package/lib/core/inference/Inference.d.ts.map +1 -1
- package/lib/core/inference/Inference.js +7 -0
- package/lib/core/inference/ModelInference.d.ts +1 -1
- package/lib/core/inference/ModelInference.d.ts.map +1 -1
- package/lib/core/inference/ValueInference.d.ts +3 -2
- package/lib/core/inference/ValueInference.d.ts.map +1 -1
- package/lib/core/inference/ValueInference.js +64 -12
- package/lib/core/inference/abc/AbcInference.d.ts +28 -2
- package/lib/core/inference/abc/AbcInference.d.ts.map +1 -1
- package/lib/core/inference/abc/AbcInference.js +105 -4
- package/lib/core/model/ArkBaseModel.d.ts +14 -1
- package/lib/core/model/ArkBaseModel.d.ts.map +1 -1
- package/lib/core/model/ArkBaseModel.js +61 -2
- package/lib/core/model/ArkBody.d.ts.map +1 -1
- package/lib/core/model/ArkBody.js +1 -3
- package/lib/core/model/ArkClass.d.ts +22 -2
- package/lib/core/model/ArkClass.d.ts.map +1 -1
- package/lib/core/model/ArkClass.js +59 -28
- package/lib/core/model/ArkField.d.ts.map +1 -1
- package/lib/core/model/ArkField.js +3 -1
- package/lib/core/model/ArkFile.d.ts +4 -1
- package/lib/core/model/ArkFile.d.ts.map +1 -1
- package/lib/core/model/ArkFile.js +44 -3
- package/lib/core/model/ArkImport.d.ts.map +1 -1
- package/lib/core/model/ArkImport.js +9 -1
- package/lib/core/model/ArkMethod.d.ts +5 -0
- package/lib/core/model/ArkMethod.d.ts.map +1 -1
- package/lib/core/model/ArkMethod.js +33 -1
- package/lib/core/model/ArkNamespace.d.ts +2 -0
- package/lib/core/model/ArkNamespace.d.ts.map +1 -1
- package/lib/core/model/ArkNamespace.js +11 -0
- package/lib/core/model/ArkSignature.d.ts +3 -3
- package/lib/core/model/ArkSignature.d.ts.map +1 -1
- package/lib/core/model/ArkSignature.js +14 -9
- package/lib/core/model/builder/ArkClassBuilder.d.ts +2 -0
- package/lib/core/model/builder/ArkClassBuilder.d.ts.map +1 -1
- package/lib/core/model/builder/ArkClassBuilder.js +3 -3
- package/lib/core/model/builder/ArkMethodBuilder.d.ts +4 -1
- package/lib/core/model/builder/ArkMethodBuilder.d.ts.map +1 -1
- package/lib/core/model/builder/ArkMethodBuilder.js +19 -6
- package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +1 -0
- package/lib/core/model/builder/ArkNamespaceBuilder.d.ts.map +1 -1
- package/lib/core/model/builder/ArkNamespaceBuilder.js +2 -1
- package/lib/core/model/builder/BodyBuilder.d.ts +4 -0
- package/lib/core/model/builder/BodyBuilder.d.ts.map +1 -1
- package/lib/core/model/builder/builderUtils.d.ts +1 -0
- package/lib/core/model/builder/builderUtils.d.ts.map +1 -1
- package/lib/core/model/builder/builderUtils.js +7 -3
- package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.d.ts +296 -0
- package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.js +145 -0
- package/lib/frontend/cppFrontend/ast/astUtils.d.ts +51 -0
- package/lib/frontend/cppFrontend/ast/astUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/astUtils.js +470 -0
- package/lib/frontend/cppFrontend/ast/const.d.ts +30 -0
- package/lib/frontend/cppFrontend/ast/const.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/const.js +134 -0
- package/lib/frontend/cppFrontend/base/Constant.d.ts +9 -0
- package/lib/frontend/cppFrontend/base/Constant.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/base/Constant.js +33 -0
- package/lib/frontend/cppFrontend/base/Expr.d.ts +174 -0
- package/lib/frontend/cppFrontend/base/Expr.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/base/Expr.js +530 -0
- package/lib/frontend/cppFrontend/base/Ref.d.ts +25 -0
- package/lib/frontend/cppFrontend/base/Ref.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/base/Ref.js +53 -0
- package/lib/frontend/cppFrontend/base/Trap.d.ts +8 -0
- package/lib/frontend/cppFrontend/base/Trap.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/base/Trap.js +28 -0
- package/lib/frontend/cppFrontend/base/Type.d.ts +264 -0
- package/lib/frontend/cppFrontend/base/Type.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/base/Type.js +600 -0
- package/lib/frontend/cppFrontend/common/ArkIRTransformer.d.ts +109 -0
- package/lib/frontend/cppFrontend/common/ArkIRTransformer.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/ArkIRTransformer.js +925 -0
- package/lib/frontend/cppFrontend/common/ArkValueTransformer.d.ts +477 -0
- package/lib/frontend/cppFrontend/common/ArkValueTransformer.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/ArkValueTransformer.js +2746 -0
- package/lib/frontend/cppFrontend/common/Builtin.d.ts +57 -0
- package/lib/frontend/cppFrontend/common/Builtin.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/Builtin.js +106 -0
- package/lib/frontend/cppFrontend/common/IRInference.d.ts +94 -0
- package/lib/frontend/cppFrontend/common/IRInference.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/IRInference.js +1087 -0
- package/lib/frontend/cppFrontend/common/IRUtils.d.ts +23 -0
- package/lib/frontend/cppFrontend/common/IRUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/IRUtils.js +168 -0
- package/lib/frontend/cppFrontend/common/ModelUtils.d.ts +44 -0
- package/lib/frontend/cppFrontend/common/ModelUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/ModelUtils.js +567 -0
- package/lib/frontend/cppFrontend/common/TypeInference.d.ts +278 -0
- package/lib/frontend/cppFrontend/common/TypeInference.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/TypeInference.js +1354 -0
- package/lib/frontend/cppFrontend/common/ValueUtil.d.ts +16 -0
- package/lib/frontend/cppFrontend/common/ValueUtil.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/common/ValueUtil.js +61 -0
- package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.d.ts +182 -0
- package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.js +1435 -0
- package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.d.ts +21 -0
- package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.js +303 -0
- package/lib/frontend/cppFrontend/graph/builder/IfBuilder.d.ts +15 -0
- package/lib/frontend/cppFrontend/graph/builder/IfBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/IfBuilder.js +161 -0
- package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.d.ts +21 -0
- package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.js +261 -0
- package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.d.ts +12 -0
- package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.js +155 -0
- package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.d.ts +29 -0
- package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.js +302 -0
- package/lib/frontend/cppFrontend/inference/CxxInference.d.ts +10 -0
- package/lib/frontend/cppFrontend/inference/CxxInference.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/inference/CxxInference.js +41 -0
- package/lib/frontend/cppFrontend/inference/CxxModelInference.d.ts +28 -0
- package/lib/frontend/cppFrontend/inference/CxxModelInference.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/inference/CxxModelInference.js +98 -0
- package/lib/frontend/cppFrontend/inference/CxxValueInference.d.ts +20 -0
- package/lib/frontend/cppFrontend/inference/CxxValueInference.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/inference/CxxValueInference.js +128 -0
- package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.d.ts +11 -0
- package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.js +413 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.d.ts +5 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.js +61 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.d.ts +17 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.js +285 -0
- package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.d.ts +6 -0
- package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.js +57 -0
- package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.d.ts +14 -0
- package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.js +422 -0
- package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.d.ts +8 -0
- package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.js +194 -0
- package/lib/frontend/cppFrontend/model/builder/BodyBuilder.d.ts +59 -0
- package/lib/frontend/cppFrontend/model/builder/BodyBuilder.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/BodyBuilder.js +605 -0
- package/lib/frontend/cppFrontend/model/builder/builderUtils.d.ts +46 -0
- package/lib/frontend/cppFrontend/model/builder/builderUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/model/builder/builderUtils.js +499 -0
- package/lib/frontend/cppFrontend/utils/cmakeUtils.d.ts +44 -0
- package/lib/frontend/cppFrontend/utils/cmakeUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/utils/cmakeUtils.js +240 -0
- package/lib/index.d.ts +1 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +7 -1
- package/lib/node_modules/ohos-typescript/.ohos-typescript-version +1 -0
- package/{node_modules → lib/node_modules}/ohos-typescript/package.json +2 -1
- package/lib/save/CGJsonPrinter.d.ts +8 -0
- package/lib/save/CGJsonPrinter.d.ts.map +1 -0
- package/lib/save/CGJsonPrinter.js +41 -0
- package/lib/save/GraphPrinter.js +2 -2
- package/lib/save/json/JsonDto.d.ts +86 -2
- package/lib/save/json/JsonDto.d.ts.map +1 -1
- package/lib/save/json/JsonSerialization.d.ts +1 -1
- package/lib/save/json/JsonSerialization.d.ts.map +1 -1
- package/lib/save/json/JsonSerialization.js +235 -145
- package/lib/save/source/SourceTransformer.d.ts.map +1 -1
- package/lib/save/source/SourceTransformer.js +0 -3
- package/lib/utils/CxxSceneUtils.d.ts +11 -0
- package/lib/utils/CxxSceneUtils.d.ts.map +1 -0
- package/lib/utils/CxxSceneUtils.js +178 -0
- package/lib/utils/FileUtils.d.ts +7 -8
- package/lib/utils/FileUtils.d.ts.map +1 -1
- package/lib/utils/FileUtils.js +27 -45
- package/lib/utils/LRUCacheDecorator.d.ts +20 -0
- package/lib/utils/LRUCacheDecorator.d.ts.map +1 -0
- package/lib/utils/LRUCacheDecorator.js +89 -0
- package/lib/utils/ModuleUtils.d.ts +39 -0
- package/lib/utils/ModuleUtils.d.ts.map +1 -0
- package/lib/utils/ModuleUtils.js +261 -0
- package/package.json +15 -12
- /package/{node_modules → lib/node_modules}/ohos-typescript/LICENSE +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/README.OpenSource +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/README.md +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/SECURITY.md +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/ThirdPartyNoticeText.txt +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/bin/tsc +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/bin/tsserver +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/README.md +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/cancellationToken.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/cs/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/de/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/es/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/fr/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/it/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ja/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ko/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.dom.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.dom.iterable.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.collection.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.core.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.generator.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.iterable.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.promise.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.proxy.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.reflect.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.symbol.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.symbol.wellknown.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.array.include.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.object.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.sharedmemory.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.string.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.typedarrays.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.asyncgenerator.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.asynciterable.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.promise.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.regexp.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.array.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.object.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.string.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.symbol.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.bigint.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.date.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.number.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.promise.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.sharedmemory.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.string.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.symbol.wellknown.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.promise.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.string.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.weakref.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.array.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.error.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.object.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.sharedmemory.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.string.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es5.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es6.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.full.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.intl.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.scripthost.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.importscripts.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.iterable.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/pl/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/pt-br/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ru/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tr/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsc.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserver.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserverlibrary.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserverlibrary.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typesMap.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typescript.d.ts +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typescript.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typingsInstaller.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/watchGuard.js +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/zh-cn/diagnosticMessages.generated.json +0 -0
- /package/{node_modules → lib/node_modules}/ohos-typescript/lib/zh-tw/diagnosticMessages.generated.json +0 -0
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2025 Huawei Device Co., Ltd.
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.CxxLoopBuilder = void 0;
|
|
18
|
+
const BasicBlock_1 = require("../../../../core/graph/BasicBlock");
|
|
19
|
+
const Stmt_1 = require("../../../../core/base/Stmt");
|
|
20
|
+
const Expr_1 = require("../../../../core/base/Expr");
|
|
21
|
+
const Builtin_1 = require("../../common/Builtin");
|
|
22
|
+
const CfgBuilder_1 = require("./CfgBuilder");
|
|
23
|
+
const ArkIRTransformer_1 = require("../../../../core/common/ArkIRTransformer");
|
|
24
|
+
const ArkIRTransformer_2 = require("../../common/ArkIRTransformer");
|
|
25
|
+
/**
|
|
26
|
+
* Builder for loop in CFG
|
|
27
|
+
*/
|
|
28
|
+
class CxxLoopBuilder {
|
|
29
|
+
rebuildBlocksInLoop(blockBuilderToCfgBlock, blocksContainLoopCondition, basicBlockSet, blockBuilders) {
|
|
30
|
+
for (const blockBuilder of blocksContainLoopCondition) {
|
|
31
|
+
if (!blockBuilderToCfgBlock.get(blockBuilder)) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
const block = blockBuilderToCfgBlock.get(blockBuilder);
|
|
35
|
+
const blockId = block.getId();
|
|
36
|
+
const stmts = block.getStmts();
|
|
37
|
+
const stmtsCnt = stmts.length;
|
|
38
|
+
const { ifStmtIdx, iteratorNextStmtIdx, dummyInitializerStmtIdx } = this.findIteratorIdx(stmts);
|
|
39
|
+
if (iteratorNextStmtIdx !== -1 || dummyInitializerStmtIdx !== -1) {
|
|
40
|
+
const stmtsInsertBeforeCondition = stmts.slice(0, dummyInitializerStmtIdx);
|
|
41
|
+
// If the loop body is empty, the loop conditional block should contain its own
|
|
42
|
+
const emptyLoopBody = blockBuilder.nexts.length === 1;
|
|
43
|
+
if (emptyLoopBody) {
|
|
44
|
+
blockBuilder.nexts.splice(0, 0, blockBuilder);
|
|
45
|
+
blockBuilder.lasts.push(blockBuilder);
|
|
46
|
+
block.getSuccessors().splice(0, 0, block);
|
|
47
|
+
block.addPredecessorBlock(block);
|
|
48
|
+
}
|
|
49
|
+
let prevBlockBuilderContainsLoop = this.doesPrevBlockBuilderContainLoop(blockBuilder, blockId, blocksContainLoopCondition);
|
|
50
|
+
if (prevBlockBuilderContainsLoop) {
|
|
51
|
+
// should create an extra block when previous block contains loop condition
|
|
52
|
+
this.insertBeforeConditionBlockBuilder(blockBuilderToCfgBlock, blockBuilder, stmtsInsertBeforeCondition, false, basicBlockSet, blockBuilders);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
const blockBuilderBeforeCondition = blockBuilder.lasts[0];
|
|
56
|
+
const blockBeforeCondition = blockBuilderToCfgBlock.get(blockBuilderBeforeCondition);
|
|
57
|
+
stmtsInsertBeforeCondition.forEach(stmt => blockBeforeCondition === null || blockBeforeCondition === void 0 ? void 0 : blockBeforeCondition.getStmts().push(stmt));
|
|
58
|
+
}
|
|
59
|
+
if (iteratorNextStmtIdx !== -1 && dummyInitializerStmtIdx !== -1) {
|
|
60
|
+
// put statements which get value of iterator into block after condition
|
|
61
|
+
const blockBuilderAfterCondition = blockBuilder.nexts[0];
|
|
62
|
+
const blockAfterCondition = blockBuilderToCfgBlock.get(blockBuilderAfterCondition);
|
|
63
|
+
const stmtsAfterCondition = stmts.slice(iteratorNextStmtIdx + 1);
|
|
64
|
+
blockAfterCondition === null || blockAfterCondition === void 0 ? void 0 : blockAfterCondition.getStmts().splice(0, 0, ...stmtsAfterCondition);
|
|
65
|
+
const iteratorStmts = stmts[iteratorNextStmtIdx];
|
|
66
|
+
blockAfterCondition === null || blockAfterCondition === void 0 ? void 0 : blockAfterCondition.getStmts().push(iteratorStmts);
|
|
67
|
+
}
|
|
68
|
+
else if (dummyInitializerStmtIdx !== -1 && ifStmtIdx !== stmtsCnt - 1) {
|
|
69
|
+
// put incrementor statements into block which reenters condition
|
|
70
|
+
this.adjustIncrementorStmts(stmts, ifStmtIdx, blockBuilder, blockId, blockBuilderToCfgBlock, blocksContainLoopCondition, basicBlockSet, emptyLoopBody, blockBuilders);
|
|
71
|
+
}
|
|
72
|
+
// remove statements which should not in condition
|
|
73
|
+
const firstStmtIdxInCondition = dummyInitializerStmtIdx + 1;
|
|
74
|
+
stmts.splice(0, firstStmtIdxInCondition);
|
|
75
|
+
stmts.splice(ifStmtIdx - firstStmtIdxInCondition + 1);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
doesPrevBlockBuilderContainLoop(currBlockBuilder, currBlockId, blocksContainLoopCondition) {
|
|
80
|
+
let prevBlockBuilderContainsLoop = false;
|
|
81
|
+
for (const prevBlockBuilder of currBlockBuilder.lasts) {
|
|
82
|
+
if (prevBlockBuilder.id < currBlockId && blocksContainLoopCondition.has(prevBlockBuilder)) {
|
|
83
|
+
prevBlockBuilderContainsLoop = true;
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return prevBlockBuilderContainsLoop;
|
|
88
|
+
}
|
|
89
|
+
insertBeforeConditionBlockBuilder(blockBuilderToCfgBlock, conditionBlockBuilder, stmtsInsertBeforeCondition, collectReenter, basicBlockSet, blockBuilders) {
|
|
90
|
+
if (stmtsInsertBeforeCondition.length === 0) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const blockId = conditionBlockBuilder.id;
|
|
94
|
+
const block = this.getBlockFromMap(blockBuilderToCfgBlock, conditionBlockBuilder);
|
|
95
|
+
const { blockBuildersBeforeCondition, blocksBeforeCondition, blockBuildersReenterCondition, blocksReenterCondition, } = this.collectBlocksBeforeAndReenter(blockBuilderToCfgBlock, conditionBlockBuilder, blockId);
|
|
96
|
+
const { collectedBlockBuilders, collectedBlocks } = this.getCollectedBlocks(collectReenter, blockBuildersBeforeCondition, blocksBeforeCondition, blockBuildersReenterCondition, blocksReenterCondition);
|
|
97
|
+
const { blockBuilderInsertBeforeCondition, blockInsertBeforeCondition } = this.createAndLinkBlocks(collectedBlockBuilders, collectedBlocks, conditionBlockBuilder, stmtsInsertBeforeCondition, block);
|
|
98
|
+
this.updatePredecessors(collectedBlockBuilders, blockBuilderToCfgBlock, conditionBlockBuilder, blockBuilderInsertBeforeCondition, blockInsertBeforeCondition);
|
|
99
|
+
const { newPrevBlockBuildersBeforeCondition, newPrevBlocksBeforeCondition } = this.getNewPrevBlocks(collectReenter, blockBuildersBeforeCondition, blocksBeforeCondition, blockBuilderInsertBeforeCondition, blockInsertBeforeCondition, blockBuildersReenterCondition, blocksReenterCondition);
|
|
100
|
+
this.updateConditionBlockBuilder(conditionBlockBuilder, newPrevBlockBuildersBeforeCondition, block, newPrevBlocksBeforeCondition);
|
|
101
|
+
this.finalizeInsertion(blockBuilderInsertBeforeCondition, blockInsertBeforeCondition, basicBlockSet, blockBuilderToCfgBlock, blockBuilders);
|
|
102
|
+
}
|
|
103
|
+
getBlockFromMap(blockBuilderToCfgBlock, conditionBlockBuilder) {
|
|
104
|
+
return blockBuilderToCfgBlock.get(conditionBlockBuilder);
|
|
105
|
+
}
|
|
106
|
+
collectBlocksBeforeAndReenter(blockBuilderToCfgBlock, conditionBlockBuilder, blockId) {
|
|
107
|
+
const blockBuildersBeforeCondition = [];
|
|
108
|
+
const blocksBeforeCondition = [];
|
|
109
|
+
const blockBuildersReenterCondition = [];
|
|
110
|
+
const blocksReenterCondition = [];
|
|
111
|
+
for (const prevBlockBuilder of conditionBlockBuilder.lasts) {
|
|
112
|
+
const prevBlock = blockBuilderToCfgBlock.get(prevBlockBuilder);
|
|
113
|
+
if (prevBlock.getId() < blockId) {
|
|
114
|
+
blockBuildersBeforeCondition.push(prevBlockBuilder);
|
|
115
|
+
blocksBeforeCondition.push(prevBlock);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
blockBuildersReenterCondition.push(prevBlockBuilder);
|
|
119
|
+
blocksReenterCondition.push(prevBlock);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return {
|
|
123
|
+
blockBuildersBeforeCondition,
|
|
124
|
+
blocksBeforeCondition,
|
|
125
|
+
blockBuildersReenterCondition,
|
|
126
|
+
blocksReenterCondition,
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
getCollectedBlocks(collectReenter, blockBuildersBeforeCondition, blocksBeforeCondition, blockBuildersReenterCondition, blocksReenterCondition) {
|
|
130
|
+
let collectedBlockBuilders = [];
|
|
131
|
+
let collectedBlocks = [];
|
|
132
|
+
if (collectReenter) {
|
|
133
|
+
collectedBlockBuilders = blockBuildersReenterCondition;
|
|
134
|
+
collectedBlocks = blocksReenterCondition;
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
collectedBlockBuilders = blockBuildersBeforeCondition;
|
|
138
|
+
collectedBlocks = blocksBeforeCondition;
|
|
139
|
+
}
|
|
140
|
+
return { collectedBlockBuilders, collectedBlocks };
|
|
141
|
+
}
|
|
142
|
+
createAndLinkBlocks(collectedBlockBuilders, collectedBlocks, conditionBlockBuilder, stmtsInsertBeforeCondition, block) {
|
|
143
|
+
const blockBuilderInsertBeforeCondition = new CfgBuilder_1.BlockBuilder(-1, []);
|
|
144
|
+
blockBuilderInsertBeforeCondition.lasts.push(...collectedBlockBuilders);
|
|
145
|
+
blockBuilderInsertBeforeCondition.nexts.push(conditionBlockBuilder);
|
|
146
|
+
const blockInsertBeforeCondition = new BasicBlock_1.BasicBlock();
|
|
147
|
+
stmtsInsertBeforeCondition.forEach(stmt => blockInsertBeforeCondition.getStmts().push(stmt));
|
|
148
|
+
blockInsertBeforeCondition.getPredecessors().push(...collectedBlocks);
|
|
149
|
+
blockInsertBeforeCondition.addSuccessorBlock(block);
|
|
150
|
+
return { blockBuilderInsertBeforeCondition, blockInsertBeforeCondition };
|
|
151
|
+
}
|
|
152
|
+
updatePredecessors(collectedBlockBuilders, blockBuilderToCfgBlock, conditionBlockBuilder, blockBuilderInsertBeforeCondition, blockInsertBeforeCondition) {
|
|
153
|
+
for (const prevBlockBuilder of collectedBlockBuilders) {
|
|
154
|
+
const prevBlock = blockBuilderToCfgBlock.get(prevBlockBuilder);
|
|
155
|
+
for (let j = 0; j < prevBlockBuilder.nexts.length; j++) {
|
|
156
|
+
if (prevBlockBuilder.nexts[j] === conditionBlockBuilder) {
|
|
157
|
+
prevBlockBuilder.nexts[j] = blockBuilderInsertBeforeCondition;
|
|
158
|
+
prevBlock.setSuccessorBlock(j, blockInsertBeforeCondition);
|
|
159
|
+
break;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
getNewPrevBlocks(collectReenter, blockBuildersBeforeCondition, blocksBeforeCondition, blockBuilderInsertBeforeCondition, blockInsertBeforeCondition, blockBuildersReenterCondition, blocksReenterCondition) {
|
|
165
|
+
let newPrevBlockBuildersBeforeCondition = [];
|
|
166
|
+
let newPrevBlocksBeforeCondition = [];
|
|
167
|
+
if (collectReenter) {
|
|
168
|
+
newPrevBlockBuildersBeforeCondition = [...blockBuildersBeforeCondition, blockBuilderInsertBeforeCondition];
|
|
169
|
+
newPrevBlocksBeforeCondition = [...blocksBeforeCondition, blockInsertBeforeCondition];
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
newPrevBlockBuildersBeforeCondition = [blockBuilderInsertBeforeCondition, ...blockBuildersReenterCondition];
|
|
173
|
+
newPrevBlocksBeforeCondition = [blockInsertBeforeCondition, ...blocksReenterCondition];
|
|
174
|
+
}
|
|
175
|
+
return {
|
|
176
|
+
newPrevBlockBuildersBeforeCondition,
|
|
177
|
+
newPrevBlocksBeforeCondition,
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
updateConditionBlockBuilder(conditionBlockBuilder, newPrevBlockBuildersBeforeCondition, block, newPrevBlocksBeforeCondition) {
|
|
181
|
+
conditionBlockBuilder.lasts = newPrevBlockBuildersBeforeCondition;
|
|
182
|
+
const predecessorsCnt = block.getPredecessors().length;
|
|
183
|
+
block.getPredecessors().splice(0, predecessorsCnt, ...newPrevBlocksBeforeCondition);
|
|
184
|
+
}
|
|
185
|
+
finalizeInsertion(blockBuilderInsertBeforeCondition, blockInsertBeforeCondition, basicBlockSet, blockBuilderToCfgBlock, blockBuilders) {
|
|
186
|
+
blockBuilders.push(blockBuilderInsertBeforeCondition);
|
|
187
|
+
basicBlockSet.add(blockInsertBeforeCondition);
|
|
188
|
+
blockBuilderToCfgBlock.set(blockBuilderInsertBeforeCondition, blockInsertBeforeCondition);
|
|
189
|
+
}
|
|
190
|
+
findIteratorIdx(stmts) {
|
|
191
|
+
var _a;
|
|
192
|
+
let ifStmtIdx = -1;
|
|
193
|
+
let iteratorNextStmtIdx = -1;
|
|
194
|
+
let dummyInitializerStmtIdx = -1;
|
|
195
|
+
const stmtsCnt = stmts.length;
|
|
196
|
+
for (let i = 0; i < stmtsCnt; i++) {
|
|
197
|
+
const stmt = stmts[i];
|
|
198
|
+
if (stmt instanceof Stmt_1.ArkAssignStmt && stmt.getRightOp() instanceof Expr_1.ArkInstanceInvokeExpr) {
|
|
199
|
+
const invokeExpr = stmt.getRightOp();
|
|
200
|
+
if (invokeExpr.getMethodSignature().getMethodSubSignature().getMethodName() === Builtin_1.BuiltinCxx.ITERATOR_NEXT) {
|
|
201
|
+
iteratorNextStmtIdx = i;
|
|
202
|
+
continue;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
if (stmt.toString() === ArkIRTransformer_1.ArkIRTransformer.DUMMY_LOOP_INITIALIZER_STMT) {
|
|
206
|
+
dummyInitializerStmtIdx = i;
|
|
207
|
+
continue;
|
|
208
|
+
}
|
|
209
|
+
if (stmt instanceof Stmt_1.ArkIfStmt) {
|
|
210
|
+
ifStmtIdx = i;
|
|
211
|
+
}
|
|
212
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt && ((_a = stmt.toString()) === null || _a === void 0 ? void 0 : _a.startsWith(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END))) {
|
|
213
|
+
ifStmtIdx = i;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
return {
|
|
217
|
+
ifStmtIdx: ifStmtIdx,
|
|
218
|
+
iteratorNextStmtIdx: iteratorNextStmtIdx,
|
|
219
|
+
dummyInitializerStmtIdx: dummyInitializerStmtIdx,
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
adjustIncrementorStmts(stmts, ifStmtIdx, currBlockBuilder, currBlockId, blockBuilderToCfgBlock, blocksContainLoopCondition, basicBlockSet, emptyLoopBody, blockBuilders) {
|
|
223
|
+
const stmtsReenterCondition = stmts.slice(ifStmtIdx + 1);
|
|
224
|
+
if (emptyLoopBody) {
|
|
225
|
+
const incrementorBlockBuilder = new CfgBuilder_1.BlockBuilder(-1, []);
|
|
226
|
+
incrementorBlockBuilder.lasts.push(currBlockBuilder);
|
|
227
|
+
currBlockBuilder.nexts[0] = incrementorBlockBuilder;
|
|
228
|
+
incrementorBlockBuilder.nexts.push(currBlockBuilder);
|
|
229
|
+
currBlockBuilder.lasts[1] = incrementorBlockBuilder;
|
|
230
|
+
const incrementorBlock = new BasicBlock_1.BasicBlock();
|
|
231
|
+
blockBuilderToCfgBlock.set(incrementorBlockBuilder, incrementorBlock);
|
|
232
|
+
stmtsReenterCondition.forEach(stmt => incrementorBlock.getStmts().push(stmt));
|
|
233
|
+
const currBlock = blockBuilderToCfgBlock.get(currBlockBuilder);
|
|
234
|
+
incrementorBlock.getPredecessors().push(currBlock);
|
|
235
|
+
currBlock.setPredecessorBlock(1, incrementorBlock);
|
|
236
|
+
incrementorBlock.addSuccessorBlock(currBlock);
|
|
237
|
+
currBlock.setSuccessorBlock(0, incrementorBlock);
|
|
238
|
+
basicBlockSet.add(incrementorBlock);
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
const blockBuildersReenterCondition = [];
|
|
242
|
+
for (const prevBlockBuilder of currBlockBuilder.lasts) {
|
|
243
|
+
const prevBlock = blockBuilderToCfgBlock.get(prevBlockBuilder);
|
|
244
|
+
if (prevBlock.getId() > currBlockId) {
|
|
245
|
+
blockBuildersReenterCondition.push(prevBlockBuilder);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
if (blockBuildersReenterCondition.length > 1 ||
|
|
249
|
+
blockBuildersReenterCondition[0].nexts.length > 1 ||
|
|
250
|
+
blocksContainLoopCondition.has(blockBuildersReenterCondition[0])) {
|
|
251
|
+
// put incrementor statements into an extra block
|
|
252
|
+
this.insertBeforeConditionBlockBuilder(blockBuilderToCfgBlock, currBlockBuilder, stmtsReenterCondition, true, basicBlockSet, blockBuilders);
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
// put incrementor statements into prev reenter block
|
|
256
|
+
const blockReenterCondition = blockBuilderToCfgBlock.get(blockBuildersReenterCondition[0]);
|
|
257
|
+
stmtsReenterCondition.forEach(stmt => blockReenterCondition === null || blockReenterCondition === void 0 ? void 0 : blockReenterCondition.getStmts().push(stmt));
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
exports.CxxLoopBuilder = CxxLoopBuilder;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BasicBlock } from '../../../../core/graph/BasicBlock';
|
|
2
|
+
import { ArkIRTransformer, ValueAndStmts } from '../../../../core/common/ArkIRTransformer';
|
|
3
|
+
import { BlockBuilder } from '../../../../core/graph/builder/CfgBuilder';
|
|
4
|
+
/**
|
|
5
|
+
* Builder for switch statement in CFG
|
|
6
|
+
*/
|
|
7
|
+
export declare class CxxSwitchBuilder {
|
|
8
|
+
buildSwitch(blockBuilderToCfgBlock: Map<BlockBuilder, BasicBlock>, blockBuildersContainSwitch: BlockBuilder[], valueAndStmtsOfSwitchAndCasesAll: ValueAndStmts[][], arkIRTransformer: ArkIRTransformer, basicBlockSet: Set<BasicBlock>): void;
|
|
9
|
+
private generateIfBlocksForCases;
|
|
10
|
+
private linkIfBlockAndCaseBlock;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=SwitchBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SwitchBuilder.d.ts","sourceRoot":"","sources":["../../../../../src/frontend/cppFrontend/graph/builder/SwitchBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AAE3F,OAAO,EAAE,YAAY,EAA0B,MAAM,2CAA2C,CAAC;AAKjG;;GAEG;AACH,qBAAa,gBAAgB;IAClB,WAAW,CACd,sBAAsB,EAAE,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,EACrD,0BAA0B,EAAE,YAAY,EAAE,EAC1C,gCAAgC,EAAE,aAAa,EAAE,EAAE,EACnD,gBAAgB,EAAE,gBAAgB,EAClC,aAAa,EAAE,GAAG,CAAC,UAAU,CAAC,GAC/B,IAAI;IA0CP,OAAO,CAAC,wBAAwB;IAwChC,OAAO,CAAC,uBAAuB;CAmDlC"}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2025 Huawei Device Co., Ltd.
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
19
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
20
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
21
|
+
}
|
|
22
|
+
Object.defineProperty(o, k2, desc);
|
|
23
|
+
}) : (function(o, m, k, k2) {
|
|
24
|
+
if (k2 === undefined) k2 = k;
|
|
25
|
+
o[k2] = m[k];
|
|
26
|
+
}));
|
|
27
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
28
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
29
|
+
}) : function(o, v) {
|
|
30
|
+
o["default"] = v;
|
|
31
|
+
});
|
|
32
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
33
|
+
if (mod && mod.__esModule) return mod;
|
|
34
|
+
var result = {};
|
|
35
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
36
|
+
__setModuleDefault(result, mod);
|
|
37
|
+
return result;
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
|
+
exports.CxxSwitchBuilder = void 0;
|
|
41
|
+
const BasicBlock_1 = require("../../../../core/graph/BasicBlock");
|
|
42
|
+
const logger_1 = __importStar(require("../../../../utils/logger"));
|
|
43
|
+
const logger = logger_1.default.getLogger(logger_1.LOG_MODULE_TYPE.ARKANALYZER, 'SwitchBuilder');
|
|
44
|
+
/**
|
|
45
|
+
* Builder for switch statement in CFG
|
|
46
|
+
*/
|
|
47
|
+
class CxxSwitchBuilder {
|
|
48
|
+
buildSwitch(blockBuilderToCfgBlock, blockBuildersContainSwitch, valueAndStmtsOfSwitchAndCasesAll, arkIRTransformer, basicBlockSet) {
|
|
49
|
+
for (let i = 0; i < blockBuildersContainSwitch.length; i++) {
|
|
50
|
+
const blockBuilderContainSwitch = blockBuildersContainSwitch[i];
|
|
51
|
+
if (!blockBuilderToCfgBlock.has(blockBuilderContainSwitch)) {
|
|
52
|
+
logger.error(`can't find basicBlock corresponding to the blockBuilder.`);
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
const blockContainSwitch = blockBuilderToCfgBlock.get(blockBuilderContainSwitch);
|
|
56
|
+
const valueAndStmtsOfSwitch = valueAndStmtsOfSwitchAndCasesAll[i][0];
|
|
57
|
+
const stmtsOfSwitch = valueAndStmtsOfSwitch.stmts;
|
|
58
|
+
stmtsOfSwitch.forEach((stmt) => {
|
|
59
|
+
blockContainSwitch.addStmt(stmt);
|
|
60
|
+
});
|
|
61
|
+
const stmtsCnt = blockBuilderContainSwitch.stmts.length;
|
|
62
|
+
const switchStmtBuilder = blockBuilderContainSwitch.stmts[stmtsCnt - 1];
|
|
63
|
+
const cases = switchStmtBuilder.cases;
|
|
64
|
+
let nonEmptyCaseCnt = 0;
|
|
65
|
+
for (const currCase of cases) {
|
|
66
|
+
if (currCase.stmt.block) {
|
|
67
|
+
// there are stmts after this case
|
|
68
|
+
nonEmptyCaseCnt++;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
if (nonEmptyCaseCnt === 0) {
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
const caseCnt = cases.length;
|
|
75
|
+
const caseIfBlocks = this.generateIfBlocksForCases(valueAndStmtsOfSwitchAndCasesAll[i], caseCnt, blockContainSwitch, basicBlockSet, arkIRTransformer);
|
|
76
|
+
this.linkIfBlockAndCaseBlock(blockContainSwitch, caseIfBlocks, switchStmtBuilder, blockBuilderToCfgBlock);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
generateIfBlocksForCases(valueAndStmtsOfSwitchAndCases, caseCnt, blockContainSwitch, basicBlockSet, arkIRTransformer) {
|
|
80
|
+
const valueAndStmtsOfSwitch = valueAndStmtsOfSwitchAndCases[0];
|
|
81
|
+
const valueOfSwitch = valueAndStmtsOfSwitch.value;
|
|
82
|
+
const caseIfBlocks = [];
|
|
83
|
+
for (let j = 0; j < caseCnt; j++) {
|
|
84
|
+
let caseIfBlock;
|
|
85
|
+
if (j === 0) {
|
|
86
|
+
caseIfBlock = blockContainSwitch;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
caseIfBlock = new BasicBlock_1.BasicBlock();
|
|
90
|
+
basicBlockSet.add(caseIfBlock);
|
|
91
|
+
}
|
|
92
|
+
caseIfBlocks.push(caseIfBlock);
|
|
93
|
+
const caseValueAndStmts = valueAndStmtsOfSwitchAndCases[j + 1];
|
|
94
|
+
const caseValue = caseValueAndStmts.value;
|
|
95
|
+
const caseStmts = caseValueAndStmts.stmts;
|
|
96
|
+
caseStmts.forEach((stmt) => {
|
|
97
|
+
caseIfBlock.addStmt(stmt);
|
|
98
|
+
});
|
|
99
|
+
const caseIfStmts = arkIRTransformer.generateIfStmtForValues(valueOfSwitch, valueAndStmtsOfSwitch.valueOriginalPositions, caseValue, caseValueAndStmts.valueOriginalPositions);
|
|
100
|
+
caseIfStmts.forEach((stmt) => {
|
|
101
|
+
caseIfBlock.addStmt(stmt);
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
return caseIfBlocks;
|
|
105
|
+
}
|
|
106
|
+
linkIfBlockAndCaseBlock(blockContainSwitch, caseIfBlocks, switchStmtBuilder, blockBuilderToCfgBlock) {
|
|
107
|
+
const successorsOfBlockContainSwitch = Array.from(blockContainSwitch.getSuccessors());
|
|
108
|
+
const expectedSuccessorsOfCaseIfBlock = [];
|
|
109
|
+
const defaultStmtBuilder = switchStmtBuilder.default;
|
|
110
|
+
if (defaultStmtBuilder && defaultStmtBuilder.block) {
|
|
111
|
+
expectedSuccessorsOfCaseIfBlock.push(...successorsOfBlockContainSwitch.splice(-1, 1));
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
const afterSwitchStmtBuilder = switchStmtBuilder.afterSwitch;
|
|
115
|
+
const afterSwitchBlockBuilder = afterSwitchStmtBuilder === null || afterSwitchStmtBuilder === void 0 ? void 0 : afterSwitchStmtBuilder.block;
|
|
116
|
+
if (!afterSwitchBlockBuilder || !blockBuilderToCfgBlock.has(afterSwitchBlockBuilder)) {
|
|
117
|
+
logger.error(`can't find basicBlock corresponding to the blockBuilder.`);
|
|
118
|
+
return false;
|
|
119
|
+
}
|
|
120
|
+
expectedSuccessorsOfCaseIfBlock.push(blockBuilderToCfgBlock.get(afterSwitchBlockBuilder));
|
|
121
|
+
}
|
|
122
|
+
const caseCnt = switchStmtBuilder.cases.length;
|
|
123
|
+
for (let i = caseCnt - 1; i >= 0; i--) {
|
|
124
|
+
const currCase = switchStmtBuilder.cases[i];
|
|
125
|
+
if (currCase.stmt.block || currCase.stmt.type === 'gotoStatement') {
|
|
126
|
+
expectedSuccessorsOfCaseIfBlock.push(...successorsOfBlockContainSwitch.splice(-1, 1));
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
// if there are no stmts after this case, reuse the successor of the next case
|
|
130
|
+
expectedSuccessorsOfCaseIfBlock.push(...expectedSuccessorsOfCaseIfBlock.slice(-1));
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
expectedSuccessorsOfCaseIfBlock.reverse();
|
|
134
|
+
blockContainSwitch.getSuccessors().forEach(successor => {
|
|
135
|
+
successor.getPredecessors().splice(0, 1);
|
|
136
|
+
});
|
|
137
|
+
blockContainSwitch.getSuccessors().splice(0);
|
|
138
|
+
for (let j = 0; j < caseCnt; j++) {
|
|
139
|
+
const caseIfBlock = caseIfBlocks[j];
|
|
140
|
+
caseIfBlock.addSuccessorBlock(expectedSuccessorsOfCaseIfBlock[j]);
|
|
141
|
+
expectedSuccessorsOfCaseIfBlock[j].addPredecessorBlock(caseIfBlock);
|
|
142
|
+
if (j === caseCnt - 1) {
|
|
143
|
+
// the false branch of last case should be default or block after switch statement
|
|
144
|
+
caseIfBlock.addSuccessorBlock(expectedSuccessorsOfCaseIfBlock[j + 1]);
|
|
145
|
+
expectedSuccessorsOfCaseIfBlock[j + 1].addPredecessorBlock(caseIfBlock);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
caseIfBlock.addSuccessorBlock(caseIfBlocks[j + 1]);
|
|
149
|
+
caseIfBlocks[j + 1].addPredecessorBlock(caseIfBlock);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return true;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
exports.CxxSwitchBuilder = CxxSwitchBuilder;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { BasicBlock } from '../../../../core/graph/BasicBlock';
|
|
2
|
+
import { CxxTrap } from '../../base/Trap';
|
|
3
|
+
import { BlockBuilder } from './CfgBuilder';
|
|
4
|
+
/**
|
|
5
|
+
* Builder for traps from try...catch
|
|
6
|
+
*/
|
|
7
|
+
export declare class CxxTrapBuilder {
|
|
8
|
+
private processedBlockBuildersBeforeTry;
|
|
9
|
+
private basicBlockSet;
|
|
10
|
+
private blockBuilderToCfgBlock;
|
|
11
|
+
private blockBuildersBeforeTry;
|
|
12
|
+
constructor(blockBuildersBeforeTry: Set<BlockBuilder>, blockBuilderToCfgBlock: Map<BlockBuilder, BasicBlock>, basicBlockSet: Set<BasicBlock>);
|
|
13
|
+
buildTraps(): CxxTrap[];
|
|
14
|
+
private buildTrapGroup;
|
|
15
|
+
private shouldSkipProcessing;
|
|
16
|
+
private getTryStatementBuilder;
|
|
17
|
+
private getFinallyBlock;
|
|
18
|
+
private prepareHeadBlock;
|
|
19
|
+
private processTryBlock;
|
|
20
|
+
private processCatchBlock;
|
|
21
|
+
private getAfterFinallyBlock;
|
|
22
|
+
private buildSingleTraps;
|
|
23
|
+
private buildTrapsRecursively;
|
|
24
|
+
private removeEmptyBlockBeforeTry;
|
|
25
|
+
private shouldRemoveEmptyBlockBeforeTry;
|
|
26
|
+
private buildTrapsIfNoFinally;
|
|
27
|
+
private getAllBlocksBFS;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=TrapBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TrapBuilder.d.ts","sourceRoot":"","sources":["../../../../../src/frontend/cppFrontend/graph/builder/TrapBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAuB,MAAM,cAAc,CAAC;AAKjE;;GAEG;AACH,qBAAa,cAAc;IACvB,OAAO,CAAC,+BAA+B,CAAoB;IAC3D,OAAO,CAAC,aAAa,CAAkB;IACvC,OAAO,CAAC,sBAAsB,CAAgC;IAC9D,OAAO,CAAC,sBAAsB,CAAoB;gBAEtC,sBAAsB,EAAE,GAAG,CAAC,YAAY,CAAC,EAAE,sBAAsB,EAAE,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,EACxG,aAAa,EAAE,GAAG,CAAC,UAAU,CAAC;IAO3B,UAAU,IAAI,OAAO,EAAE;IAS9B,OAAO,CAAC,cAAc;IA6CtB,OAAO,CAAC,oBAAoB;IAa5B,OAAO,CAAC,sBAAsB;IAK9B,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,gBAAgB;IAMxB,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,iBAAiB;IA0BzB,OAAO,CAAC,oBAAoB;IAS5B,OAAO,CAAC,gBAAgB;IAgBxB,OAAO,CAAC,qBAAqB;IAkC7B,OAAO,CAAC,yBAAyB;IAyBjC,OAAO,CAAC,+BAA+B;IAMvC,OAAO,CAAC,qBAAqB;IA0D7B,OAAO,CAAC,eAAe;CAkC1B"}
|