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.
Files changed (422) hide show
  1. package/README.en.md +69 -65
  2. package/README.md +56 -70
  3. package/config/arkanalyzer.json +7 -2
  4. package/docs/cppFrontend/ArkAnalyzer-cpp_usage_guide.md +245 -0
  5. package/docs/cppFrontend/cpp_frontend_build_guide.md +126 -0
  6. package/docs/cppFrontend/cpp_frontend_user_guide.md +175 -0
  7. package/docs/cppFrontend/img.png +0 -0
  8. package/docs/cppFrontend/img_1.png +0 -0
  9. package/docs/cppFrontend/img_10.png +0 -0
  10. package/docs/cppFrontend/img_11.png +0 -0
  11. package/docs/cppFrontend/img_12.png +0 -0
  12. package/docs/cppFrontend/img_13.png +0 -0
  13. package/docs/cppFrontend/img_14.png +0 -0
  14. package/docs/cppFrontend/img_15.png +0 -0
  15. package/docs/cppFrontend/img_16.png +0 -0
  16. package/docs/cppFrontend/img_17.png +0 -0
  17. package/docs/cppFrontend/img_18.png +0 -0
  18. package/docs/cppFrontend/img_19.png +0 -0
  19. package/docs/cppFrontend/img_2.png +0 -0
  20. package/docs/cppFrontend/img_20.png +0 -0
  21. package/docs/cppFrontend/img_21.png +0 -0
  22. package/docs/cppFrontend/img_22.png +0 -0
  23. package/docs/cppFrontend/img_23.png +0 -0
  24. package/docs/cppFrontend/img_3.png +0 -0
  25. package/docs/cppFrontend/img_4.png +0 -0
  26. package/docs/cppFrontend/img_5.png +0 -0
  27. package/docs/cppFrontend/img_6.png +0 -0
  28. package/docs/cppFrontend/img_7.png +0 -0
  29. package/docs/cppFrontend/img_8.png +0 -0
  30. package/docs/cppFrontend/img_9.png +0 -0
  31. package/docs/sig_programanalysis.en.md +66 -0
  32. package/docs/sig_programanalysis.md +73 -0
  33. package/lib/Config.d.ts +35 -1
  34. package/lib/Config.d.ts.map +1 -1
  35. package/lib/Config.js +91 -2
  36. package/lib/Scene.d.ts +25 -2
  37. package/lib/Scene.d.ts.map +1 -1
  38. package/lib/Scene.js +151 -44
  39. package/lib/callgraph/algorithm/AbstractAnalysis.d.ts +4 -3
  40. package/lib/callgraph/algorithm/AbstractAnalysis.d.ts.map +1 -1
  41. package/lib/callgraph/algorithm/AbstractAnalysis.js +17 -17
  42. package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts +6 -1
  43. package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts.map +1 -1
  44. package/lib/callgraph/algorithm/RapidTypeAnalysis.js +117 -14
  45. package/lib/callgraph/common/Statistics.d.ts +4 -2
  46. package/lib/callgraph/common/Statistics.d.ts.map +1 -1
  47. package/lib/callgraph/common/Statistics.js +14 -2
  48. package/lib/callgraph/model/CallGraph.d.ts +12 -8
  49. package/lib/callgraph/model/CallGraph.d.ts.map +1 -1
  50. package/lib/callgraph/model/CallGraph.js +53 -29
  51. package/lib/callgraph/model/builder/CallGraphBuilder.d.ts +1 -0
  52. package/lib/callgraph/model/builder/CallGraphBuilder.d.ts.map +1 -1
  53. package/lib/callgraph/model/builder/CallGraphBuilder.js +5 -1
  54. package/lib/callgraph/pointerAnalysis/Pag.d.ts.map +1 -1
  55. package/lib/callgraph/pointerAnalysis/Pag.js +3 -0
  56. package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +4 -2
  57. package/lib/cli/cli.d.ts +3 -0
  58. package/lib/cli/cli.d.ts.map +1 -0
  59. package/lib/cli/cli.js +82 -0
  60. package/lib/cli/commands/cg.d.ts +53 -0
  61. package/lib/cli/commands/cg.d.ts.map +1 -0
  62. package/lib/cli/commands/cg.js +404 -0
  63. package/lib/cli/commands/index.d.ts +6 -0
  64. package/lib/cli/commands/index.d.ts.map +1 -0
  65. package/lib/cli/commands/index.js +64 -0
  66. package/lib/cli/commands/ir.d.ts +26 -0
  67. package/lib/cli/commands/ir.d.ts.map +1 -0
  68. package/lib/cli/commands/ir.js +94 -0
  69. package/lib/core/base/Constant.d.ts +1 -1
  70. package/lib/core/base/Constant.d.ts.map +1 -1
  71. package/lib/core/base/Constant.js +1 -1
  72. package/lib/core/base/Expr.d.ts +29 -5
  73. package/lib/core/base/Expr.d.ts.map +1 -1
  74. package/lib/core/base/Expr.js +145 -23
  75. package/lib/core/base/Position.d.ts +14 -0
  76. package/lib/core/base/Position.d.ts.map +1 -1
  77. package/lib/core/base/Position.js +27 -0
  78. package/lib/core/base/Ref.d.ts +1 -0
  79. package/lib/core/base/Ref.d.ts.map +1 -1
  80. package/lib/core/base/Ref.js +4 -1
  81. package/lib/core/base/Type.d.ts +64 -24
  82. package/lib/core/base/Type.d.ts.map +1 -1
  83. package/lib/core/base/Type.js +144 -49
  84. package/lib/core/common/ArkError.d.ts +26 -2
  85. package/lib/core/common/ArkError.d.ts.map +1 -1
  86. package/lib/core/common/ArkError.js +56 -2
  87. package/lib/core/common/ArkIRTransformer.d.ts +11 -10
  88. package/lib/core/common/ArkIRTransformer.d.ts.map +1 -1
  89. package/lib/core/common/ArkIRTransformer.js +1 -1
  90. package/lib/core/common/ArkValueTransformer.d.ts +14 -12
  91. package/lib/core/common/ArkValueTransformer.d.ts.map +1 -1
  92. package/lib/core/common/ArkValueTransformer.js +1 -5
  93. package/lib/core/common/Const.d.ts +4 -0
  94. package/lib/core/common/Const.d.ts.map +1 -1
  95. package/lib/core/common/Const.js +5 -1
  96. package/lib/core/common/DummyMainCreater.d.ts +23 -13
  97. package/lib/core/common/DummyMainCreater.d.ts.map +1 -1
  98. package/lib/core/common/DummyMainCreater.js +66 -43
  99. package/lib/core/common/EtsConst.d.ts +11 -0
  100. package/lib/core/common/EtsConst.d.ts.map +1 -1
  101. package/lib/core/common/EtsConst.js +12 -1
  102. package/lib/core/common/IRInference.d.ts.map +1 -1
  103. package/lib/core/common/IRInference.js +6 -2
  104. package/lib/core/common/IRUtils.d.ts.map +1 -1
  105. package/lib/core/common/IRUtils.js +3 -33
  106. package/lib/core/common/ModelUtils.d.ts +4 -7
  107. package/lib/core/common/ModelUtils.d.ts.map +1 -1
  108. package/lib/core/common/ModelUtils.js +77 -110
  109. package/lib/core/common/SdkUtils.d.ts +1 -1
  110. package/lib/core/common/SdkUtils.d.ts.map +1 -1
  111. package/lib/core/common/SdkUtils.js +14 -5
  112. package/lib/core/common/TypeInference.d.ts.map +1 -1
  113. package/lib/core/common/TypeInference.js +9 -3
  114. package/lib/core/graph/BaseExplicitGraph.d.ts +4 -4
  115. package/lib/core/graph/BaseExplicitGraph.d.ts.map +1 -1
  116. package/lib/core/graph/BaseExplicitGraph.js +15 -8
  117. package/lib/core/graph/BasicBlock.d.ts.map +1 -1
  118. package/lib/core/graph/Scc.d.ts.map +1 -1
  119. package/lib/core/graph/Scc.js +7 -2
  120. package/lib/core/graph/builder/CfgBuilder.d.ts +10 -7
  121. package/lib/core/graph/builder/CfgBuilder.d.ts.map +1 -1
  122. package/lib/core/graph/builder/CfgBuilder.js +12 -5
  123. package/lib/core/inference/Inference.d.ts.map +1 -1
  124. package/lib/core/inference/Inference.js +7 -0
  125. package/lib/core/inference/ModelInference.d.ts +1 -1
  126. package/lib/core/inference/ModelInference.d.ts.map +1 -1
  127. package/lib/core/inference/ValueInference.d.ts +3 -2
  128. package/lib/core/inference/ValueInference.d.ts.map +1 -1
  129. package/lib/core/inference/ValueInference.js +64 -12
  130. package/lib/core/inference/abc/AbcInference.d.ts +28 -2
  131. package/lib/core/inference/abc/AbcInference.d.ts.map +1 -1
  132. package/lib/core/inference/abc/AbcInference.js +105 -4
  133. package/lib/core/model/ArkBaseModel.d.ts +14 -1
  134. package/lib/core/model/ArkBaseModel.d.ts.map +1 -1
  135. package/lib/core/model/ArkBaseModel.js +61 -2
  136. package/lib/core/model/ArkBody.d.ts.map +1 -1
  137. package/lib/core/model/ArkBody.js +1 -3
  138. package/lib/core/model/ArkClass.d.ts +25 -2
  139. package/lib/core/model/ArkClass.d.ts.map +1 -1
  140. package/lib/core/model/ArkClass.js +72 -30
  141. package/lib/core/model/ArkField.d.ts.map +1 -1
  142. package/lib/core/model/ArkField.js +3 -1
  143. package/lib/core/model/ArkFile.d.ts +4 -1
  144. package/lib/core/model/ArkFile.d.ts.map +1 -1
  145. package/lib/core/model/ArkFile.js +44 -3
  146. package/lib/core/model/ArkImport.d.ts.map +1 -1
  147. package/lib/core/model/ArkImport.js +9 -1
  148. package/lib/core/model/ArkMetadata.d.ts +32 -1
  149. package/lib/core/model/ArkMetadata.d.ts.map +1 -1
  150. package/lib/core/model/ArkMetadata.js +28 -2
  151. package/lib/core/model/ArkMethod.d.ts +5 -0
  152. package/lib/core/model/ArkMethod.d.ts.map +1 -1
  153. package/lib/core/model/ArkMethod.js +33 -1
  154. package/lib/core/model/ArkNamespace.d.ts +2 -0
  155. package/lib/core/model/ArkNamespace.d.ts.map +1 -1
  156. package/lib/core/model/ArkNamespace.js +11 -0
  157. package/lib/core/model/ArkSignature.d.ts +3 -3
  158. package/lib/core/model/ArkSignature.d.ts.map +1 -1
  159. package/lib/core/model/ArkSignature.js +14 -9
  160. package/lib/core/model/builder/ArkClassBuilder.d.ts +2 -0
  161. package/lib/core/model/builder/ArkClassBuilder.d.ts.map +1 -1
  162. package/lib/core/model/builder/ArkClassBuilder.js +3 -3
  163. package/lib/core/model/builder/ArkMetadataBuilder.d.ts +21 -0
  164. package/lib/core/model/builder/ArkMetadataBuilder.d.ts.map +1 -0
  165. package/lib/core/model/builder/ArkMetadataBuilder.js +160 -0
  166. package/lib/core/model/builder/ArkMethodBuilder.d.ts +4 -1
  167. package/lib/core/model/builder/ArkMethodBuilder.d.ts.map +1 -1
  168. package/lib/core/model/builder/ArkMethodBuilder.js +50 -29
  169. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +1 -0
  170. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts.map +1 -1
  171. package/lib/core/model/builder/ArkNamespaceBuilder.js +2 -1
  172. package/lib/core/model/builder/BodyBuilder.d.ts +4 -0
  173. package/lib/core/model/builder/BodyBuilder.d.ts.map +1 -1
  174. package/lib/core/model/builder/builderUtils.d.ts +1 -0
  175. package/lib/core/model/builder/builderUtils.d.ts.map +1 -1
  176. package/lib/core/model/builder/builderUtils.js +7 -3
  177. package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.d.ts +296 -0
  178. package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.d.ts.map +1 -0
  179. package/lib/frontend/cppFrontend/ast/ArkCxxAstNode.js +145 -0
  180. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiApi.d.ts +8 -0
  181. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiApi.d.ts.map +1 -0
  182. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiApi.js +90 -0
  183. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.d.ts +8 -0
  184. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.d.ts.map +1 -0
  185. package/lib/frontend/cppFrontend/ast/astJsonNapi/napiRunner.js +183 -0
  186. package/lib/frontend/cppFrontend/ast/astParser.d.ts +25 -0
  187. package/lib/frontend/cppFrontend/ast/astParser.d.ts.map +1 -0
  188. package/lib/frontend/cppFrontend/ast/astParser.js +280 -0
  189. package/lib/frontend/cppFrontend/ast/astUtils.d.ts +18 -0
  190. package/lib/frontend/cppFrontend/ast/astUtils.d.ts.map +1 -0
  191. package/lib/frontend/cppFrontend/ast/astUtils.js +158 -0
  192. package/lib/frontend/cppFrontend/ast/const.d.ts +17 -0
  193. package/lib/frontend/cppFrontend/ast/const.d.ts.map +1 -0
  194. package/lib/frontend/cppFrontend/ast/const.js +58 -0
  195. package/lib/frontend/cppFrontend/ast/index.d.ts +5 -0
  196. package/lib/frontend/cppFrontend/ast/index.d.ts.map +1 -0
  197. package/lib/frontend/cppFrontend/ast/index.js +31 -0
  198. package/lib/frontend/cppFrontend/base/Constant.d.ts +9 -0
  199. package/lib/frontend/cppFrontend/base/Constant.d.ts.map +1 -0
  200. package/lib/frontend/cppFrontend/base/Constant.js +33 -0
  201. package/lib/frontend/cppFrontend/base/Expr.d.ts +174 -0
  202. package/lib/frontend/cppFrontend/base/Expr.d.ts.map +1 -0
  203. package/lib/frontend/cppFrontend/base/Expr.js +530 -0
  204. package/lib/frontend/cppFrontend/base/Ref.d.ts +25 -0
  205. package/lib/frontend/cppFrontend/base/Ref.d.ts.map +1 -0
  206. package/lib/frontend/cppFrontend/base/Ref.js +53 -0
  207. package/lib/frontend/cppFrontend/base/Trap.d.ts +8 -0
  208. package/lib/frontend/cppFrontend/base/Trap.d.ts.map +1 -0
  209. package/lib/frontend/cppFrontend/base/Trap.js +28 -0
  210. package/lib/frontend/cppFrontend/base/Type.d.ts +264 -0
  211. package/lib/frontend/cppFrontend/base/Type.d.ts.map +1 -0
  212. package/lib/frontend/cppFrontend/base/Type.js +600 -0
  213. package/lib/frontend/cppFrontend/common/ArkIRTransformer.d.ts +109 -0
  214. package/lib/frontend/cppFrontend/common/ArkIRTransformer.d.ts.map +1 -0
  215. package/lib/frontend/cppFrontend/common/ArkIRTransformer.js +925 -0
  216. package/lib/frontend/cppFrontend/common/ArkValueTransformer.d.ts +477 -0
  217. package/lib/frontend/cppFrontend/common/ArkValueTransformer.d.ts.map +1 -0
  218. package/lib/frontend/cppFrontend/common/ArkValueTransformer.js +2746 -0
  219. package/lib/frontend/cppFrontend/common/Builtin.d.ts +57 -0
  220. package/lib/frontend/cppFrontend/common/Builtin.d.ts.map +1 -0
  221. package/lib/frontend/cppFrontend/common/Builtin.js +106 -0
  222. package/lib/frontend/cppFrontend/common/IRInference.d.ts +94 -0
  223. package/lib/frontend/cppFrontend/common/IRInference.d.ts.map +1 -0
  224. package/lib/frontend/cppFrontend/common/IRInference.js +1087 -0
  225. package/lib/frontend/cppFrontend/common/IRUtils.d.ts +23 -0
  226. package/lib/frontend/cppFrontend/common/IRUtils.d.ts.map +1 -0
  227. package/lib/frontend/cppFrontend/common/IRUtils.js +168 -0
  228. package/lib/frontend/cppFrontend/common/ModelUtils.d.ts +44 -0
  229. package/lib/frontend/cppFrontend/common/ModelUtils.d.ts.map +1 -0
  230. package/lib/frontend/cppFrontend/common/ModelUtils.js +567 -0
  231. package/lib/frontend/cppFrontend/common/TypeInference.d.ts +278 -0
  232. package/lib/frontend/cppFrontend/common/TypeInference.d.ts.map +1 -0
  233. package/lib/frontend/cppFrontend/common/TypeInference.js +1354 -0
  234. package/lib/frontend/cppFrontend/common/ValueUtil.d.ts +16 -0
  235. package/lib/frontend/cppFrontend/common/ValueUtil.d.ts.map +1 -0
  236. package/lib/frontend/cppFrontend/common/ValueUtil.js +61 -0
  237. package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.d.ts +182 -0
  238. package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.d.ts.map +1 -0
  239. package/lib/frontend/cppFrontend/graph/builder/CfgBuilder.js +1435 -0
  240. package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.d.ts +21 -0
  241. package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.d.ts.map +1 -0
  242. package/lib/frontend/cppFrontend/graph/builder/ConditionBuilder.js +303 -0
  243. package/lib/frontend/cppFrontend/graph/builder/IfBuilder.d.ts +15 -0
  244. package/lib/frontend/cppFrontend/graph/builder/IfBuilder.d.ts.map +1 -0
  245. package/lib/frontend/cppFrontend/graph/builder/IfBuilder.js +161 -0
  246. package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.d.ts +21 -0
  247. package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.d.ts.map +1 -0
  248. package/lib/frontend/cppFrontend/graph/builder/LoopBuilder.js +261 -0
  249. package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.d.ts +12 -0
  250. package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.d.ts.map +1 -0
  251. package/lib/frontend/cppFrontend/graph/builder/SwitchBuilder.js +155 -0
  252. package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.d.ts +29 -0
  253. package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.d.ts.map +1 -0
  254. package/lib/frontend/cppFrontend/graph/builder/TrapBuilder.js +302 -0
  255. package/lib/frontend/cppFrontend/inference/CxxInference.d.ts +10 -0
  256. package/lib/frontend/cppFrontend/inference/CxxInference.d.ts.map +1 -0
  257. package/lib/frontend/cppFrontend/inference/CxxInference.js +41 -0
  258. package/lib/frontend/cppFrontend/inference/CxxModelInference.d.ts +28 -0
  259. package/lib/frontend/cppFrontend/inference/CxxModelInference.d.ts.map +1 -0
  260. package/lib/frontend/cppFrontend/inference/CxxModelInference.js +98 -0
  261. package/lib/frontend/cppFrontend/inference/CxxValueInference.d.ts +20 -0
  262. package/lib/frontend/cppFrontend/inference/CxxValueInference.d.ts.map +1 -0
  263. package/lib/frontend/cppFrontend/inference/CxxValueInference.js +128 -0
  264. package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.d.ts +11 -0
  265. package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.d.ts.map +1 -0
  266. package/lib/frontend/cppFrontend/model/builder/ArkClassBuilder.js +413 -0
  267. package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.d.ts +5 -0
  268. package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.d.ts.map +1 -0
  269. package/lib/frontend/cppFrontend/model/builder/ArkFieldBuilder.js +61 -0
  270. package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.d.ts +17 -0
  271. package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.d.ts.map +1 -0
  272. package/lib/frontend/cppFrontend/model/builder/ArkFileBuilder.js +284 -0
  273. package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.d.ts +6 -0
  274. package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.d.ts.map +1 -0
  275. package/lib/frontend/cppFrontend/model/builder/ArkImportBuilder.js +57 -0
  276. package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.d.ts +14 -0
  277. package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.d.ts.map +1 -0
  278. package/lib/frontend/cppFrontend/model/builder/ArkMethodBuilder.js +422 -0
  279. package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.d.ts +8 -0
  280. package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.d.ts.map +1 -0
  281. package/lib/frontend/cppFrontend/model/builder/ArkNamespaceBuilder.js +194 -0
  282. package/lib/frontend/cppFrontend/model/builder/BodyBuilder.d.ts +59 -0
  283. package/lib/frontend/cppFrontend/model/builder/BodyBuilder.d.ts.map +1 -0
  284. package/lib/frontend/cppFrontend/model/builder/BodyBuilder.js +605 -0
  285. package/lib/frontend/cppFrontend/model/builder/builderUtils.d.ts +46 -0
  286. package/lib/frontend/cppFrontend/model/builder/builderUtils.d.ts.map +1 -0
  287. package/lib/frontend/cppFrontend/model/builder/builderUtils.js +499 -0
  288. package/lib/frontend/cppFrontend/utils/cmakeUtils.d.ts +44 -0
  289. package/lib/frontend/cppFrontend/utils/cmakeUtils.d.ts.map +1 -0
  290. package/lib/frontend/cppFrontend/utils/cmakeUtils.js +240 -0
  291. package/lib/index.d.ts +2 -1
  292. package/lib/index.d.ts.map +1 -1
  293. package/lib/index.js +8 -1
  294. package/lib/node_modules/ohos-typescript/.ohos-typescript-version +1 -0
  295. package/{node_modules → lib/node_modules}/ohos-typescript/package.json +2 -1
  296. package/lib/save/CGJsonPrinter.d.ts +8 -0
  297. package/lib/save/CGJsonPrinter.d.ts.map +1 -0
  298. package/lib/save/CGJsonPrinter.js +41 -0
  299. package/lib/save/GraphPrinter.js +2 -2
  300. package/lib/save/json/JsonDto.d.ts +86 -2
  301. package/lib/save/json/JsonDto.d.ts.map +1 -1
  302. package/lib/save/json/JsonSerialization.d.ts +1 -1
  303. package/lib/save/json/JsonSerialization.d.ts.map +1 -1
  304. package/lib/save/json/JsonSerialization.js +235 -145
  305. package/lib/save/source/SourceStmt.d.ts.map +1 -1
  306. package/lib/save/source/SourceStmt.js +3 -1
  307. package/lib/save/source/SourceTransformer.d.ts.map +1 -1
  308. package/lib/save/source/SourceTransformer.js +0 -3
  309. package/lib/utils/CxxSceneUtils.d.ts +11 -0
  310. package/lib/utils/CxxSceneUtils.d.ts.map +1 -0
  311. package/lib/utils/CxxSceneUtils.js +178 -0
  312. package/lib/utils/FileUtils.d.ts +8 -8
  313. package/lib/utils/FileUtils.d.ts.map +1 -1
  314. package/lib/utils/FileUtils.js +35 -45
  315. package/lib/utils/LRUCacheDecorator.d.ts +20 -0
  316. package/lib/utils/LRUCacheDecorator.d.ts.map +1 -0
  317. package/lib/utils/LRUCacheDecorator.js +89 -0
  318. package/lib/utils/ModuleUtils.d.ts +39 -0
  319. package/lib/utils/ModuleUtils.d.ts.map +1 -0
  320. package/lib/utils/ModuleUtils.js +261 -0
  321. package/package.json +13 -7
  322. /package/{node_modules → lib/node_modules}/ohos-typescript/LICENSE +0 -0
  323. /package/{node_modules → lib/node_modules}/ohos-typescript/README.OpenSource +0 -0
  324. /package/{node_modules → lib/node_modules}/ohos-typescript/README.md +0 -0
  325. /package/{node_modules → lib/node_modules}/ohos-typescript/SECURITY.md +0 -0
  326. /package/{node_modules → lib/node_modules}/ohos-typescript/ThirdPartyNoticeText.txt +0 -0
  327. /package/{node_modules → lib/node_modules}/ohos-typescript/bin/tsc +0 -0
  328. /package/{node_modules → lib/node_modules}/ohos-typescript/bin/tsserver +0 -0
  329. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/README.md +0 -0
  330. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/cancellationToken.js +0 -0
  331. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/cs/diagnosticMessages.generated.json +0 -0
  332. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/de/diagnosticMessages.generated.json +0 -0
  333. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/es/diagnosticMessages.generated.json +0 -0
  334. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/fr/diagnosticMessages.generated.json +0 -0
  335. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/it/diagnosticMessages.generated.json +0 -0
  336. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ja/diagnosticMessages.generated.json +0 -0
  337. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ko/diagnosticMessages.generated.json +0 -0
  338. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.d.ts +0 -0
  339. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.dom.d.ts +0 -0
  340. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.dom.iterable.d.ts +0 -0
  341. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.collection.d.ts +0 -0
  342. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.core.d.ts +0 -0
  343. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.d.ts +0 -0
  344. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.generator.d.ts +0 -0
  345. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.iterable.d.ts +0 -0
  346. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.promise.d.ts +0 -0
  347. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.proxy.d.ts +0 -0
  348. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.reflect.d.ts +0 -0
  349. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.symbol.d.ts +0 -0
  350. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2015.symbol.wellknown.d.ts +0 -0
  351. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.array.include.d.ts +0 -0
  352. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.d.ts +0 -0
  353. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2016.full.d.ts +0 -0
  354. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.d.ts +0 -0
  355. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.full.d.ts +0 -0
  356. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.intl.d.ts +0 -0
  357. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.object.d.ts +0 -0
  358. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.sharedmemory.d.ts +0 -0
  359. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.string.d.ts +0 -0
  360. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2017.typedarrays.d.ts +0 -0
  361. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.asyncgenerator.d.ts +0 -0
  362. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.asynciterable.d.ts +0 -0
  363. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.d.ts +0 -0
  364. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.full.d.ts +0 -0
  365. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.intl.d.ts +0 -0
  366. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.promise.d.ts +0 -0
  367. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2018.regexp.d.ts +0 -0
  368. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.array.d.ts +0 -0
  369. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.d.ts +0 -0
  370. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.full.d.ts +0 -0
  371. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.intl.d.ts +0 -0
  372. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.object.d.ts +0 -0
  373. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.string.d.ts +0 -0
  374. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2019.symbol.d.ts +0 -0
  375. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.bigint.d.ts +0 -0
  376. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.d.ts +0 -0
  377. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.date.d.ts +0 -0
  378. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.full.d.ts +0 -0
  379. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.intl.d.ts +0 -0
  380. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.number.d.ts +0 -0
  381. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.promise.d.ts +0 -0
  382. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.sharedmemory.d.ts +0 -0
  383. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.string.d.ts +0 -0
  384. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2020.symbol.wellknown.d.ts +0 -0
  385. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.d.ts +0 -0
  386. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.full.d.ts +0 -0
  387. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.intl.d.ts +0 -0
  388. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.promise.d.ts +0 -0
  389. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.string.d.ts +0 -0
  390. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2021.weakref.d.ts +0 -0
  391. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.array.d.ts +0 -0
  392. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.d.ts +0 -0
  393. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.error.d.ts +0 -0
  394. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.full.d.ts +0 -0
  395. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.intl.d.ts +0 -0
  396. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.object.d.ts +0 -0
  397. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.sharedmemory.d.ts +0 -0
  398. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es2022.string.d.ts +0 -0
  399. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es5.d.ts +0 -0
  400. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.es6.d.ts +0 -0
  401. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.d.ts +0 -0
  402. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.full.d.ts +0 -0
  403. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.esnext.intl.d.ts +0 -0
  404. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.scripthost.d.ts +0 -0
  405. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.d.ts +0 -0
  406. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.importscripts.d.ts +0 -0
  407. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/lib.webworker.iterable.d.ts +0 -0
  408. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/pl/diagnosticMessages.generated.json +0 -0
  409. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/pt-br/diagnosticMessages.generated.json +0 -0
  410. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/ru/diagnosticMessages.generated.json +0 -0
  411. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tr/diagnosticMessages.generated.json +0 -0
  412. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsc.js +0 -0
  413. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserver.js +0 -0
  414. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserverlibrary.d.ts +0 -0
  415. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/tsserverlibrary.js +0 -0
  416. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typesMap.json +0 -0
  417. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typescript.d.ts +0 -0
  418. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typescript.js +0 -0
  419. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/typingsInstaller.js +0 -0
  420. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/watchGuard.js +0 -0
  421. /package/{node_modules → lib/node_modules}/ohos-typescript/lib/zh-cn/diagnosticMessages.generated.json +0 -0
  422. /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"}