arkanalyzer 1.0.5

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 (322) hide show
  1. package/LICENSE +201 -0
  2. package/README.en.md +88 -0
  3. package/README.md +98 -0
  4. package/docs/HowToCreatePR.md +55 -0
  5. package/docs/HowToHandleIssues.md +155 -0
  6. package/docs/quickstart.pdf +0 -0
  7. package/lib/Config.d.ts +26 -0
  8. package/lib/Config.d.ts.map +1 -0
  9. package/lib/Config.js +128 -0
  10. package/lib/Scene.d.ts +125 -0
  11. package/lib/Scene.d.ts.map +1 -0
  12. package/lib/Scene.js +762 -0
  13. package/lib/callgraph/algorithm/AbstractAnalysis.d.ts +28 -0
  14. package/lib/callgraph/algorithm/AbstractAnalysis.d.ts.map +1 -0
  15. package/lib/callgraph/algorithm/AbstractAnalysis.js +137 -0
  16. package/lib/callgraph/algorithm/ClassHierarchyAnalysis.d.ts +11 -0
  17. package/lib/callgraph/algorithm/ClassHierarchyAnalysis.d.ts.map +1 -0
  18. package/lib/callgraph/algorithm/ClassHierarchyAnalysis.js +71 -0
  19. package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts +16 -0
  20. package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts.map +1 -0
  21. package/lib/callgraph/algorithm/RapidTypeAnalysis.js +147 -0
  22. package/lib/callgraph/common/Statistics.d.ts +58 -0
  23. package/lib/callgraph/common/Statistics.d.ts.map +1 -0
  24. package/lib/callgraph/common/Statistics.js +203 -0
  25. package/lib/callgraph/model/BaseGraph.d.ts +62 -0
  26. package/lib/callgraph/model/BaseGraph.d.ts.map +1 -0
  27. package/lib/callgraph/model/BaseGraph.js +158 -0
  28. package/lib/callgraph/model/CallGraph.d.ts +94 -0
  29. package/lib/callgraph/model/CallGraph.d.ts.map +1 -0
  30. package/lib/callgraph/model/CallGraph.js +339 -0
  31. package/lib/callgraph/model/builder/CallGraphBuilder.d.ts +16 -0
  32. package/lib/callgraph/model/builder/CallGraphBuilder.d.ts.map +1 -0
  33. package/lib/callgraph/model/builder/CallGraphBuilder.js +106 -0
  34. package/lib/callgraph/pointerAnalysis/Context.d.ts +38 -0
  35. package/lib/callgraph/pointerAnalysis/Context.d.ts.map +1 -0
  36. package/lib/callgraph/pointerAnalysis/Context.js +156 -0
  37. package/lib/callgraph/pointerAnalysis/DummyCallCreator.d.ts +23 -0
  38. package/lib/callgraph/pointerAnalysis/DummyCallCreator.d.ts.map +1 -0
  39. package/lib/callgraph/pointerAnalysis/DummyCallCreator.js +104 -0
  40. package/lib/callgraph/pointerAnalysis/Pag.d.ts +209 -0
  41. package/lib/callgraph/pointerAnalysis/Pag.d.ts.map +1 -0
  42. package/lib/callgraph/pointerAnalysis/Pag.js +774 -0
  43. package/lib/callgraph/pointerAnalysis/PagBuilder.d.ts +88 -0
  44. package/lib/callgraph/pointerAnalysis/PagBuilder.d.ts.map +1 -0
  45. package/lib/callgraph/pointerAnalysis/PagBuilder.js +821 -0
  46. package/lib/callgraph/pointerAnalysis/PointerAnalysis.d.ts +64 -0
  47. package/lib/callgraph/pointerAnalysis/PointerAnalysis.d.ts.map +1 -0
  48. package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +502 -0
  49. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.d.ts +9 -0
  50. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.d.ts.map +1 -0
  51. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.js +57 -0
  52. package/lib/callgraph/pointerAnalysis/PtsDS.d.ts +58 -0
  53. package/lib/callgraph/pointerAnalysis/PtsDS.d.ts.map +1 -0
  54. package/lib/callgraph/pointerAnalysis/PtsDS.js +234 -0
  55. package/lib/core/base/Constant.d.ts +17 -0
  56. package/lib/core/base/Constant.d.ts.map +1 -0
  57. package/lib/core/base/Constant.js +53 -0
  58. package/lib/core/base/Decorator.d.ts +15 -0
  59. package/lib/core/base/Decorator.d.ts.map +1 -0
  60. package/lib/core/base/Decorator.js +43 -0
  61. package/lib/core/base/DefUseChain.d.ts +9 -0
  62. package/lib/core/base/DefUseChain.d.ts.map +1 -0
  63. package/lib/core/base/DefUseChain.js +25 -0
  64. package/lib/core/base/Expr.d.ts +219 -0
  65. package/lib/core/base/Expr.d.ts.map +1 -0
  66. package/lib/core/base/Expr.js +896 -0
  67. package/lib/core/base/Local.d.ts +40 -0
  68. package/lib/core/base/Local.d.ts.map +1 -0
  69. package/lib/core/base/Local.js +101 -0
  70. package/lib/core/base/Position.d.ts +39 -0
  71. package/lib/core/base/Position.d.ts.map +1 -0
  72. package/lib/core/base/Position.js +86 -0
  73. package/lib/core/base/Ref.d.ts +75 -0
  74. package/lib/core/base/Ref.d.ts.map +1 -0
  75. package/lib/core/base/Ref.js +286 -0
  76. package/lib/core/base/Stmt.d.ts +109 -0
  77. package/lib/core/base/Stmt.d.ts.map +1 -0
  78. package/lib/core/base/Stmt.js +374 -0
  79. package/lib/core/base/Type.d.ts +220 -0
  80. package/lib/core/base/Type.d.ts.map +1 -0
  81. package/lib/core/base/Type.js +477 -0
  82. package/lib/core/base/Value.d.ts +11 -0
  83. package/lib/core/base/Value.d.ts.map +1 -0
  84. package/lib/core/base/Value.js +16 -0
  85. package/lib/core/common/ArkIRTransformer.d.ts +101 -0
  86. package/lib/core/common/ArkIRTransformer.d.ts.map +1 -0
  87. package/lib/core/common/ArkIRTransformer.js +1674 -0
  88. package/lib/core/common/BodyBuilder.d.ts +10 -0
  89. package/lib/core/common/BodyBuilder.d.ts.map +1 -0
  90. package/lib/core/common/BodyBuilder.js +34 -0
  91. package/lib/core/common/Builtin.d.ts +35 -0
  92. package/lib/core/common/Builtin.d.ts.map +1 -0
  93. package/lib/core/common/Builtin.js +78 -0
  94. package/lib/core/common/CfgBuilder.d.ts +136 -0
  95. package/lib/core/common/CfgBuilder.d.ts.map +1 -0
  96. package/lib/core/common/CfgBuilder.js +1241 -0
  97. package/lib/core/common/Const.d.ts +15 -0
  98. package/lib/core/common/Const.d.ts.map +1 -0
  99. package/lib/core/common/Const.js +34 -0
  100. package/lib/core/common/DummyMainCreater.d.ts +48 -0
  101. package/lib/core/common/DummyMainCreater.d.ts.map +1 -0
  102. package/lib/core/common/DummyMainCreater.js +433 -0
  103. package/lib/core/common/EtsConst.d.ts +65 -0
  104. package/lib/core/common/EtsConst.d.ts.map +1 -0
  105. package/lib/core/common/EtsConst.js +918 -0
  106. package/lib/core/common/ExprUseReplacer.d.ts +18 -0
  107. package/lib/core/common/ExprUseReplacer.d.ts.map +1 -0
  108. package/lib/core/common/ExprUseReplacer.js +88 -0
  109. package/lib/core/common/IRUtils.d.ts +7 -0
  110. package/lib/core/common/IRUtils.d.ts.map +1 -0
  111. package/lib/core/common/IRUtils.js +39 -0
  112. package/lib/core/common/ModelUtils.d.ts +61 -0
  113. package/lib/core/common/ModelUtils.d.ts.map +1 -0
  114. package/lib/core/common/ModelUtils.js +628 -0
  115. package/lib/core/common/RefUseReplacer.d.ts +14 -0
  116. package/lib/core/common/RefUseReplacer.d.ts.map +1 -0
  117. package/lib/core/common/RefUseReplacer.js +50 -0
  118. package/lib/core/common/StmtUseReplacer.d.ts +16 -0
  119. package/lib/core/common/StmtUseReplacer.d.ts.map +1 -0
  120. package/lib/core/common/StmtUseReplacer.js +88 -0
  121. package/lib/core/common/TSConst.d.ts +11 -0
  122. package/lib/core/common/TSConst.d.ts.map +1 -0
  123. package/lib/core/common/TSConst.js +28 -0
  124. package/lib/core/common/TypeInference.d.ts +44 -0
  125. package/lib/core/common/TypeInference.d.ts.map +1 -0
  126. package/lib/core/common/TypeInference.js +519 -0
  127. package/lib/core/common/ValueUtil.d.ts +17 -0
  128. package/lib/core/common/ValueUtil.d.ts.map +1 -0
  129. package/lib/core/common/ValueUtil.js +71 -0
  130. package/lib/core/common/VisibleValue.d.ts +37 -0
  131. package/lib/core/common/VisibleValue.d.ts.map +1 -0
  132. package/lib/core/common/VisibleValue.js +212 -0
  133. package/lib/core/dataflow/DataflowProblem.d.ts +21 -0
  134. package/lib/core/dataflow/DataflowProblem.d.ts.map +1 -0
  135. package/lib/core/dataflow/DataflowProblem.js +33 -0
  136. package/lib/core/dataflow/DataflowResult.d.ts +8 -0
  137. package/lib/core/dataflow/DataflowResult.d.ts.map +1 -0
  138. package/lib/core/dataflow/DataflowResult.js +26 -0
  139. package/lib/core/dataflow/DataflowSolver.d.ts +40 -0
  140. package/lib/core/dataflow/DataflowSolver.d.ts.map +1 -0
  141. package/lib/core/dataflow/DataflowSolver.js +318 -0
  142. package/lib/core/dataflow/Edge.d.ts +16 -0
  143. package/lib/core/dataflow/Edge.d.ts.map +1 -0
  144. package/lib/core/dataflow/Edge.js +40 -0
  145. package/lib/core/dataflow/Fact.d.ts +7 -0
  146. package/lib/core/dataflow/Fact.d.ts.map +1 -0
  147. package/lib/core/dataflow/Fact.js +24 -0
  148. package/lib/core/dataflow/TiantAnalysis.d.ts +37 -0
  149. package/lib/core/dataflow/TiantAnalysis.d.ts.map +1 -0
  150. package/lib/core/dataflow/TiantAnalysis.js +326 -0
  151. package/lib/core/dataflow/UndefinedVariable.d.ts +32 -0
  152. package/lib/core/dataflow/UndefinedVariable.d.ts.map +1 -0
  153. package/lib/core/dataflow/UndefinedVariable.js +235 -0
  154. package/lib/core/dataflow/Util.d.ts +8 -0
  155. package/lib/core/dataflow/Util.d.ts.map +1 -0
  156. package/lib/core/dataflow/Util.js +137 -0
  157. package/lib/core/graph/BasicBlock.d.ts +26 -0
  158. package/lib/core/graph/BasicBlock.d.ts.map +1 -0
  159. package/lib/core/graph/BasicBlock.js +92 -0
  160. package/lib/core/graph/Cfg.d.ts +29 -0
  161. package/lib/core/graph/Cfg.d.ts.map +1 -0
  162. package/lib/core/graph/Cfg.js +154 -0
  163. package/lib/core/graph/DominanceFinder.d.ts +16 -0
  164. package/lib/core/graph/DominanceFinder.d.ts.map +1 -0
  165. package/lib/core/graph/DominanceFinder.js +121 -0
  166. package/lib/core/graph/DominanceTree.d.ts +13 -0
  167. package/lib/core/graph/DominanceTree.d.ts.map +1 -0
  168. package/lib/core/graph/DominanceTree.js +70 -0
  169. package/lib/core/graph/ViewTree.d.ts +115 -0
  170. package/lib/core/graph/ViewTree.d.ts.map +1 -0
  171. package/lib/core/graph/ViewTree.js +16 -0
  172. package/lib/core/graph/builder/ViewTreeBuilder.d.ts +204 -0
  173. package/lib/core/graph/builder/ViewTreeBuilder.d.ts.map +1 -0
  174. package/lib/core/graph/builder/ViewTreeBuilder.js +1046 -0
  175. package/lib/core/model/ArkBody.d.ts +22 -0
  176. package/lib/core/model/ArkBody.d.ts.map +1 -0
  177. package/lib/core/model/ArkBody.js +63 -0
  178. package/lib/core/model/ArkClass.d.ts +110 -0
  179. package/lib/core/model/ArkClass.d.ts.map +1 -0
  180. package/lib/core/model/ArkClass.js +315 -0
  181. package/lib/core/model/ArkExport.d.ts +70 -0
  182. package/lib/core/model/ArkExport.d.ts.map +1 -0
  183. package/lib/core/model/ArkExport.js +143 -0
  184. package/lib/core/model/ArkField.d.ts +60 -0
  185. package/lib/core/model/ArkField.d.ts.map +1 -0
  186. package/lib/core/model/ArkField.js +157 -0
  187. package/lib/core/model/ArkFile.d.ts +62 -0
  188. package/lib/core/model/ArkFile.d.ts.map +1 -0
  189. package/lib/core/model/ArkFile.js +160 -0
  190. package/lib/core/model/ArkImport.d.ts +43 -0
  191. package/lib/core/model/ArkImport.d.ts.map +1 -0
  192. package/lib/core/model/ArkImport.js +109 -0
  193. package/lib/core/model/ArkMethod.d.ts +76 -0
  194. package/lib/core/model/ArkMethod.d.ts.map +1 -0
  195. package/lib/core/model/ArkMethod.js +235 -0
  196. package/lib/core/model/ArkNamespace.d.ts +65 -0
  197. package/lib/core/model/ArkNamespace.d.ts.map +1 -0
  198. package/lib/core/model/ArkNamespace.js +182 -0
  199. package/lib/core/model/ArkSignature.d.ts +98 -0
  200. package/lib/core/model/ArkSignature.d.ts.map +1 -0
  201. package/lib/core/model/ArkSignature.js +281 -0
  202. package/lib/core/model/builder/ArkClassBuilder.d.ts +13 -0
  203. package/lib/core/model/builder/ArkClassBuilder.d.ts.map +1 -0
  204. package/lib/core/model/builder/ArkClassBuilder.js +422 -0
  205. package/lib/core/model/builder/ArkExportBuilder.d.ts +25 -0
  206. package/lib/core/model/builder/ArkExportBuilder.d.ts.map +1 -0
  207. package/lib/core/model/builder/ArkExportBuilder.js +207 -0
  208. package/lib/core/model/builder/ArkFieldBuilder.d.ts +9 -0
  209. package/lib/core/model/builder/ArkFieldBuilder.d.ts.map +1 -0
  210. package/lib/core/model/builder/ArkFieldBuilder.js +189 -0
  211. package/lib/core/model/builder/ArkFileBuilder.d.ts +10 -0
  212. package/lib/core/model/builder/ArkFileBuilder.d.ts.map +1 -0
  213. package/lib/core/model/builder/ArkFileBuilder.js +164 -0
  214. package/lib/core/model/builder/ArkImportBuilder.d.ts +4 -0
  215. package/lib/core/model/builder/ArkImportBuilder.d.ts.map +1 -0
  216. package/lib/core/model/builder/ArkImportBuilder.js +125 -0
  217. package/lib/core/model/builder/ArkMethodBuilder.d.ts +60 -0
  218. package/lib/core/model/builder/ArkMethodBuilder.d.ts.map +1 -0
  219. package/lib/core/model/builder/ArkMethodBuilder.js +419 -0
  220. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +5 -0
  221. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts.map +1 -0
  222. package/lib/core/model/builder/ArkNamespaceBuilder.js +171 -0
  223. package/lib/core/model/builder/ArkSignatureBuilder.d.ts +9 -0
  224. package/lib/core/model/builder/ArkSignatureBuilder.d.ts.map +1 -0
  225. package/lib/core/model/builder/ArkSignatureBuilder.js +40 -0
  226. package/lib/core/model/builder/builderUtils.d.ts +18 -0
  227. package/lib/core/model/builder/builderUtils.d.ts.map +1 -0
  228. package/lib/core/model/builder/builderUtils.js +449 -0
  229. package/lib/index.d.ts +77 -0
  230. package/lib/index.d.ts.map +1 -0
  231. package/lib/index.js +190 -0
  232. package/lib/save/ArkStream.d.ts +24 -0
  233. package/lib/save/ArkStream.d.ts.map +1 -0
  234. package/lib/save/ArkStream.js +83 -0
  235. package/lib/save/DotPrinter.d.ts +48 -0
  236. package/lib/save/DotPrinter.d.ts.map +1 -0
  237. package/lib/save/DotPrinter.js +229 -0
  238. package/lib/save/GraphPrinter.d.ts +17 -0
  239. package/lib/save/GraphPrinter.d.ts.map +1 -0
  240. package/lib/save/GraphPrinter.js +135 -0
  241. package/lib/save/JsonPrinter.d.ts +28 -0
  242. package/lib/save/JsonPrinter.d.ts.map +1 -0
  243. package/lib/save/JsonPrinter.js +511 -0
  244. package/lib/save/Printer.d.ts +17 -0
  245. package/lib/save/Printer.d.ts.map +1 -0
  246. package/lib/save/Printer.js +27 -0
  247. package/lib/save/PrinterBuilder.d.ts +38 -0
  248. package/lib/save/PrinterBuilder.d.ts.map +1 -0
  249. package/lib/save/PrinterBuilder.js +102 -0
  250. package/lib/save/serializeArkIR.d.ts +3 -0
  251. package/lib/save/serializeArkIR.d.ts.map +1 -0
  252. package/lib/save/serializeArkIR.js +166 -0
  253. package/lib/save/source/SourceBase.d.ts +32 -0
  254. package/lib/save/source/SourceBase.d.ts.map +1 -0
  255. package/lib/save/source/SourceBase.js +93 -0
  256. package/lib/save/source/SourceBody.d.ts +60 -0
  257. package/lib/save/source/SourceBody.d.ts.map +1 -0
  258. package/lib/save/source/SourceBody.js +292 -0
  259. package/lib/save/source/SourceClass.d.ts +27 -0
  260. package/lib/save/source/SourceClass.d.ts.map +1 -0
  261. package/lib/save/source/SourceClass.js +202 -0
  262. package/lib/save/source/SourceField.d.ts +15 -0
  263. package/lib/save/source/SourceField.d.ts.map +1 -0
  264. package/lib/save/source/SourceField.js +68 -0
  265. package/lib/save/source/SourceFilePrinter.d.ts +14 -0
  266. package/lib/save/source/SourceFilePrinter.d.ts.map +1 -0
  267. package/lib/save/source/SourceFilePrinter.js +73 -0
  268. package/lib/save/source/SourceMethod.d.ts +24 -0
  269. package/lib/save/source/SourceMethod.d.ts.map +1 -0
  270. package/lib/save/source/SourceMethod.js +170 -0
  271. package/lib/save/source/SourceModule.d.ts +18 -0
  272. package/lib/save/source/SourceModule.d.ts.map +1 -0
  273. package/lib/save/source/SourceModule.js +120 -0
  274. package/lib/save/source/SourceNamespace.d.ts +13 -0
  275. package/lib/save/source/SourceNamespace.d.ts.map +1 -0
  276. package/lib/save/source/SourceNamespace.js +80 -0
  277. package/lib/save/source/SourceStmt.d.ts +172 -0
  278. package/lib/save/source/SourceStmt.d.ts.map +1 -0
  279. package/lib/save/source/SourceStmt.js +757 -0
  280. package/lib/save/source/SourceTransformer.d.ts +37 -0
  281. package/lib/save/source/SourceTransformer.d.ts.map +1 -0
  282. package/lib/save/source/SourceTransformer.js +338 -0
  283. package/lib/save/source/SourceUtils.d.ts +25 -0
  284. package/lib/save/source/SourceUtils.d.ts.map +1 -0
  285. package/lib/save/source/SourceUtils.js +201 -0
  286. package/lib/transformer/FunctionTransformer.d.ts +3 -0
  287. package/lib/transformer/FunctionTransformer.d.ts.map +1 -0
  288. package/lib/transformer/FunctionTransformer.js +17 -0
  289. package/lib/transformer/SceneTransformer.d.ts +3 -0
  290. package/lib/transformer/SceneTransformer.d.ts.map +1 -0
  291. package/lib/transformer/SceneTransformer.js +17 -0
  292. package/lib/transformer/StaticSingleAssignmentFormer.d.ts +13 -0
  293. package/lib/transformer/StaticSingleAssignmentFormer.d.ts.map +1 -0
  294. package/lib/transformer/StaticSingleAssignmentFormer.js +259 -0
  295. package/lib/transformer/Transformer.d.ts +7 -0
  296. package/lib/transformer/Transformer.d.ts.map +1 -0
  297. package/lib/transformer/Transformer.js +22 -0
  298. package/lib/utils/CfgStructualAnalysis.d.ts +93 -0
  299. package/lib/utils/CfgStructualAnalysis.d.ts.map +1 -0
  300. package/lib/utils/CfgStructualAnalysis.js +955 -0
  301. package/lib/utils/FileUtils.d.ts +18 -0
  302. package/lib/utils/FileUtils.d.ts.map +1 -0
  303. package/lib/utils/FileUtils.js +131 -0
  304. package/lib/utils/callGraphUtils.d.ts +31 -0
  305. package/lib/utils/callGraphUtils.d.ts.map +1 -0
  306. package/lib/utils/callGraphUtils.js +208 -0
  307. package/lib/utils/entryMethodUtils.d.ts +16 -0
  308. package/lib/utils/entryMethodUtils.d.ts.map +1 -0
  309. package/lib/utils/entryMethodUtils.js +139 -0
  310. package/lib/utils/getAllFiles.d.ts +10 -0
  311. package/lib/utils/getAllFiles.d.ts.map +1 -0
  312. package/lib/utils/getAllFiles.js +91 -0
  313. package/lib/utils/json5parser.d.ts +7 -0
  314. package/lib/utils/json5parser.d.ts.map +1 -0
  315. package/lib/utils/json5parser.js +146 -0
  316. package/lib/utils/logger.d.ts +19 -0
  317. package/lib/utils/logger.d.ts.map +1 -0
  318. package/lib/utils/logger.js +90 -0
  319. package/lib/utils/pathTransfer.d.ts +2 -0
  320. package/lib/utils/pathTransfer.d.ts.map +1 -0
  321. package/lib/utils/pathTransfer.js +25 -0
  322. package/package.json +29 -0
@@ -0,0 +1,339 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright (c) 2024 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.CallGraph = exports.CallGraphNode = exports.CallGraphEdge = exports.CSCallSite = exports.DynCallSite = exports.CallSite = exports.CallGraphNodeKind = void 0;
18
+ const GraphPrinter_1 = require("../../save/GraphPrinter");
19
+ const PrinterBuilder_1 = require("../../save/PrinterBuilder");
20
+ const BaseGraph_1 = require("./BaseGraph");
21
+ const Statistics_1 = require("../common/Statistics");
22
+ var CallGraphNodeKind;
23
+ (function (CallGraphNodeKind) {
24
+ CallGraphNodeKind[CallGraphNodeKind["real"] = 0] = "real";
25
+ CallGraphNodeKind[CallGraphNodeKind["vitual"] = 1] = "vitual";
26
+ CallGraphNodeKind[CallGraphNodeKind["intrinsic"] = 2] = "intrinsic";
27
+ CallGraphNodeKind[CallGraphNodeKind["constructor"] = 3] = "constructor";
28
+ })(CallGraphNodeKind = exports.CallGraphNodeKind || (exports.CallGraphNodeKind = {}));
29
+ class CallSite {
30
+ constructor(s, a, ce, cr) {
31
+ this.callStmt = s;
32
+ this.args = a;
33
+ this.calleeFuncID = ce;
34
+ this.callerFuncID = cr;
35
+ }
36
+ }
37
+ exports.CallSite = CallSite;
38
+ class DynCallSite {
39
+ constructor(caller, s, a, ptcCallee) {
40
+ this.callerFuncID = caller;
41
+ this.callStmt = s;
42
+ this.args = a;
43
+ this.protentialCalleeFuncID = ptcCallee;
44
+ }
45
+ }
46
+ exports.DynCallSite = DynCallSite;
47
+ class CSCallSite extends CallSite {
48
+ constructor(id, cs) {
49
+ super(cs.callStmt, cs.args, cs.calleeFuncID, cs.callerFuncID);
50
+ this.cid = id;
51
+ }
52
+ }
53
+ exports.CSCallSite = CSCallSite;
54
+ class CallGraphEdge extends BaseGraph_1.BaseEdge {
55
+ // private callSiteID: CallSiteID;
56
+ constructor(src, dst) {
57
+ super(src, dst, 0);
58
+ this.directCalls = new Set();
59
+ this.specialCalls = new Set();
60
+ this.indirectCalls = new Set();
61
+ //this.callSiteID = csID;
62
+ }
63
+ addDirectCallSite(stmt) {
64
+ this.directCalls.add(stmt);
65
+ }
66
+ addSpecialCallSite(stmt) {
67
+ this.specialCalls.add(stmt);
68
+ }
69
+ addInDirectCallSite(stmt) {
70
+ this.indirectCalls.add(stmt);
71
+ }
72
+ getDotAttr() {
73
+ const indirectCallNums = this.indirectCalls.size;
74
+ const directCallNums = this.directCalls.size;
75
+ const specialCallNums = this.specialCalls.size;
76
+ if ([CallGraphNodeKind.intrinsic, CallGraphNodeKind.constructor].includes(this.getDstNode().getKind())) {
77
+ return '';
78
+ }
79
+ if (indirectCallNums != 0 && directCallNums == 0) {
80
+ return "color=red";
81
+ }
82
+ else if (specialCallNums != 0) {
83
+ return "color=yellow";
84
+ }
85
+ else if (indirectCallNums == 0 && directCallNums != 0) {
86
+ return "color=black";
87
+ }
88
+ else {
89
+ return "color=black";
90
+ }
91
+ }
92
+ }
93
+ exports.CallGraphEdge = CallGraphEdge;
94
+ class CallGraphNode extends BaseGraph_1.BaseNode {
95
+ constructor(id, m, k = CallGraphNodeKind.real) {
96
+ super(id, k);
97
+ this.isSdkMethod = false;
98
+ this.isBlank = false;
99
+ this.method = m;
100
+ }
101
+ getMethod() {
102
+ return this.method;
103
+ }
104
+ setSdkMethod(v) {
105
+ this.isSdkMethod = v;
106
+ }
107
+ getIsSdkMethod() {
108
+ return this.isSdkMethod;
109
+ }
110
+ get isBlankMethod() {
111
+ return this.isBlank;
112
+ }
113
+ set isBlankMethod(is) {
114
+ this.isBlank = is;
115
+ }
116
+ getDotAttr() {
117
+ if ([CallGraphNodeKind.intrinsic, CallGraphNodeKind.constructor].includes(this.getKind())) {
118
+ return '';
119
+ }
120
+ return 'shape=box';
121
+ }
122
+ getDotLabel() {
123
+ let label = 'ID: ' + this.getID() + '\n';
124
+ label = label + this.getMethod().toString();
125
+ return label;
126
+ }
127
+ }
128
+ exports.CallGraphNode = CallGraphNode;
129
+ class CallGraph extends BaseGraph_1.BaseGraph {
130
+ constructor(s) {
131
+ super();
132
+ this.idToCallSiteMap = new Map();
133
+ this.callSiteToIdMap = new Map();
134
+ this.stmtToCallSitemap = new Map();
135
+ this.stmtToDynCallSitemap = new Map();
136
+ this.methodToCGNodeMap = new Map();
137
+ this.callPairToEdgeMap = new Map();
138
+ this.callSiteNum = 0;
139
+ this.scene = s;
140
+ this.cgStat = new Statistics_1.CGStat();
141
+ }
142
+ getCallPairString(srcID, dstID) {
143
+ return `${srcID}-${dstID}`;
144
+ }
145
+ getCallEdgeByPair(srcID, dstID) {
146
+ let key = this.getCallPairString(srcID, dstID);
147
+ return this.callPairToEdgeMap.get(key);
148
+ }
149
+ addCallGraphNode(method, kind = CallGraphNodeKind.real) {
150
+ let id = this.nodeNum;
151
+ let cgNode = new CallGraphNode(id, method, kind);
152
+ // check if sdk method
153
+ cgNode.setSdkMethod(this.scene.getSdkArkFilesMap().has(method.getDeclaringClassSignature().getDeclaringFileSignature().toString()));
154
+ let arkMethod = this.scene.getMethod(method);
155
+ if (!arkMethod || !arkMethod.getCfg()) {
156
+ cgNode.isBlankMethod = true;
157
+ }
158
+ this.addNode(cgNode);
159
+ this.methodToCGNodeMap.set(method.toString(), cgNode.getID());
160
+ this.cgStat.addNodeStat(kind);
161
+ return cgNode;
162
+ }
163
+ removeCallGraphNode(nodeID) {
164
+ // remove edge relate to node first
165
+ this.removeCallGraphEdge(nodeID);
166
+ let node = this.getNode(nodeID);
167
+ // remove node itself
168
+ this.removeNode(nodeID);
169
+ this.methodToCGNodeMap.delete(node.getMethod().toString());
170
+ }
171
+ getCallGraphNodeByMethod(method) {
172
+ if (!method) {
173
+ throw new Error();
174
+ }
175
+ let n = this.methodToCGNodeMap.get(method.toString());
176
+ if (n == undefined) {
177
+ // The method can't be found
178
+ // means the method has no implementation, or base type is unclear to find it
179
+ // Create a virtual CG Node
180
+ // TODO: this virtual CG Node need be remove once the base type is clear
181
+ return this.addCallGraphNode(method, CallGraphNodeKind.vitual);
182
+ }
183
+ return this.getNode(n);
184
+ }
185
+ addDirectOrSpecialCallEdge(caller, callee, callStmt, isDirectCall = true) {
186
+ var _a;
187
+ let callerNode = this.getCallGraphNodeByMethod(caller);
188
+ let calleeNode = this.getCallGraphNodeByMethod(callee);
189
+ let args = (_a = callStmt.getInvokeExpr()) === null || _a === void 0 ? void 0 : _a.getArgs();
190
+ let cs = new CallSite(callStmt, args, calleeNode.getID(), callerNode.getID());
191
+ let csID;
192
+ if (!this.callSiteToIdMap.has(cs)) {
193
+ csID = this.callSiteNum++;
194
+ this.idToCallSiteMap.set(csID, cs);
195
+ this.callSiteToIdMap.set(cs, csID);
196
+ }
197
+ else {
198
+ csID = this.callSiteToIdMap.get(cs);
199
+ }
200
+ if (this.addStmtToCallSiteMap(callStmt, cs)) {
201
+ // TODO: check stmt exists
202
+ }
203
+ // TODO: check if edge exists
204
+ let callEdge = this.getCallEdgeByPair(callerNode.getID(), calleeNode.getID());
205
+ if (callEdge == undefined) {
206
+ callEdge = new CallGraphEdge(callerNode, calleeNode);
207
+ callEdge.getSrcNode().addOutgoingEdge(callEdge);
208
+ callEdge.getDstNode().addIncomingEdge(callEdge);
209
+ this.callPairToEdgeMap.set(this.getCallPairString(callerNode.getID(), calleeNode.getID()), callEdge);
210
+ }
211
+ if (isDirectCall) {
212
+ callEdge.addDirectCallSite(callStmt);
213
+ }
214
+ else {
215
+ callEdge.addSpecialCallSite(callStmt);
216
+ }
217
+ }
218
+ removeCallGraphEdge(nodeID) {
219
+ let node = this.getNode(nodeID);
220
+ for (const inEdge of node.getIncomingEdge()) {
221
+ node.removeIncomingEdge(inEdge);
222
+ }
223
+ for (const outEdge of node.getOutgoingEdges()) {
224
+ node.removeIncomingEdge(outEdge);
225
+ }
226
+ }
227
+ addDynamicCallInfo(callStmt, caller, protentialCallee) {
228
+ var _a;
229
+ let callerNode = this.getCallGraphNodeByMethod(caller);
230
+ let calleeNode;
231
+ if (protentialCallee) {
232
+ calleeNode = this.getCallGraphNodeByMethod(protentialCallee);
233
+ }
234
+ let args = (_a = callStmt.getInvokeExpr()) === null || _a === void 0 ? void 0 : _a.getArgs();
235
+ let cs = new DynCallSite(callerNode.getID(), callStmt, args, calleeNode === null || calleeNode === void 0 ? void 0 : calleeNode.getID());
236
+ this.stmtToDynCallSitemap.set(callStmt, cs);
237
+ }
238
+ addDynamicCallEdge(callerID, calleeID, callStmt) {
239
+ let callerNode = this.getNode(callerID);
240
+ let calleeNode = this.getNode(calleeID);
241
+ let callEdge = this.getCallEdgeByPair(callerNode.getID(), calleeNode.getID());
242
+ if (callEdge == undefined) {
243
+ callEdge = new CallGraphEdge(callerNode, calleeNode);
244
+ callEdge.getSrcNode().addOutgoingEdge(callEdge);
245
+ callEdge.getDstNode().addIncomingEdge(callEdge);
246
+ this.callPairToEdgeMap.set(this.getCallPairString(callerNode.getID(), calleeNode.getID()), callEdge);
247
+ }
248
+ callEdge.addInDirectCallSite(callStmt);
249
+ }
250
+ getDynCallsiteByStmt(stmt) {
251
+ return this.stmtToDynCallSitemap.get(stmt);
252
+ }
253
+ addStmtToCallSiteMap(stmt, cs) {
254
+ if (this.stmtToCallSitemap.has(stmt)) {
255
+ return false;
256
+ }
257
+ this.stmtToCallSitemap.set(stmt, cs);
258
+ return true;
259
+ }
260
+ getCallSiteByStmt(stmt) {
261
+ return this.stmtToCallSitemap.get(stmt);
262
+ }
263
+ getDynEdges() {
264
+ let callMap = new Map();
265
+ this.callPairToEdgeMap.forEach((edge) => {
266
+ let srcMethod = edge.getSrcNode().getMethod();
267
+ let dstMethod = edge.getDstNode().getMethod();
268
+ let dstSet;
269
+ if (callMap.has(srcMethod)) {
270
+ dstSet = callMap.get(srcMethod);
271
+ }
272
+ else {
273
+ dstSet = new Set();
274
+ }
275
+ callMap.set(srcMethod, dstSet.add(dstMethod));
276
+ });
277
+ return callMap;
278
+ }
279
+ getMethodByFuncID(id) {
280
+ let node = this.getNode(id);
281
+ if (node != undefined) {
282
+ return node.getMethod();
283
+ }
284
+ //return undefined;
285
+ return null;
286
+ }
287
+ getArkMethodByFuncID(id) {
288
+ let method = this.getMethodByFuncID(id);
289
+ if (method != null) {
290
+ // TODO: SDK Method search
291
+ return this.scene.getMethod(method);
292
+ }
293
+ return null;
294
+ }
295
+ getEntries() {
296
+ return this.entries;
297
+ }
298
+ setEntries(n) {
299
+ this.entries = n;
300
+ }
301
+ dump(name, entry) {
302
+ let printer = new GraphPrinter_1.GraphPrinter(this);
303
+ if (entry) {
304
+ printer.setStartID(entry);
305
+ }
306
+ PrinterBuilder_1.PrinterBuilder.dump(printer, name);
307
+ }
308
+ detectReachable(fromID, dstID) {
309
+ let dWorklist = [];
310
+ let travserdFuncs = new Set();
311
+ dWorklist.push(fromID);
312
+ while (dWorklist.length > 0) {
313
+ let nodeID = dWorklist.shift();
314
+ if (travserdFuncs.has(nodeID)) {
315
+ continue;
316
+ }
317
+ travserdFuncs.add(nodeID);
318
+ let node = this.getNode(nodeID);
319
+ for (let e of node.getOutgoingEdges()) {
320
+ let dst = e.getDstID();
321
+ if (dst === dstID) {
322
+ return true;
323
+ }
324
+ dWorklist.push(dst);
325
+ }
326
+ }
327
+ return false;
328
+ }
329
+ printStat() {
330
+ this.cgStat.printStat();
331
+ }
332
+ setDummyMainFuncID(dummyMainMethodID) {
333
+ this.dummyMainMethodID = dummyMainMethodID;
334
+ }
335
+ getDummyMainFuncID() {
336
+ return this.dummyMainMethodID;
337
+ }
338
+ }
339
+ exports.CallGraph = CallGraph;
@@ -0,0 +1,16 @@
1
+ import { CallGraph, Method } from '../CallGraph';
2
+ import { Scene } from '../../../Scene';
3
+ import { ArkMethod } from '../../../core/model/ArkMethod';
4
+ export declare class CallGraphBuilder {
5
+ private cg;
6
+ private scene;
7
+ constructor(c: CallGraph, s: Scene);
8
+ buildDirectCallGraphForScene(): void;
9
+ buildDirectCallGraph(methods: ArkMethod[]): void;
10
+ buildClassHierarchyCallGraph(entries: Method[], displayGeneratedMethod?: Boolean): void;
11
+ buildRapidTypeCallGraph(entries: Method[], displayGeneratedMethod?: Boolean): void;
12
+ private getDCCallee;
13
+ private isConstructor;
14
+ setEntries(): void;
15
+ }
16
+ //# sourceMappingURL=CallGraphBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CallGraphBuilder.d.ts","sourceRoot":"","sources":["../../../../src/callgraph/model/builder/CallGraphBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,SAAS,EAAoC,MAAM,EAAE,MAAM,cAAc,CAAC;AACnF,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAKvC,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAE1D,qBAAa,gBAAgB;IACzB,OAAO,CAAC,EAAE,CAAY;IACtB,OAAO,CAAC,KAAK,CAAQ;gBAET,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,KAAK;IAM3B,4BAA4B,IAAI,IAAI;IAQpC,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,GAAG,IAAI;IAyChD,4BAA4B,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,sBAAsB,GAAE,OAAe,GAAG,IAAI;IAW9F,uBAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,sBAAsB,GAAE,OAAe,GAAG,IAAI;IAYhG,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,aAAa;IAId,UAAU,IAAI,IAAI;CAQ5B"}
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright (c) 2024 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.CallGraphBuilder = void 0;
18
+ const CallGraph_1 = require("../CallGraph");
19
+ const Expr_1 = require("../../../core/base/Expr");
20
+ const ClassHierarchyAnalysis_1 = require("../../algorithm/ClassHierarchyAnalysis");
21
+ const RapidTypeAnalysis_1 = require("../../algorithm/RapidTypeAnalysis");
22
+ class CallGraphBuilder {
23
+ constructor(c, s) {
24
+ this.cg = c;
25
+ this.scene = s;
26
+ }
27
+ buildDirectCallGraphForScene() {
28
+ const methods = this.scene.getMethods();
29
+ this.buildDirectCallGraph(methods);
30
+ // set entries at end
31
+ this.setEntries();
32
+ }
33
+ buildDirectCallGraph(methods) {
34
+ var _a;
35
+ for (const method of methods) {
36
+ let m = method.getSignature();
37
+ let kind = CallGraph_1.CallGraphNodeKind.real;
38
+ if (method.isGenerated()) { // || method.getName() === '_DEFAULT_ARK_METHOD') {
39
+ kind = CallGraph_1.CallGraphNodeKind.intrinsic;
40
+ }
41
+ if (method.getName() === 'constructor') {
42
+ kind = CallGraph_1.CallGraphNodeKind.constructor;
43
+ }
44
+ this.cg.addCallGraphNode(m, kind);
45
+ }
46
+ for (const method of methods) {
47
+ let cfg = method.getCfg();
48
+ if (cfg === undefined) {
49
+ // abstract method cfg is undefined
50
+ continue;
51
+ }
52
+ let stmts = cfg.getStmts();
53
+ for (const stmt of stmts) {
54
+ let invokeExpr = stmt.getInvokeExpr();
55
+ if (invokeExpr == undefined) {
56
+ continue;
57
+ }
58
+ let callee = this.getDCCallee(invokeExpr);
59
+ // abstract method will also be added into direct cg
60
+ if (callee && invokeExpr instanceof Expr_1.ArkStaticInvokeExpr) {
61
+ this.cg.addDirectOrSpecialCallEdge(method.getSignature(), callee, stmt);
62
+ }
63
+ else if (callee && (invokeExpr instanceof Expr_1.ArkInstanceInvokeExpr && (this.isConstructor(callee) || ((_a = this.scene.getMethod(callee)) === null || _a === void 0 ? void 0 : _a.isGenerated())))) {
64
+ this.cg.addDirectOrSpecialCallEdge(method.getSignature(), callee, stmt, false);
65
+ }
66
+ else {
67
+ this.cg.addDynamicCallInfo(stmt, method.getSignature(), callee);
68
+ }
69
+ }
70
+ }
71
+ }
72
+ buildClassHierarchyCallGraph(entries, displayGeneratedMethod = false) {
73
+ let cgEntries = [];
74
+ entries.forEach((entry) => {
75
+ cgEntries.push(this.cg.getCallGraphNodeByMethod(entry).getID());
76
+ });
77
+ this.cg.setEntries(cgEntries);
78
+ let classHierarchyAnalysis = new ClassHierarchyAnalysis_1.ClassHierarchyAnalysis(this.scene, this.cg);
79
+ classHierarchyAnalysis.start(displayGeneratedMethod);
80
+ }
81
+ buildRapidTypeCallGraph(entries, displayGeneratedMethod = false) {
82
+ let cgEntries = [];
83
+ entries.forEach((entry) => {
84
+ cgEntries.push(this.cg.getCallGraphNodeByMethod(entry).getID());
85
+ });
86
+ this.cg.setEntries(cgEntries);
87
+ let rapidTypeAnalysis = new RapidTypeAnalysis_1.RapidTypeAnalysis(this.scene, this.cg);
88
+ rapidTypeAnalysis.start(displayGeneratedMethod);
89
+ }
90
+ /// Get direct call callee
91
+ getDCCallee(invokeExpr) {
92
+ return invokeExpr.getMethodSignature();
93
+ }
94
+ isConstructor(m) {
95
+ return m.getMethodSubSignature().getMethodName() === 'constructor';
96
+ }
97
+ setEntries() {
98
+ let nodesIter = this.cg.getNodesIter();
99
+ let entries = Array.from(nodesIter)
100
+ .filter(node => !node.hasIncomingEdges() && node.getKind() == CallGraph_1.CallGraphNodeKind.real
101
+ && !node.isBlankMethod)
102
+ .map(node => node.getID());
103
+ this.cg.setEntries(entries);
104
+ }
105
+ }
106
+ exports.CallGraphBuilder = CallGraphBuilder;
@@ -0,0 +1,38 @@
1
+ import { FuncID } from '../model/CallGraph';
2
+ export type ContextID = number;
3
+ export declare const DUMMY_CID = 0;
4
+ declare class Context {
5
+ private contextElems;
6
+ static sEmptyCtx: Context;
7
+ constructor(contextElems?: number[]);
8
+ static newEmpty(): Context;
9
+ static new(contextElems: number[]): Context;
10
+ static newKLimitedContext(oldCtx: Context, elem: number, k: number): Context;
11
+ static kLimitedContext(ctx: Context, k: number): Context;
12
+ length(): number;
13
+ get(index: number): number;
14
+ toString(): String;
15
+ }
16
+ declare class ContextCache {
17
+ private contextList;
18
+ private contextToIDMap;
19
+ constructor();
20
+ getOrNewContextID(context: Context): ContextID;
21
+ updateContext(id: ContextID, newContext: Context, oldContext: Context): boolean;
22
+ getContextID(context: Context): ContextID | undefined;
23
+ getContext(id: number): Context | undefined;
24
+ getContextList(): Context[];
25
+ }
26
+ export declare class KLimitedContextSensitive {
27
+ k: number;
28
+ ctxCache: ContextCache;
29
+ constructor(k: number);
30
+ emptyContext(): Context;
31
+ getEmptyContextID(): ContextID;
32
+ getContextID(context: Context): ContextID;
33
+ getContextByID(context_id: number): Context | undefined;
34
+ getNewContextID(callerFuncId: FuncID): ContextID;
35
+ getOrNewContext(callerCid: ContextID, calleeFuncId: FuncID, findCalleeAsTop?: boolean): ContextID;
36
+ }
37
+ export {};
38
+ //# sourceMappingURL=Context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Context.d.ts","sourceRoot":"","sources":["../../../src/callgraph/pointerAnalysis/Context.ts"],"names":[],"mappings":"AAeA,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAA;AAEzC,MAAM,MAAM,SAAS,GAAG,MAAM,CAAA;AAC9B,eAAO,MAAM,SAAS,IAAI,CAAA;AAE1B,cAAM,OAAO;IACT,OAAO,CAAC,YAAY,CAAW;IAC/B,MAAM,CAAC,SAAS,EAAE,OAAO,CAAmB;gBAEhC,YAAY,GAAE,MAAM,EAAO;IAIvC,MAAM,CAAC,QAAQ,IAAI,OAAO;IAI1B,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO;IAK3C,MAAM,CAAC,kBAAkB,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO;IAa5E,MAAM,CAAC,eAAe,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,EAAC,MAAM,GAAG,OAAO;IAShD,MAAM,IAAI,MAAM;IAIhB,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAO1B,QAAQ,IAAI,MAAM;CAG5B;AAED,cAAM,YAAY;IACd,OAAO,CAAC,WAAW,CAAiB;IACpC,OAAO,CAAC,cAAc,CAAkC;;IAOjD,iBAAiB,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS;IAa9C,aAAa,CAAC,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,GAAG,OAAO;IAY/E,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS,GAAG,SAAS;IASrD,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAQ3C,cAAc,IAAI,OAAO,EAAE;CAGrC;AAED,qBAAa,wBAAwB;IACjC,CAAC,EAAE,MAAM,CAAC;IACV,QAAQ,EAAE,YAAY,CAAC;gBAEX,CAAC,EAAE,MAAM;IAOd,YAAY,IAAI,OAAO;IAIvB,iBAAiB,IAAI,SAAS;IAI9B,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS;IAIzC,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAIvD,eAAe,CAAC,YAAY,EAAE,MAAM,GAAG,SAAS;IAIhD,eAAe,CAAC,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,eAAe,GAAE,OAAe,GAAG,SAAS;CAoBlH"}
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright (c) 2024 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.KLimitedContextSensitive = exports.DUMMY_CID = void 0;
18
+ exports.DUMMY_CID = 0;
19
+ class Context {
20
+ constructor(contextElems = []) {
21
+ this.contextElems = contextElems;
22
+ }
23
+ static newEmpty() {
24
+ return new Context();
25
+ }
26
+ static new(contextElems) {
27
+ return new Context(contextElems);
28
+ }
29
+ // use old context and a new element to create a new k-limited Context
30
+ static newKLimitedContext(oldCtx, elem, k) {
31
+ let elems = [];
32
+ if (k > 0) {
33
+ elems.push(elem);
34
+ if (oldCtx.contextElems.length < k) {
35
+ elems = elems.concat(oldCtx.contextElems);
36
+ }
37
+ else {
38
+ elems = elems.concat(oldCtx.contextElems.slice(0, k - 1));
39
+ }
40
+ }
41
+ return new Context(elems);
42
+ }
43
+ static kLimitedContext(ctx, k) {
44
+ if (ctx.length() <= k) {
45
+ return new Context(ctx.contextElems);
46
+ }
47
+ else {
48
+ const elems = ctx.contextElems.slice(0, k);
49
+ return new Context(elems);
50
+ }
51
+ }
52
+ length() {
53
+ return this.contextElems.length;
54
+ }
55
+ get(index) {
56
+ if (index < 0 || index >= this.contextElems.length) {
57
+ throw new Error('Index out of bounds');
58
+ }
59
+ return this.contextElems[index];
60
+ }
61
+ toString() {
62
+ return this.contextElems.join('-');
63
+ }
64
+ }
65
+ Context.sEmptyCtx = new Context([]);
66
+ class ContextCache {
67
+ constructor() {
68
+ this.contextList = [];
69
+ this.contextToIDMap = new Map();
70
+ this.contextList = [];
71
+ this.contextToIDMap = new Map();
72
+ }
73
+ getOrNewContextID(context) {
74
+ let cStr = context.toString();
75
+ if (this.contextToIDMap.has(cStr)) {
76
+ return this.contextToIDMap.get(cStr);
77
+ }
78
+ else {
79
+ // real cid start from 1
80
+ const id = this.contextList.length;
81
+ this.contextList.push(context);
82
+ this.contextToIDMap.set(cStr, id);
83
+ return id;
84
+ }
85
+ }
86
+ updateContext(id, newContext, oldContext) {
87
+ if (this.contextList.length < id) {
88
+ return false;
89
+ }
90
+ this.contextList[id] = newContext;
91
+ let oldCStr = oldContext.toString();
92
+ let newCStr = newContext.toString();
93
+ this.contextToIDMap.delete(oldCStr);
94
+ this.contextToIDMap.set(newCStr, id);
95
+ return true;
96
+ }
97
+ getContextID(context) {
98
+ let cStr = context.toString();
99
+ if (this.contextToIDMap.has(cStr)) {
100
+ return this.contextToIDMap.get(cStr);
101
+ }
102
+ return undefined;
103
+ }
104
+ getContext(id) {
105
+ //if (id === 0 || id > this.contextList.length) {
106
+ if (id > this.contextList.length) {
107
+ return undefined;
108
+ }
109
+ return this.contextList[id];
110
+ }
111
+ getContextList() {
112
+ return this.contextList;
113
+ }
114
+ }
115
+ class KLimitedContextSensitive {
116
+ constructor(k) {
117
+ this.k = k;
118
+ this.ctxCache = new ContextCache();
119
+ // put dummy cid
120
+ this.getEmptyContextID();
121
+ }
122
+ emptyContext() {
123
+ return new Context([]);
124
+ }
125
+ getEmptyContextID() {
126
+ return this.getContextID(Context.newEmpty());
127
+ }
128
+ getContextID(context) {
129
+ return this.ctxCache.getOrNewContextID(context);
130
+ }
131
+ getContextByID(context_id) {
132
+ return this.ctxCache.getContext(context_id);
133
+ }
134
+ getNewContextID(callerFuncId) {
135
+ return this.ctxCache.getOrNewContextID(Context.new([callerFuncId]));
136
+ }
137
+ getOrNewContext(callerCid, calleeFuncId, findCalleeAsTop = false) {
138
+ const callerCtx = this.ctxCache.getContext(callerCid);
139
+ if (!callerCtx) {
140
+ throw new Error(`Context with id ${callerCid} not found.`);
141
+ }
142
+ const calleeNewCtx = Context.newKLimitedContext(callerCtx, calleeFuncId, this.k);
143
+ if (findCalleeAsTop) {
144
+ const calleeAsTopCtx = Context.newKLimitedContext(Context.sEmptyCtx, calleeFuncId, this.k);
145
+ let topID = this.ctxCache.getContextID(calleeAsTopCtx);
146
+ if (topID) {
147
+ // let ctx = this.ctxCache.getContext(topID);
148
+ this.ctxCache.updateContext(topID, calleeNewCtx, calleeAsTopCtx);
149
+ return topID;
150
+ }
151
+ }
152
+ const calleeCid = this.ctxCache.getOrNewContextID(calleeNewCtx);
153
+ return calleeCid;
154
+ }
155
+ }
156
+ exports.KLimitedContextSensitive = KLimitedContextSensitive;
@@ -0,0 +1,23 @@
1
+ import { Local } from '../../core/base/Local';
2
+ import { Stmt } from '../../core/base/Stmt';
3
+ import { ClassSignature } from '../../core/model/ArkSignature';
4
+ import { Scene } from '../../Scene';
5
+ /**
6
+ * TODO: constructor pointer and cid
7
+ */
8
+ export declare class DummyCallCreator {
9
+ private scene;
10
+ private pageMap;
11
+ private componentMap;
12
+ constructor(scene: Scene);
13
+ getDummyCallByPage(classSig: ClassSignature, basePage: Local): Set<Stmt>;
14
+ getDummyCallByComponent(classSig: ClassSignature, baseComponent: Local): Set<Stmt>;
15
+ /**
16
+ * build dummy call edge with class signature, including a class new expr and call back function invokes
17
+ * @param classSig class signature
18
+ * @returns dummy call edges
19
+ */
20
+ private buildDummyCallBody;
21
+ private getComponentCallStmts;
22
+ }
23
+ //# sourceMappingURL=DummyCallCreator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DummyCallCreator.d.ts","sourceRoot":"","sources":["../../../src/callgraph/pointerAnalysis/DummyCallCreator.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAiB,MAAM,sBAAsB,CAAC;AAE3D,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAMpC;;GAEG;AACH,qBAAa,gBAAgB;IACzB,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,OAAO,CAAC;IAEhB,OAAO,CAAC,YAAY,CAAiC;gBAEzC,KAAK,EAAE,KAAK;IAMjB,kBAAkB,CAAC,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC;IAYxE,uBAAuB,CAAC,QAAQ,EAAE,cAAc,EAAE,aAAa,EAAE,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC;IAYzF;;;;OAIG;IACH,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,qBAAqB;CAqBhC"}