arkanalyzer 1.0.86 → 1.0.88
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 +35 -1
- package/lib/Config.d.ts.map +1 -1
- package/lib/Config.js +91 -2
- package/lib/Scene.d.ts +25 -2
- package/lib/Scene.d.ts.map +1 -1
- package/lib/Scene.js +151 -44
- 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 +53 -0
- package/lib/cli/commands/cg.d.ts.map +1 -0
- package/lib/cli/commands/cg.js +404 -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 +145 -23
- 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 +4 -0
- package/lib/core/common/Const.d.ts.map +1 -1
- package/lib/core/common/Const.js +5 -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 +6 -2
- package/lib/core/common/IRUtils.d.ts.map +1 -1
- package/lib/core/common/IRUtils.js +3 -33
- 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 +25 -2
- package/lib/core/model/ArkClass.d.ts.map +1 -1
- package/lib/core/model/ArkClass.js +72 -30
- 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/ArkMetadata.d.ts +32 -1
- package/lib/core/model/ArkMetadata.d.ts.map +1 -1
- package/lib/core/model/ArkMetadata.js +28 -2
- 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/ArkMetadataBuilder.d.ts +21 -0
- package/lib/core/model/builder/ArkMetadataBuilder.d.ts.map +1 -0
- package/lib/core/model/builder/ArkMetadataBuilder.js +160 -0
- 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 +50 -29
- 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/astJsonNapi/napiApi.d.ts +8 -0
- package/lib/frontend/cppFrontend/ast/astJsonNapi/napiApi.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/astJsonNapi/napiApi.js +90 -0
- package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.d.ts +8 -0
- package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.js +183 -0
- package/lib/frontend/cppFrontend/ast/astParser.d.ts +25 -0
- package/lib/frontend/cppFrontend/ast/astParser.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/astParser.js +280 -0
- package/lib/frontend/cppFrontend/ast/astUtils.d.ts +18 -0
- package/lib/frontend/cppFrontend/ast/astUtils.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/astUtils.js +158 -0
- package/lib/frontend/cppFrontend/ast/const.d.ts +17 -0
- package/lib/frontend/cppFrontend/ast/const.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/const.js +58 -0
- package/lib/frontend/cppFrontend/ast/index.d.ts +5 -0
- package/lib/frontend/cppFrontend/ast/index.d.ts.map +1 -0
- package/lib/frontend/cppFrontend/ast/index.js +31 -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 +284 -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 +2 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +8 -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/SourceStmt.d.ts.map +1 -1
- package/lib/save/source/SourceStmt.js +3 -1
- 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 +8 -8
- package/lib/utils/FileUtils.d.ts.map +1 -1
- package/lib/utils/FileUtils.js +35 -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 +13 -7
- /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,21 @@
|
|
|
1
|
+
import { BasicBlock } from '../../../../core/graph/BasicBlock';
|
|
2
|
+
import { BlockBuilder } from '../../../../core/graph/builder/CfgBuilder';
|
|
3
|
+
/**
|
|
4
|
+
* Builder for condition in CFG
|
|
5
|
+
*/
|
|
6
|
+
export declare class CxxConditionBuilder {
|
|
7
|
+
rebuildBlocksContainConditionalOperator(blockBuilderToCfgBlock: Map<BlockBuilder, BasicBlock>, basicBlockSet: Set<BasicBlock>, isArkUIBuilder: boolean): void;
|
|
8
|
+
private relinkPrevAndSuccOfBlockContainConditionalOperator;
|
|
9
|
+
private generateBlocksContainConditionalOperatorGroup;
|
|
10
|
+
private segmentSourceStatements;
|
|
11
|
+
private initializeSuffix;
|
|
12
|
+
private addBlocksToSet;
|
|
13
|
+
private linkBlocks;
|
|
14
|
+
private generateBlocksContainSingleConditionalOperator;
|
|
15
|
+
private generateBlockWithoutConditionalOperator;
|
|
16
|
+
private deleteDummyConditionalOperatorStmt;
|
|
17
|
+
private findFirstConditionalOperator;
|
|
18
|
+
private removeUnnecessaryBlocksInConditionalOperator;
|
|
19
|
+
private replaceTempRecursively;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=ConditionBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConditionBuilder.d.ts","sourceRoot":"","sources":["../../../../../src/frontend/cppFrontend/graph/builder/ConditionBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAK/D,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AAazE;;GAEG;AACH,qBAAa,mBAAmB;IACrB,uCAAuC,CAC1C,sBAAsB,EAAE,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,EACrD,aAAa,EAAE,GAAG,CAAC,UAAU,CAAC,EAC9B,cAAc,EAAE,OAAO,GACxB,IAAI;IAmDP,OAAO,CAAC,kDAAkD;IAuB1D,OAAO,CAAC,6CAA6C;IAgCrD,OAAO,CAAC,uBAAuB;IAyB/B,OAAO,CAAC,gBAAgB;IAWxB,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,8CAA8C;IAqDtD,OAAO,CAAC,uCAAuC;IAc/C,OAAO,CAAC,kCAAkC;IAW1C,OAAO,CAAC,4BAA4B;IAyBpC,OAAO,CAAC,4CAA4C;IAoCpD,OAAO,CAAC,sBAAsB;CA2DjC"}
|
|
@@ -0,0 +1,303 @@
|
|
|
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.CxxConditionBuilder = void 0;
|
|
18
|
+
const BasicBlock_1 = require("../../../../core/graph/BasicBlock");
|
|
19
|
+
const ArkIRTransformer_1 = require("../../../../core/common/ArkIRTransformer");
|
|
20
|
+
const Stmt_1 = require("../../../../core/base/Stmt");
|
|
21
|
+
const Local_1 = require("../../../../core/base/Local");
|
|
22
|
+
const IRUtils_1 = require("../../common/IRUtils");
|
|
23
|
+
/**
|
|
24
|
+
* Builder for condition in CFG
|
|
25
|
+
*/
|
|
26
|
+
class CxxConditionBuilder {
|
|
27
|
+
rebuildBlocksContainConditionalOperator(blockBuilderToCfgBlock, basicBlockSet, isArkUIBuilder) {
|
|
28
|
+
var _a;
|
|
29
|
+
if (isArkUIBuilder) {
|
|
30
|
+
this.deleteDummyConditionalOperatorStmt(basicBlockSet);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const blockPairsToSet = [];
|
|
34
|
+
for (const [currBlockBuilder, currBasicBlock] of blockBuilderToCfgBlock) {
|
|
35
|
+
const stmtsInCurrBasicBlock = Array.from(currBasicBlock.getStmts());
|
|
36
|
+
const stmtsCnt = stmtsInCurrBasicBlock.length;
|
|
37
|
+
let conditionalOperatorEndPos = -1;
|
|
38
|
+
for (let i = stmtsCnt - 1; i >= 0; i--) {
|
|
39
|
+
const stmt = stmtsInCurrBasicBlock[i];
|
|
40
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt && ((_a = stmt.toString()) === null || _a === void 0 ? void 0 : _a.startsWith(ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR_END_STMT))) {
|
|
41
|
+
conditionalOperatorEndPos = i;
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (conditionalOperatorEndPos === -1) {
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
let { generatedTopBlock: generatedTopBlock, generatedBottomBlocks: generatedBottomBlocks, } = this.generateBlocksContainConditionalOperatorGroup(stmtsInCurrBasicBlock.slice(0, conditionalOperatorEndPos + 1), basicBlockSet);
|
|
49
|
+
if (conditionalOperatorEndPos !== stmtsCnt - 1) {
|
|
50
|
+
// need create a new basic block for rest statements
|
|
51
|
+
const { generatedTopBlock: extraBlock } = this.generateBlockWithoutConditionalOperator(stmtsInCurrBasicBlock.slice(conditionalOperatorEndPos + 1));
|
|
52
|
+
generatedBottomBlocks.forEach(generatedBottomBlock => {
|
|
53
|
+
generatedBottomBlock.addSuccessorBlock(extraBlock);
|
|
54
|
+
extraBlock.addPredecessorBlock(generatedBottomBlock);
|
|
55
|
+
});
|
|
56
|
+
basicBlockSet.add(extraBlock);
|
|
57
|
+
generatedBottomBlocks = this.removeUnnecessaryBlocksInConditionalOperator(extraBlock, basicBlockSet);
|
|
58
|
+
}
|
|
59
|
+
this.relinkPrevAndSuccOfBlockContainConditionalOperator(currBasicBlock, generatedTopBlock, generatedBottomBlocks);
|
|
60
|
+
basicBlockSet.delete(currBasicBlock);
|
|
61
|
+
blockPairsToSet.push([currBlockBuilder, generatedTopBlock]);
|
|
62
|
+
}
|
|
63
|
+
for (const [currBlockBuilder, generatedTopBlock] of blockPairsToSet) {
|
|
64
|
+
blockBuilderToCfgBlock.set(currBlockBuilder, generatedTopBlock);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
relinkPrevAndSuccOfBlockContainConditionalOperator(currBasicBlock, generatedTopBlock, generatedBottomBlocks) {
|
|
68
|
+
const predecessorsOfCurrBasicBlock = Array.from(currBasicBlock.getPredecessors());
|
|
69
|
+
predecessorsOfCurrBasicBlock.forEach(predecessor => {
|
|
70
|
+
predecessor.removeSuccessorBlock(currBasicBlock);
|
|
71
|
+
currBasicBlock.removePredecessorBlock(predecessor);
|
|
72
|
+
generatedTopBlock.addPredecessorBlock(predecessor);
|
|
73
|
+
predecessor.addSuccessorBlock(generatedTopBlock);
|
|
74
|
+
});
|
|
75
|
+
const successorsOfCurrBasicBlock = Array.from(currBasicBlock.getSuccessors());
|
|
76
|
+
successorsOfCurrBasicBlock.forEach(successor => {
|
|
77
|
+
successor.removePredecessorBlock(currBasicBlock);
|
|
78
|
+
currBasicBlock.removeSuccessorBlock(successor);
|
|
79
|
+
generatedBottomBlocks.forEach(generatedBottomBlock => {
|
|
80
|
+
generatedBottomBlock.addSuccessorBlock(successor);
|
|
81
|
+
successor.addPredecessorBlock(generatedBottomBlock);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
generateBlocksContainConditionalOperatorGroup(sourceStmts, basicBlockSet) {
|
|
86
|
+
const { segs, tail } = this.segmentSourceStatements(sourceStmts, basicBlockSet);
|
|
87
|
+
// Case 1: No conditional operators found, or only a trailing non-operator block
|
|
88
|
+
if (segs.length === 0) {
|
|
89
|
+
return tail !== null && tail !== void 0 ? tail : this.generateBlockWithoutConditionalOperator(sourceStmts);
|
|
90
|
+
}
|
|
91
|
+
// Case 2: Multi-segment linking
|
|
92
|
+
let { suffixTop, suffixBottoms } = this.initializeSuffix(segs, tail);
|
|
93
|
+
// Backward link segments: Seg[i].bottoms -> Seg[i+1].top
|
|
94
|
+
for (let i = segs.length - 1; i >= 0; i--) {
|
|
95
|
+
// Skip the last segment if there's no tail, as it's already the initial suffix
|
|
96
|
+
if (i === segs.length - 1 && !tail) {
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
const cur = segs[i];
|
|
100
|
+
this.linkBlocks(cur.bottoms, suffixTop);
|
|
101
|
+
this.addBlocksToSet(suffixBottoms, basicBlockSet);
|
|
102
|
+
this.removeUnnecessaryBlocksInConditionalOperator(suffixTop, basicBlockSet);
|
|
103
|
+
suffixTop = cur.top;
|
|
104
|
+
}
|
|
105
|
+
return { generatedTopBlock: segs[0].top, generatedBottomBlocks: suffixBottoms };
|
|
106
|
+
}
|
|
107
|
+
segmentSourceStatements(sourceStmts, basicBlockSet) {
|
|
108
|
+
const segs = [];
|
|
109
|
+
let offset = 0;
|
|
110
|
+
let tail;
|
|
111
|
+
while (offset < sourceStmts.length) {
|
|
112
|
+
const rest = sourceStmts.slice(offset);
|
|
113
|
+
const { firstEndPos } = this.findFirstConditionalOperator(rest);
|
|
114
|
+
if (firstEndPos === -1) {
|
|
115
|
+
tail = this.generateBlockWithoutConditionalOperator(rest);
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
const result = this.generateBlocksContainSingleConditionalOperator(rest.slice(0, firstEndPos + 1));
|
|
119
|
+
this.addBlocksToSet(result.generatedAllBlocks, basicBlockSet);
|
|
120
|
+
segs.push({ top: result.generatedTopBlock, bottoms: result.generatedBottomBlocks });
|
|
121
|
+
offset += firstEndPos + 1;
|
|
122
|
+
}
|
|
123
|
+
return { segs, tail };
|
|
124
|
+
}
|
|
125
|
+
initializeSuffix(segs, tail) {
|
|
126
|
+
if (tail) {
|
|
127
|
+
return { suffixTop: tail.generatedTopBlock, suffixBottoms: tail.generatedBottomBlocks };
|
|
128
|
+
}
|
|
129
|
+
const last = segs[segs.length - 1];
|
|
130
|
+
return { suffixTop: last.top, suffixBottoms: last.bottoms };
|
|
131
|
+
}
|
|
132
|
+
addBlocksToSet(blocks, set) {
|
|
133
|
+
for (const b of blocks) {
|
|
134
|
+
set.add(b);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
linkBlocks(from, to) {
|
|
138
|
+
for (const b of from) {
|
|
139
|
+
b.addSuccessorBlock(to);
|
|
140
|
+
to.addPredecessorBlock(b);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
generateBlocksContainSingleConditionalOperator(sourceStmts) {
|
|
144
|
+
const { firstIfTruePos: ifTruePos, firstIfFalsePos: ifFalsePos, firstEndPos: endPos, } = this.findFirstConditionalOperator(sourceStmts);
|
|
145
|
+
if (endPos === -1) {
|
|
146
|
+
return this.generateBlockWithoutConditionalOperator(sourceStmts);
|
|
147
|
+
}
|
|
148
|
+
const { generatedTopBlock: generatedTopBlock, generatedAllBlocks: generatedAllBlocks, } = this.generateBlockWithoutConditionalOperator(sourceStmts.slice(0, ifTruePos));
|
|
149
|
+
let generatedBottomBlocks = [];
|
|
150
|
+
const { generatedTopBlock: generatedTopBlockOfTrueBranch, generatedBottomBlocks: generatedBottomBlocksOfTrueBranch, generatedAllBlocks: generatedAllBlocksOfTrueBranch, } = this.generateBlocksContainSingleConditionalOperator(sourceStmts.slice(ifTruePos + 1, ifFalsePos));
|
|
151
|
+
generatedBottomBlocks.push(...generatedBottomBlocksOfTrueBranch);
|
|
152
|
+
generatedAllBlocks.push(...generatedAllBlocksOfTrueBranch);
|
|
153
|
+
const { generatedTopBlock: generatedTopBlockOfFalseBranch, generatedBottomBlocks: generatedBottomBlocksOfFalseBranch, generatedAllBlocks: generatedAllBlocksOfFalseBranch, } = this.generateBlocksContainSingleConditionalOperator(sourceStmts.slice(ifFalsePos + 1, endPos));
|
|
154
|
+
generatedBottomBlocks.push(...generatedBottomBlocksOfFalseBranch);
|
|
155
|
+
generatedAllBlocks.push(...generatedAllBlocksOfFalseBranch);
|
|
156
|
+
generatedTopBlock.addSuccessorBlock(generatedTopBlockOfTrueBranch);
|
|
157
|
+
generatedTopBlockOfTrueBranch.addPredecessorBlock(generatedTopBlock);
|
|
158
|
+
generatedTopBlock.addSuccessorBlock(generatedTopBlockOfFalseBranch);
|
|
159
|
+
generatedTopBlockOfFalseBranch.addPredecessorBlock(generatedTopBlock);
|
|
160
|
+
const stmtsCnt = sourceStmts.length;
|
|
161
|
+
if (endPos !== stmtsCnt - 1) {
|
|
162
|
+
// need create a new basic block for rest statements
|
|
163
|
+
const { generatedTopBlock: extraBlock } = this.generateBlockWithoutConditionalOperator(sourceStmts.slice(endPos + 1));
|
|
164
|
+
generatedBottomBlocks.forEach(generatedBottomBlock => {
|
|
165
|
+
generatedBottomBlock.addSuccessorBlock(extraBlock);
|
|
166
|
+
extraBlock.addPredecessorBlock(generatedBottomBlock);
|
|
167
|
+
});
|
|
168
|
+
generatedBottomBlocks = [extraBlock];
|
|
169
|
+
generatedAllBlocks.push(extraBlock);
|
|
170
|
+
}
|
|
171
|
+
return { generatedTopBlock, generatedBottomBlocks, generatedAllBlocks };
|
|
172
|
+
}
|
|
173
|
+
generateBlockWithoutConditionalOperator(sourceStmts) {
|
|
174
|
+
const generatedBlock = new BasicBlock_1.BasicBlock();
|
|
175
|
+
sourceStmts.forEach(stmt => generatedBlock.addStmt(stmt));
|
|
176
|
+
return {
|
|
177
|
+
generatedTopBlock: generatedBlock,
|
|
178
|
+
generatedBottomBlocks: [generatedBlock],
|
|
179
|
+
generatedAllBlocks: [generatedBlock],
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
deleteDummyConditionalOperatorStmt(basicBlockSet) {
|
|
183
|
+
var _a;
|
|
184
|
+
for (const basicBlock of basicBlockSet) {
|
|
185
|
+
const stmts = Array.from(basicBlock.getStmts());
|
|
186
|
+
for (const stmt of stmts) {
|
|
187
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt && ((_a = stmt.toString()) === null || _a === void 0 ? void 0 : _a.startsWith(ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR))) {
|
|
188
|
+
basicBlock.remove(stmt);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
findFirstConditionalOperator(stmts) {
|
|
194
|
+
let firstIfTruePos = -1;
|
|
195
|
+
let firstIfFalsePos = -1;
|
|
196
|
+
let firstEndPos = -1;
|
|
197
|
+
let firstConditionalOperatorNo = '';
|
|
198
|
+
for (let i = 0; i < stmts.length; i++) {
|
|
199
|
+
const stmt = stmts[i];
|
|
200
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt) {
|
|
201
|
+
if (stmt.toString().startsWith(ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR_IF_TRUE_STMT) && firstIfTruePos === -1) {
|
|
202
|
+
firstIfTruePos = i;
|
|
203
|
+
firstConditionalOperatorNo = stmt.toString().replace(ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR_IF_TRUE_STMT, '');
|
|
204
|
+
}
|
|
205
|
+
else if (stmt.toString() === ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR_IF_FALSE_STMT + firstConditionalOperatorNo) {
|
|
206
|
+
firstIfFalsePos = i;
|
|
207
|
+
}
|
|
208
|
+
else if (stmt.toString() === ArkIRTransformer_1.ArkIRTransformer.DUMMY_CONDITIONAL_OPERATOR_END_STMT + firstConditionalOperatorNo) {
|
|
209
|
+
firstEndPos = i;
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
return { firstIfTruePos, firstIfFalsePos, firstEndPos };
|
|
214
|
+
}
|
|
215
|
+
removeUnnecessaryBlocksInConditionalOperator(bottomBlock, allBlocks) {
|
|
216
|
+
var _a;
|
|
217
|
+
const firstStmtInBottom = bottomBlock.getHead();
|
|
218
|
+
if (!(firstStmtInBottom instanceof Stmt_1.ArkAssignStmt)) {
|
|
219
|
+
return [bottomBlock];
|
|
220
|
+
}
|
|
221
|
+
const targetValue = firstStmtInBottom.getLeftOp();
|
|
222
|
+
const targetValuePosition = (_a = firstStmtInBottom.getOperandOriginalPosition(targetValue)) !== null && _a !== void 0 ? _a : undefined;
|
|
223
|
+
const tempResultValue = firstStmtInBottom.getRightOp();
|
|
224
|
+
if (!(targetValue instanceof Local_1.Local && IRUtils_1.IRUtils.isTempLocal(tempResultValue))) {
|
|
225
|
+
return [bottomBlock];
|
|
226
|
+
}
|
|
227
|
+
const oldPredecessors = Array.from(bottomBlock.getPredecessors());
|
|
228
|
+
const newPredecessors = [];
|
|
229
|
+
for (const predecessor of oldPredecessors) {
|
|
230
|
+
predecessor.removeSuccessorBlock(bottomBlock);
|
|
231
|
+
newPredecessors.push(...this.replaceTempRecursively(predecessor, targetValue, tempResultValue, allBlocks, targetValuePosition));
|
|
232
|
+
}
|
|
233
|
+
bottomBlock.remove(firstStmtInBottom);
|
|
234
|
+
if (bottomBlock.getStmts().length === 0) {
|
|
235
|
+
// must be a new block without successors
|
|
236
|
+
allBlocks.delete(bottomBlock);
|
|
237
|
+
return newPredecessors;
|
|
238
|
+
}
|
|
239
|
+
oldPredecessors.forEach(oldPredecessor => {
|
|
240
|
+
bottomBlock.removePredecessorBlock(oldPredecessor);
|
|
241
|
+
});
|
|
242
|
+
newPredecessors.forEach(newPredecessor => {
|
|
243
|
+
bottomBlock.addPredecessorBlock(newPredecessor);
|
|
244
|
+
newPredecessor.addSuccessorBlock(bottomBlock);
|
|
245
|
+
});
|
|
246
|
+
return [bottomBlock];
|
|
247
|
+
}
|
|
248
|
+
replaceTempRecursively(currBottomBlock, targetLocal, tempResultLocal, allBlocks, targetValuePosition) {
|
|
249
|
+
var _a;
|
|
250
|
+
const stmts = currBottomBlock.getStmts();
|
|
251
|
+
const stmtsCnt = stmts.length;
|
|
252
|
+
let tempResultReassignStmt = null;
|
|
253
|
+
for (let i = stmtsCnt - 1; i >= 0; i--) {
|
|
254
|
+
const stmt = stmts[i];
|
|
255
|
+
if (!(stmt instanceof Stmt_1.ArkAssignStmt) || stmt.getLeftOp() !== tempResultLocal) {
|
|
256
|
+
continue;
|
|
257
|
+
}
|
|
258
|
+
if (IRUtils_1.IRUtils.isTempLocal(stmt.getRightOp())) {
|
|
259
|
+
// When only one stmt remains in a block, it should be retained, and the final value of the ternary expression should be concatenated with it
|
|
260
|
+
tempResultReassignStmt = stmt;
|
|
261
|
+
if (i !== 0) {
|
|
262
|
+
continue;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
stmt.setLeftOp(targetLocal);
|
|
266
|
+
if (targetValuePosition) {
|
|
267
|
+
const restPositions = (_a = stmt.getOperandOriginalPositions()) === null || _a === void 0 ? void 0 : _a.slice(1);
|
|
268
|
+
if (restPositions) {
|
|
269
|
+
stmt.setOperandOriginalPositions([targetValuePosition, ...restPositions]);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
let newBottomBlocks = [];
|
|
274
|
+
// When both ends are TempLocal, the statement begins filtering
|
|
275
|
+
if (tempResultReassignStmt && IRUtils_1.IRUtils.isTempLocal(tempResultReassignStmt.getLeftOp())) {
|
|
276
|
+
const oldPredecessors = currBottomBlock.getPredecessors();
|
|
277
|
+
const newPredecessors = [];
|
|
278
|
+
const prevTempResultLocal = tempResultReassignStmt.getRightOp();
|
|
279
|
+
for (const predecessor of oldPredecessors) {
|
|
280
|
+
predecessor.removeSuccessorBlock(currBottomBlock);
|
|
281
|
+
newPredecessors.push(...this.replaceTempRecursively(predecessor, targetLocal, prevTempResultLocal, allBlocks, targetValuePosition));
|
|
282
|
+
}
|
|
283
|
+
currBottomBlock.remove(tempResultReassignStmt);
|
|
284
|
+
if (currBottomBlock.getStmts().length === 0) {
|
|
285
|
+
// remove this block
|
|
286
|
+
newBottomBlocks = newPredecessors;
|
|
287
|
+
allBlocks.delete(currBottomBlock);
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
currBottomBlock.getPredecessors().splice(0, oldPredecessors.length, ...newPredecessors);
|
|
291
|
+
newPredecessors.forEach(newPredecessor => {
|
|
292
|
+
newPredecessor.addSuccessorBlock(currBottomBlock);
|
|
293
|
+
});
|
|
294
|
+
newBottomBlocks = [currBottomBlock];
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
else {
|
|
298
|
+
newBottomBlocks = [currBottomBlock];
|
|
299
|
+
}
|
|
300
|
+
return newBottomBlocks;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
exports.CxxConditionBuilder = CxxConditionBuilder;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BasicBlock } from '../../../../core/graph/BasicBlock';
|
|
2
|
+
/**
|
|
3
|
+
* Builder for if statement in CFG
|
|
4
|
+
* This is a scenario where the processing criteria include | | or &&
|
|
5
|
+
*/
|
|
6
|
+
export declare class CxxIfBuilder {
|
|
7
|
+
rebuildIf(basicBlockSet: Set<BasicBlock>): void;
|
|
8
|
+
private generateBlocksForComplexBooleanExpr;
|
|
9
|
+
private generateBlocksForOrExpr;
|
|
10
|
+
private generateBlocksForAndExpr;
|
|
11
|
+
private findOrOperator;
|
|
12
|
+
private findAndOperator;
|
|
13
|
+
private generateBlock;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=IfBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IfBuilder.d.ts","sourceRoot":"","sources":["../../../../../src/frontend/cppFrontend/graph/builder/IfBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAQ/D;;;GAGG;AACH,qBAAa,YAAY;IACd,SAAS,CACZ,aAAa,EAAE,GAAG,CAAC,UAAU,CAAC,GAC/B,IAAI;IAYP,OAAO,CAAC,mCAAmC;IAmB3C,OAAO,CAAC,uBAAuB;IAqB/B,OAAO,CAAC,wBAAwB;IAuBhC,OAAO,CAAC,cAAc;IAqBtB,OAAO,CAAC,eAAe;IAqBvB,OAAO,CAAC,aAAa;CAcxB"}
|
|
@@ -0,0 +1,161 @@
|
|
|
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.CxxIfBuilder = void 0;
|
|
41
|
+
const BasicBlock_1 = require("../../../../core/graph/BasicBlock");
|
|
42
|
+
const ArkIRTransformer_1 = require("../../../../core/common/ArkIRTransformer");
|
|
43
|
+
const logger_1 = __importStar(require("../../../../utils/logger"));
|
|
44
|
+
const ArkIRTransformer_2 = require("../../common/ArkIRTransformer");
|
|
45
|
+
const logger = logger_1.default.getLogger(logger_1.LOG_MODULE_TYPE.ARKANALYZER, 'SwitchBuilder');
|
|
46
|
+
/**
|
|
47
|
+
* Builder for if statement in CFG
|
|
48
|
+
* This is a scenario where the processing criteria include | | or &&
|
|
49
|
+
*/
|
|
50
|
+
class CxxIfBuilder {
|
|
51
|
+
rebuildIf(basicBlockSet) {
|
|
52
|
+
var _a;
|
|
53
|
+
for (const basicBlock of basicBlockSet) {
|
|
54
|
+
const stmts = Array.from(basicBlock.getStmts());
|
|
55
|
+
const stmtsCnt = stmts.length;
|
|
56
|
+
const stmt = stmts[stmtsCnt - 1];
|
|
57
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt && ((_a = stmt.toString()) === null || _a === void 0 ? void 0 : _a.startsWith(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END))) {
|
|
58
|
+
this.generateBlocksForComplexBooleanExpr(basicBlock, basicBlockSet);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
generateBlocksForComplexBooleanExpr(block, basicBlockSet) {
|
|
63
|
+
if (block.getSuccessors().length !== 2) {
|
|
64
|
+
logger.error('the ifStmt build failed');
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
const { firstOrSignalPos: firstOrSignalPos, firstOrEndPos: OrEndPos } = this.findOrOperator(block.getStmts());
|
|
68
|
+
if (firstOrSignalPos !== -1) {
|
|
69
|
+
this.generateBlocksForOrExpr(block, basicBlockSet, firstOrSignalPos, OrEndPos);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
const { firstAndSignalPos: firstAndSignalPos, firstAndEndPos: AndEndPos, } = this.findAndOperator(block.getStmts());
|
|
73
|
+
if (firstAndSignalPos !== -1) {
|
|
74
|
+
this.generateBlocksForAndExpr(block, basicBlockSet, firstAndSignalPos, AndEndPos);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
generateBlocksForOrExpr(block, basicBlockSet, firstOrSignalPos, OrEndPos) {
|
|
78
|
+
const sourceStmts = block.getStmts();
|
|
79
|
+
const { generatedTopBlock: secondBlock } = this.generateBlock(sourceStmts.slice(firstOrSignalPos + 1, OrEndPos));
|
|
80
|
+
sourceStmts.splice(firstOrSignalPos);
|
|
81
|
+
const falseBlock = block.getSuccessors()[1];
|
|
82
|
+
const trueBlock = block.getSuccessors()[0];
|
|
83
|
+
block.removeSuccessorBlock(falseBlock);
|
|
84
|
+
falseBlock.removePredecessorBlock(block);
|
|
85
|
+
block.addSuccessorBlock(secondBlock);
|
|
86
|
+
secondBlock.addPredecessorBlock(block);
|
|
87
|
+
secondBlock.addSuccessorBlock(trueBlock);
|
|
88
|
+
trueBlock.addPredecessorBlock(secondBlock);
|
|
89
|
+
secondBlock.addSuccessorBlock(falseBlock);
|
|
90
|
+
falseBlock.addPredecessorBlock(secondBlock);
|
|
91
|
+
basicBlockSet.add(secondBlock);
|
|
92
|
+
this.generateBlocksForComplexBooleanExpr(block, basicBlockSet);
|
|
93
|
+
this.generateBlocksForComplexBooleanExpr(secondBlock, basicBlockSet);
|
|
94
|
+
}
|
|
95
|
+
generateBlocksForAndExpr(block, basicBlockSet, firstOrSignalPos, OrEndPos) {
|
|
96
|
+
const sourceStmts = block.getStmts();
|
|
97
|
+
const { generatedTopBlock: secondBlock } = this.generateBlock(sourceStmts.slice(firstOrSignalPos + 1, OrEndPos));
|
|
98
|
+
sourceStmts.splice(firstOrSignalPos);
|
|
99
|
+
// Need to check if it is the default rule
|
|
100
|
+
const falseBlock = block.getSuccessors()[1];
|
|
101
|
+
const trueBlock = block.getSuccessors()[0];
|
|
102
|
+
block.removeSuccessorBlock(trueBlock);
|
|
103
|
+
trueBlock.removePredecessorBlock(block);
|
|
104
|
+
const successesBlock = block.getSuccessors();
|
|
105
|
+
successesBlock.unshift(secondBlock);
|
|
106
|
+
secondBlock.addPredecessorBlock(block);
|
|
107
|
+
secondBlock.addSuccessorBlock(trueBlock);
|
|
108
|
+
trueBlock.addPredecessorBlock(secondBlock);
|
|
109
|
+
secondBlock.addSuccessorBlock(falseBlock);
|
|
110
|
+
falseBlock.addPredecessorBlock(secondBlock);
|
|
111
|
+
basicBlockSet.add(secondBlock);
|
|
112
|
+
this.generateBlocksForComplexBooleanExpr(block, basicBlockSet);
|
|
113
|
+
this.generateBlocksForComplexBooleanExpr(secondBlock, basicBlockSet);
|
|
114
|
+
}
|
|
115
|
+
findOrOperator(stmts) {
|
|
116
|
+
let firstOrSignalPos = -1;
|
|
117
|
+
let firstOrEndPos = -1;
|
|
118
|
+
let firstConditionalOperatorNo = '';
|
|
119
|
+
for (let i = stmts.length; i >= 0; i--) {
|
|
120
|
+
const stmt = stmts[i];
|
|
121
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt) {
|
|
122
|
+
if (stmt.toString().startsWith(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END) && firstOrEndPos === -1) {
|
|
123
|
+
firstOrEndPos = i;
|
|
124
|
+
firstConditionalOperatorNo = stmt.toString().replace(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END, '');
|
|
125
|
+
}
|
|
126
|
+
else if (stmt.toString() === ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_OR_SIGNAL + firstConditionalOperatorNo) {
|
|
127
|
+
firstOrSignalPos = i;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return { firstOrSignalPos, firstOrEndPos };
|
|
132
|
+
}
|
|
133
|
+
findAndOperator(stmts) {
|
|
134
|
+
let firstAndSignalPos = -1;
|
|
135
|
+
let firstAndEndPos = -1;
|
|
136
|
+
let firstConditionalOperatorNo = '';
|
|
137
|
+
for (let i = stmts.length; i >= 0; i--) {
|
|
138
|
+
const stmt = stmts[i];
|
|
139
|
+
if (stmt instanceof ArkIRTransformer_1.DummyStmt) {
|
|
140
|
+
if (stmt.toString().startsWith(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END) && firstAndEndPos === -1) {
|
|
141
|
+
firstAndEndPos = i;
|
|
142
|
+
firstConditionalOperatorNo = stmt.toString().replace(ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_END, '');
|
|
143
|
+
}
|
|
144
|
+
else if (stmt.toString() === ArkIRTransformer_2.ArkCxxIRTransformer.DUMMY_IF_OPERATOR_AND_SIGNAL + firstConditionalOperatorNo) {
|
|
145
|
+
firstAndSignalPos = i;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return { firstAndSignalPos, firstAndEndPos };
|
|
150
|
+
}
|
|
151
|
+
generateBlock(sourceStmts) {
|
|
152
|
+
const generatedBlock = new BasicBlock_1.BasicBlock();
|
|
153
|
+
sourceStmts.forEach(stmt => generatedBlock.addStmt(stmt));
|
|
154
|
+
return {
|
|
155
|
+
generatedTopBlock: generatedBlock,
|
|
156
|
+
generatedBottomBlocks: [generatedBlock],
|
|
157
|
+
generatedAllBlocks: [generatedBlock],
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
exports.CxxIfBuilder = CxxIfBuilder;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { BasicBlock } from '../../../../core/graph/BasicBlock';
|
|
2
|
+
import { BlockBuilder } from './CfgBuilder';
|
|
3
|
+
/**
|
|
4
|
+
* Builder for loop in CFG
|
|
5
|
+
*/
|
|
6
|
+
export declare class CxxLoopBuilder {
|
|
7
|
+
rebuildBlocksInLoop(blockBuilderToCfgBlock: Map<BlockBuilder, BasicBlock>, blocksContainLoopCondition: Set<BlockBuilder>, basicBlockSet: Set<BasicBlock>, blockBuilders: BlockBuilder[]): void;
|
|
8
|
+
private doesPrevBlockBuilderContainLoop;
|
|
9
|
+
private insertBeforeConditionBlockBuilder;
|
|
10
|
+
private getBlockFromMap;
|
|
11
|
+
private collectBlocksBeforeAndReenter;
|
|
12
|
+
private getCollectedBlocks;
|
|
13
|
+
private createAndLinkBlocks;
|
|
14
|
+
private updatePredecessors;
|
|
15
|
+
private getNewPrevBlocks;
|
|
16
|
+
private updateConditionBlockBuilder;
|
|
17
|
+
private finalizeInsertion;
|
|
18
|
+
private findIteratorIdx;
|
|
19
|
+
private adjustIncrementorStmts;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=LoopBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoopBuilder.d.ts","sourceRoot":"","sources":["../../../../../src/frontend/cppFrontend/graph/builder/LoopBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAI/D,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAI5C;;GAEG;AACH,qBAAa,cAAc;IAChB,mBAAmB,CACtB,sBAAsB,EAAE,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,EACrD,0BAA0B,EAAE,GAAG,CAAC,YAAY,CAAC,EAC7C,aAAa,EAAE,GAAG,CAAC,UAAU,CAAC,EAC9B,aAAa,EAAE,YAAY,EAAE,GAC9B,IAAI;IAqEP,OAAO,CAAC,+BAA+B;IAWvC,OAAO,CAAC,iCAAiC;IA4DzC,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,6BAA6B;IAgCrC,OAAO,CAAC,kBAAkB;IAmB1B,OAAO,CAAC,mBAAmB;IAoB3B,OAAO,CAAC,kBAAkB;IAmB1B,OAAO,CAAC,gBAAgB;IA2BxB,OAAO,CAAC,2BAA2B;IAWnC,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,eAAe;IAoCvB,OAAO,CAAC,sBAAsB;CAoDjC"}
|