arkanalyzer 1.0.20 → 1.0.22

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 (292) hide show
  1. package/config/arkanalyzer.json +14 -13
  2. package/lib/Config.d.ts +70 -70
  3. package/lib/Config.js +198 -198
  4. package/lib/Scene.d.ts +316 -316
  5. package/lib/Scene.js +1316 -1316
  6. package/lib/callgraph/algorithm/AbstractAnalysis.d.ts +28 -28
  7. package/lib/callgraph/algorithm/AbstractAnalysis.js +144 -144
  8. package/lib/callgraph/algorithm/ClassHierarchyAnalysis.d.ts +10 -10
  9. package/lib/callgraph/algorithm/ClassHierarchyAnalysis.js +69 -69
  10. package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts +15 -15
  11. package/lib/callgraph/algorithm/RapidTypeAnalysis.js +146 -146
  12. package/lib/callgraph/common/Statistics.d.ts +57 -57
  13. package/lib/callgraph/common/Statistics.js +228 -228
  14. package/lib/callgraph/model/CallGraph.d.ts +96 -96
  15. package/lib/callgraph/model/CallGraph.js +354 -354
  16. package/lib/callgraph/model/builder/CallGraphBuilder.d.ts +15 -15
  17. package/lib/callgraph/model/builder/CallGraphBuilder.js +106 -106
  18. package/lib/callgraph/pointerAnalysis/Context.d.ts +37 -37
  19. package/lib/callgraph/pointerAnalysis/Context.js +155 -155
  20. package/lib/callgraph/pointerAnalysis/DummyCallCreator.d.ts +22 -22
  21. package/lib/callgraph/pointerAnalysis/DummyCallCreator.js +104 -104
  22. package/lib/callgraph/pointerAnalysis/PTAUtils.d.ts +5 -5
  23. package/lib/callgraph/pointerAnalysis/PTAUtils.js +46 -46
  24. package/lib/callgraph/pointerAnalysis/Pag.d.ts +261 -261
  25. package/lib/callgraph/pointerAnalysis/Pag.js +930 -930
  26. package/lib/callgraph/pointerAnalysis/PagBuilder.d.ts +157 -157
  27. package/lib/callgraph/pointerAnalysis/PagBuilder.js +1399 -1399
  28. package/lib/callgraph/pointerAnalysis/PointerAnalysis.d.ts +72 -72
  29. package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +573 -573
  30. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.d.ts +15 -15
  31. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.js +81 -81
  32. package/lib/callgraph/pointerAnalysis/PtsDS.d.ts +80 -80
  33. package/lib/callgraph/pointerAnalysis/PtsDS.js +308 -308
  34. package/lib/core/base/Constant.d.ts +48 -48
  35. package/lib/core/base/Constant.js +103 -103
  36. package/lib/core/base/Decorator.d.ts +15 -15
  37. package/lib/core/base/Decorator.js +46 -46
  38. package/lib/core/base/DefUseChain.d.ts +8 -8
  39. package/lib/core/base/DefUseChain.js +25 -25
  40. package/lib/core/base/Expr.d.ts +340 -340
  41. package/lib/core/base/Expr.js +917 -917
  42. package/lib/core/base/Local.d.ts +104 -104
  43. package/lib/core/base/Local.js +176 -176
  44. package/lib/core/base/Position.d.ts +30 -30
  45. package/lib/core/base/Position.js +147 -147
  46. package/lib/core/base/Ref.d.ts +173 -173
  47. package/lib/core/base/Ref.d.ts.map +1 -1
  48. package/lib/core/base/Ref.js +373 -374
  49. package/lib/core/base/Stmt.d.ts +237 -237
  50. package/lib/core/base/Stmt.js +525 -525
  51. package/lib/core/base/Trap.d.ts +8 -8
  52. package/lib/core/base/Trap.js +30 -30
  53. package/lib/core/base/Type.d.ts +308 -308
  54. package/lib/core/base/Type.js +639 -639
  55. package/lib/core/base/TypeExpr.d.ts +71 -71
  56. package/lib/core/base/TypeExpr.js +155 -155
  57. package/lib/core/base/Value.d.ts +32 -32
  58. package/lib/core/base/Value.js +16 -16
  59. package/lib/core/common/ArkError.d.ts +14 -14
  60. package/lib/core/common/ArkError.js +28 -28
  61. package/lib/core/common/ArkIRTransformer.d.ts +68 -67
  62. package/lib/core/common/ArkIRTransformer.d.ts.map +1 -1
  63. package/lib/core/common/ArkIRTransformer.js +705 -690
  64. package/lib/core/common/ArkValueTransformer.d.ts +89 -89
  65. package/lib/core/common/ArkValueTransformer.js +1478 -1478
  66. package/lib/core/common/Builtin.d.ts +36 -36
  67. package/lib/core/common/Builtin.js +81 -81
  68. package/lib/core/common/Const.d.ts +21 -21
  69. package/lib/core/common/Const.js +43 -43
  70. package/lib/core/common/DummyMainCreater.d.ts +46 -46
  71. package/lib/core/common/DummyMainCreater.js +319 -319
  72. package/lib/core/common/EtsConst.d.ts +73 -73
  73. package/lib/core/common/EtsConst.js +1021 -1021
  74. package/lib/core/common/ExprUseReplacer.d.ts +21 -21
  75. package/lib/core/common/ExprUseReplacer.js +124 -124
  76. package/lib/core/common/IRInference.d.ts +45 -36
  77. package/lib/core/common/IRInference.d.ts.map +1 -1
  78. package/lib/core/common/IRInference.js +731 -648
  79. package/lib/core/common/IRUtils.d.ts +18 -18
  80. package/lib/core/common/IRUtils.js +141 -141
  81. package/lib/core/common/ModelUtils.d.ts +70 -70
  82. package/lib/core/common/ModelUtils.d.ts.map +1 -1
  83. package/lib/core/common/ModelUtils.js +723 -712
  84. package/lib/core/common/RefUseReplacer.d.ts +13 -13
  85. package/lib/core/common/RefUseReplacer.js +52 -52
  86. package/lib/core/common/SdkUtils.d.ts +11 -8
  87. package/lib/core/common/SdkUtils.d.ts.map +1 -1
  88. package/lib/core/common/SdkUtils.js +127 -105
  89. package/lib/core/common/StmtDefReplacer.d.ts +12 -12
  90. package/lib/core/common/StmtDefReplacer.js +41 -41
  91. package/lib/core/common/StmtUseReplacer.d.ts +16 -16
  92. package/lib/core/common/StmtUseReplacer.js +108 -108
  93. package/lib/core/common/TSConst.d.ts +20 -18
  94. package/lib/core/common/TSConst.d.ts.map +1 -1
  95. package/lib/core/common/TSConst.js +38 -36
  96. package/lib/core/common/TypeInference.d.ts +105 -102
  97. package/lib/core/common/TypeInference.d.ts.map +1 -1
  98. package/lib/core/common/TypeInference.js +806 -748
  99. package/lib/core/common/ValueUtil.d.ts +12 -12
  100. package/lib/core/common/ValueUtil.js +54 -54
  101. package/lib/core/common/VisibleValue.d.ts +36 -36
  102. package/lib/core/common/VisibleValue.js +212 -212
  103. package/lib/core/dataflow/DataflowProblem.d.ts +20 -20
  104. package/lib/core/dataflow/DataflowProblem.js +20 -20
  105. package/lib/core/dataflow/DataflowResult.d.ts +7 -7
  106. package/lib/core/dataflow/DataflowResult.js +26 -26
  107. package/lib/core/dataflow/DataflowSolver.d.ts +43 -43
  108. package/lib/core/dataflow/DataflowSolver.js +307 -307
  109. package/lib/core/dataflow/Edge.d.ts +11 -11
  110. package/lib/core/dataflow/Edge.js +31 -31
  111. package/lib/core/dataflow/Fact.d.ts +6 -6
  112. package/lib/core/dataflow/Fact.js +24 -24
  113. package/lib/core/dataflow/GenericDataFlow.d.ts +142 -142
  114. package/lib/core/dataflow/GenericDataFlow.js +109 -109
  115. package/lib/core/dataflow/ReachingDef.d.ts +62 -62
  116. package/lib/core/dataflow/ReachingDef.js +168 -168
  117. package/lib/core/dataflow/UndefinedVariable.d.ts +45 -45
  118. package/lib/core/dataflow/UndefinedVariable.js +288 -288
  119. package/lib/core/dataflow/Util.d.ts +9 -9
  120. package/lib/core/dataflow/Util.js +64 -64
  121. package/lib/core/graph/BaseExplicitGraph.d.ts +58 -58
  122. package/lib/core/graph/BaseExplicitGraph.js +157 -157
  123. package/lib/core/graph/BaseImplicitGraph.d.ts +77 -77
  124. package/lib/core/graph/BaseImplicitGraph.js +78 -78
  125. package/lib/core/graph/BasicBlock.d.ts +104 -104
  126. package/lib/core/graph/BasicBlock.js +280 -280
  127. package/lib/core/graph/Cfg.d.ts +59 -59
  128. package/lib/core/graph/Cfg.js +282 -282
  129. package/lib/core/graph/DependsGraph.d.ts +35 -35
  130. package/lib/core/graph/DependsGraph.js +87 -87
  131. package/lib/core/graph/DominanceFinder.d.ts +15 -15
  132. package/lib/core/graph/DominanceFinder.js +121 -121
  133. package/lib/core/graph/DominanceTree.d.ts +12 -12
  134. package/lib/core/graph/DominanceTree.js +70 -70
  135. package/lib/core/graph/GraphTraits.d.ts +7 -7
  136. package/lib/core/graph/GraphTraits.js +16 -16
  137. package/lib/core/graph/Scc.d.ts +61 -61
  138. package/lib/core/graph/Scc.js +222 -222
  139. package/lib/core/graph/ViewTree.d.ts +114 -114
  140. package/lib/core/graph/ViewTree.js +16 -16
  141. package/lib/core/graph/builder/CfgBuilder.d.ts +176 -176
  142. package/lib/core/graph/builder/CfgBuilder.js +1139 -1139
  143. package/lib/core/graph/builder/ConditionBuilder.d.ts +15 -15
  144. package/lib/core/graph/builder/ConditionBuilder.js +252 -252
  145. package/lib/core/graph/builder/LoopBuilder.d.ts +20 -20
  146. package/lib/core/graph/builder/LoopBuilder.js +251 -251
  147. package/lib/core/graph/builder/SwitchBuilder.d.ts +11 -11
  148. package/lib/core/graph/builder/SwitchBuilder.js +152 -152
  149. package/lib/core/graph/builder/TrapBuilder.d.ts +16 -16
  150. package/lib/core/graph/builder/TrapBuilder.js +272 -272
  151. package/lib/core/graph/builder/ViewTreeBuilder.d.ts +203 -203
  152. package/lib/core/graph/builder/ViewTreeBuilder.d.ts.map +1 -1
  153. package/lib/core/graph/builder/ViewTreeBuilder.js +1058 -1055
  154. package/lib/core/model/ArkBaseModel.d.ts +59 -59
  155. package/lib/core/model/ArkBaseModel.js +274 -274
  156. package/lib/core/model/ArkBody.d.ts +24 -24
  157. package/lib/core/model/ArkBody.js +65 -65
  158. package/lib/core/model/ArkClass.d.ts +206 -206
  159. package/lib/core/model/ArkClass.d.ts.map +1 -1
  160. package/lib/core/model/ArkClass.js +442 -439
  161. package/lib/core/model/ArkExport.d.ts +72 -72
  162. package/lib/core/model/ArkExport.js +147 -147
  163. package/lib/core/model/ArkField.d.ts +62 -62
  164. package/lib/core/model/ArkField.js +113 -113
  165. package/lib/core/model/ArkFile.d.ts +131 -131
  166. package/lib/core/model/ArkFile.js +267 -267
  167. package/lib/core/model/ArkImport.d.ts +44 -44
  168. package/lib/core/model/ArkImport.js +108 -108
  169. package/lib/core/model/ArkMetadata.d.ts +31 -31
  170. package/lib/core/model/ArkMetadata.js +55 -55
  171. package/lib/core/model/ArkMethod.d.ts +261 -261
  172. package/lib/core/model/ArkMethod.js +592 -592
  173. package/lib/core/model/ArkNamespace.d.ts +66 -66
  174. package/lib/core/model/ArkNamespace.js +209 -209
  175. package/lib/core/model/ArkSignature.d.ts +167 -162
  176. package/lib/core/model/ArkSignature.d.ts.map +1 -1
  177. package/lib/core/model/ArkSignature.js +393 -379
  178. package/lib/core/model/builder/ArkClassBuilder.d.ts +12 -12
  179. package/lib/core/model/builder/ArkClassBuilder.d.ts.map +1 -1
  180. package/lib/core/model/builder/ArkClassBuilder.js +423 -454
  181. package/lib/core/model/builder/ArkExportBuilder.d.ts +24 -24
  182. package/lib/core/model/builder/ArkExportBuilder.js +210 -210
  183. package/lib/core/model/builder/ArkFieldBuilder.d.ts +8 -8
  184. package/lib/core/model/builder/ArkFieldBuilder.js +193 -193
  185. package/lib/core/model/builder/ArkFileBuilder.d.ts +9 -9
  186. package/lib/core/model/builder/ArkFileBuilder.js +165 -165
  187. package/lib/core/model/builder/ArkImportBuilder.d.ts +4 -4
  188. package/lib/core/model/builder/ArkImportBuilder.js +128 -128
  189. package/lib/core/model/builder/ArkMethodBuilder.d.ts +63 -63
  190. package/lib/core/model/builder/ArkMethodBuilder.d.ts.map +1 -1
  191. package/lib/core/model/builder/ArkMethodBuilder.js +487 -486
  192. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +5 -5
  193. package/lib/core/model/builder/ArkNamespaceBuilder.js +205 -205
  194. package/lib/core/model/builder/ArkSignatureBuilder.d.ts +8 -8
  195. package/lib/core/model/builder/ArkSignatureBuilder.js +40 -40
  196. package/lib/core/model/builder/BodyBuilder.d.ts +55 -30
  197. package/lib/core/model/builder/BodyBuilder.d.ts.map +1 -1
  198. package/lib/core/model/builder/BodyBuilder.js +542 -371
  199. package/lib/core/model/builder/builderUtils.d.ts +18 -18
  200. package/lib/core/model/builder/builderUtils.d.ts.map +1 -1
  201. package/lib/core/model/builder/builderUtils.js +571 -558
  202. package/lib/index.d.ts +82 -80
  203. package/lib/index.d.ts.map +1 -1
  204. package/lib/index.js +201 -196
  205. package/lib/save/ArkStream.d.ts +23 -23
  206. package/lib/save/ArkStream.js +83 -83
  207. package/lib/save/DotPrinter.d.ts +43 -43
  208. package/lib/save/DotPrinter.js +170 -170
  209. package/lib/save/GraphPrinter.d.ts +16 -16
  210. package/lib/save/GraphPrinter.js +134 -134
  211. package/lib/save/JsonPrinter.d.ts +30 -30
  212. package/lib/save/JsonPrinter.js +580 -580
  213. package/lib/save/Printer.d.ts +12 -12
  214. package/lib/save/Printer.js +27 -27
  215. package/lib/save/PrinterBuilder.d.ts +53 -53
  216. package/lib/save/PrinterBuilder.js +145 -145
  217. package/lib/save/ViewTreePrinter.d.ts +14 -14
  218. package/lib/save/ViewTreePrinter.js +123 -123
  219. package/lib/save/arkir/ArkIRClassPrinter.d.ts +13 -13
  220. package/lib/save/arkir/ArkIRClassPrinter.js +92 -92
  221. package/lib/save/arkir/ArkIRFieldPrinter.d.ts +11 -11
  222. package/lib/save/arkir/ArkIRFieldPrinter.js +64 -64
  223. package/lib/save/arkir/ArkIRFilePrinter.d.ts +12 -12
  224. package/lib/save/arkir/ArkIRFilePrinter.js +54 -54
  225. package/lib/save/arkir/ArkIRMethodPrinter.d.ts +16 -16
  226. package/lib/save/arkir/ArkIRMethodPrinter.js +159 -159
  227. package/lib/save/arkir/ArkIRNamespacePrinter.d.ts +11 -11
  228. package/lib/save/arkir/ArkIRNamespacePrinter.js +66 -66
  229. package/lib/save/base/BasePrinter.d.ts +23 -23
  230. package/lib/save/base/BasePrinter.js +70 -70
  231. package/lib/save/base/ExportPrinter.d.ts +8 -8
  232. package/lib/save/base/ExportPrinter.js +67 -67
  233. package/lib/save/base/ImportPrinter.d.ts +9 -9
  234. package/lib/save/base/ImportPrinter.js +92 -92
  235. package/lib/save/base/PrinterUtils.d.ts +24 -24
  236. package/lib/save/base/PrinterUtils.js +208 -208
  237. package/lib/save/serializeArkIR.d.ts +8 -8
  238. package/lib/save/serializeArkIR.js +294 -294
  239. package/lib/save/source/SourceBase.d.ts +22 -22
  240. package/lib/save/source/SourceBase.js +64 -64
  241. package/lib/save/source/SourceBody.d.ts +58 -58
  242. package/lib/save/source/SourceBody.js +296 -296
  243. package/lib/save/source/SourceClass.d.ts +25 -25
  244. package/lib/save/source/SourceClass.js +187 -187
  245. package/lib/save/source/SourceField.d.ts +13 -13
  246. package/lib/save/source/SourceField.js +73 -73
  247. package/lib/save/source/SourceFilePrinter.d.ts +12 -12
  248. package/lib/save/source/SourceFilePrinter.js +69 -69
  249. package/lib/save/source/SourceMethod.d.ts +22 -22
  250. package/lib/save/source/SourceMethod.d.ts.map +1 -1
  251. package/lib/save/source/SourceMethod.js +196 -193
  252. package/lib/save/source/SourceNamespace.d.ts +11 -11
  253. package/lib/save/source/SourceNamespace.js +83 -83
  254. package/lib/save/source/SourceStmt.d.ts +178 -178
  255. package/lib/save/source/SourceStmt.js +838 -838
  256. package/lib/save/source/SourceTransformer.d.ts +46 -46
  257. package/lib/save/source/SourceTransformer.js +446 -446
  258. package/lib/transformer/FunctionTransformer.d.ts +2 -2
  259. package/lib/transformer/FunctionTransformer.js +17 -17
  260. package/lib/transformer/SceneTransformer.d.ts +2 -2
  261. package/lib/transformer/SceneTransformer.js +17 -17
  262. package/lib/transformer/StaticSingleAssignmentFormer.d.ts +12 -12
  263. package/lib/transformer/StaticSingleAssignmentFormer.js +259 -259
  264. package/lib/transformer/Transformer.d.ts +6 -6
  265. package/lib/transformer/Transformer.js +22 -22
  266. package/lib/utils/AstTreeUtils.d.ts +4 -4
  267. package/lib/utils/AstTreeUtils.js +26 -26
  268. package/lib/utils/CfgStructualAnalysis.d.ts +110 -110
  269. package/lib/utils/CfgStructualAnalysis.js +1277 -1277
  270. package/lib/utils/FileUtils.d.ts +18 -18
  271. package/lib/utils/FileUtils.js +135 -135
  272. package/lib/utils/SparseBitVector.d.ts +100 -100
  273. package/lib/utils/SparseBitVector.js +445 -445
  274. package/lib/utils/callGraphUtils.d.ts +30 -30
  275. package/lib/utils/callGraphUtils.js +205 -205
  276. package/lib/utils/crypto_utils.d.ts +5 -5
  277. package/lib/utils/crypto_utils.js +57 -57
  278. package/lib/utils/entryMethodUtils.d.ts +13 -13
  279. package/lib/utils/entryMethodUtils.js +110 -110
  280. package/lib/utils/getAllFiles.d.ts +9 -9
  281. package/lib/utils/getAllFiles.js +90 -90
  282. package/lib/utils/json5parser.d.ts +6 -6
  283. package/lib/utils/json5parser.js +146 -146
  284. package/lib/utils/logger.d.ts +18 -18
  285. package/lib/utils/logger.d.ts.map +1 -1
  286. package/lib/utils/logger.js +97 -90
  287. package/lib/utils/pathTransfer.d.ts +1 -1
  288. package/lib/utils/pathTransfer.js +25 -25
  289. package/node_modules/json5/lib/cli.js +0 -0
  290. package/node_modules/ohos-typescript/bin/tsc +0 -0
  291. package/node_modules/ohos-typescript/bin/tsserver +0 -0
  292. package/package.json +3 -3
@@ -1,238 +1,238 @@
1
- import { Cfg } from '../graph/Cfg';
2
- import { AbstractExpr, AbstractInvokeExpr, AliasTypeExpr, ArkConditionExpr } from './Expr';
3
- import { AbstractFieldRef, ArkArrayRef } from './Ref';
4
- import { Value } from './Value';
5
- import { FullPosition, LineColPosition } from './Position';
6
- import { ArkMetadata, ArkMetadataKind, ArkMetadataType } from '../model/ArkMetadata';
7
- import { AliasType } from './Type';
8
- import { AbstractTypeExpr } from './TypeExpr';
9
- /**
10
- * @category core/base/stmt
11
- */
12
- export declare abstract class Stmt {
13
- protected text?: string;
14
- protected originalText?: string;
15
- protected originalPosition: LineColPosition;
16
- protected cfg: Cfg;
17
- protected operandOriginalPositions?: FullPosition[];
18
- metadata?: ArkMetadata;
19
- getMetadata(kind: ArkMetadataKind): ArkMetadataType | undefined;
20
- setMetadata(kind: ArkMetadataKind, value: ArkMetadataType): void;
21
- /** Return a list of values which are uesd in this statement */
22
- getUses(): Value[];
23
- replaceUse(oldUse: Value, newUse: Value): void;
24
- /**
25
- * Return the definition which is uesd in this statement. Generally, the definition is the left value of `=` in
26
- * 3AC. For example, the definition in 3AC of `value = parameter0: @project-1/sample-1.ets: AnonymousClass-0` is
27
- * `value`, and the definition in `$temp0 = staticinvoke <@_ProjectName/_FileName: xxx.create()>()` is `\$temp0`.
28
- * @returns The definition in 3AC (may be a **null**).
29
- * @example
30
- * 1. get the def in stmt.
31
- ```typescript
32
- for (const block of this.blocks) {
33
- for (const stmt of block.getStmts()) {
34
- const defValue = stmt.getDef();
35
- ...
36
- }
37
- }
38
- ```
39
- */
40
- getDef(): Value | null;
41
- replaceDef(oldDef: Value, newDef: Value): void;
42
- getDefAndUses(): Value[];
43
- /**
44
- * Get the CFG (i.e., control flow graph) of an {@link ArkBody} in which the statement is.
45
- * A CFG contains a set of basic blocks and statements corresponding to each basic block.
46
- * Note that, "source code" and "three-address" are two types of {@link Stmt} in ArkAnalyzer.
47
- * Source code {@link Stmt} represents the statement of ets/ts source code, while three-address code {@link Stmt}
48
- * represents the statement after it has been converted into three-address code. Since the source code {@link
49
- * Stmt} does not save its CFG reference, it returns **null**, while the `getCfg()` of the third address code
50
- * {@link Stmt} will return its CFG reference.
51
- * @returns The CFG (i.e., control flow graph) of an {@link ArkBody} in which the statement is.
52
- * @example
53
- * 1. get the ArkFile based on stmt.
54
- ```typescript
55
- const arkFile = stmt.getCfg()?.getDeclaringMethod().getDeclaringArkFile();
56
- ```
57
- 2. get the ArkMethod based on stmt.
58
- ```typescript
59
- let sourceMethod: ArkMethod = stmt.getCfg()?.getDeclaringMethod();
60
- ```
61
- */
62
- getCfg(): Cfg;
63
- setCfg(cfg: Cfg): void;
64
- /**
65
- * Return true if the following statement may not execute after this statement.
66
- * The ArkIfStmt and ArkGotoStmt will return true.
67
- */
68
- isBranch(): boolean;
69
- /** Return the number of statements which this statement may go to */
70
- getExpectedSuccessorCount(): number;
71
- containsInvokeExpr(): boolean;
72
- /**
73
- * Returns the method's invocation expression (including method signature and its arguments)
74
- * in the current statement. An **undefined** will be returned if there is no method used in this statement.
75
- * @returns the method's invocation expression from the statement. An **undefined** will be returned if there is
76
- * no method can be found in this statement.
77
- * @example
78
- * 1. get invoke expr based on stmt.
79
- ```typescript
80
- let invoke = stmt.getInvokeExpr();
81
- ```
82
- */
83
- getInvokeExpr(): AbstractInvokeExpr | undefined;
84
- /**
85
- * Returns an array of expressions in the statement.
86
- * @returns An array of expressions in the statement.
87
- * @example
88
- * 1. Traverse expression of statement.
89
-
90
- ```typescript
91
- for (const expr of stmt.getExprs()) {
92
- ...
93
- }
94
- ```
95
- */
96
- getExprs(): AbstractExpr[];
97
- getTypeExprs(): AbstractTypeExpr[];
98
- containsArrayRef(): boolean;
99
- getArrayRef(): ArkArrayRef | undefined;
100
- containsFieldRef(): boolean;
101
- getFieldRef(): AbstractFieldRef | undefined;
102
- setOriginPositionInfo(originPositionInfo: LineColPosition): void;
103
- /**
104
- * Returns the original position of the statement.
105
- * The position consists of two parts: line number and column number.
106
- * In the source file, the former (i.e., line number) indicates which line the statement is in,
107
- * and the latter (i.e., column number) indicates the position of the statement in the line.
108
- * The position is described as `LineColPosition(lineNo,colNum)` in ArkAnalyzer,
109
- * and its default value is LineColPosition(-1,-1).
110
- * @returns The original location of the statement.
111
- * @example
112
- * 1. Get the stmt position info to make some condition judgements.
113
- ```typescript
114
- for (const stmt of stmts) {
115
- if (stmt.getOriginPositionInfo().getLineNo() === -1) {
116
- stmt.setOriginPositionInfo(originalStmt.getOriginPositionInfo());
117
- this.stmtToOriginalStmt.set(stmt, originalStmt);
118
- }
119
- }
120
- ```
121
- */
122
- getOriginPositionInfo(): LineColPosition;
123
- abstract toString(): string;
124
- setText(text: string): void;
125
- setOriginalText(originalText: string): void;
126
- getOriginalText(): string | undefined;
127
- setOperandOriginalPositions(operandOriginalPositions: FullPosition[]): void;
128
- getOperandOriginalPositions(): FullPosition[] | undefined;
129
- getOperandOriginalPosition(indexOrOperand: number | Value): FullPosition | null;
130
- }
131
- export declare class ArkAssignStmt extends Stmt {
132
- private leftOp;
133
- private rightOp;
134
- constructor(leftOp: Value, rightOp: Value);
135
- /**
136
- * Returns the left operand of the assigning statement.
137
- * @returns The left operand of the assigning statement.
138
- * @example
139
- * 1. If the statement is `a=b;`, the right operand is `a`; if the statement is `dd = cc + 5;`, the right operand
140
- * is `cc`.
141
- */
142
- getLeftOp(): Value;
143
- setLeftOp(newLeftOp: Value): void;
144
- /**
145
- * Returns the right operand of the assigning statement.
146
- * @returns The right operand of the assigning statement.
147
- * @example
148
- * 1. If the statement is `a=b;`, the right operand is `b`; if the statement is `dd = cc + 5;`, the right operand
149
- * is `cc + 5`.
150
- * 2. Get the rightOp from stmt.
151
- ```typescript
152
- const rightOp = stmt.getRightOp();
153
- ```
154
- */
155
- getRightOp(): Value;
156
- setRightOp(rightOp: Value): void;
157
- toString(): string;
158
- getDef(): Value | null;
159
- getUses(): Value[];
160
- }
161
- export declare class ArkInvokeStmt extends Stmt {
162
- private invokeExpr;
163
- constructor(invokeExpr: AbstractInvokeExpr);
164
- replaceInvokeExpr(newExpr: AbstractInvokeExpr): void;
165
- getInvokeExpr(): AbstractInvokeExpr;
166
- toString(): string;
167
- getUses(): Value[];
168
- }
169
- export declare class ArkIfStmt extends Stmt {
170
- private conditionExpr;
171
- constructor(conditionExpr: ArkConditionExpr);
172
- /**
173
- * The condition expression consisit of two values as operands and one binary operator as operator.
174
- * The operator can indicate the relation between the two values, e.g., `<`, `<=`,`>`, `>=`, `==`, `!=`, `===`,
175
- * `!==`.
176
- * @returns a condition expression.
177
- * @example
178
- * 1. When a statement is `if (a > b)`, the operands are `a` and `b`, the operator is `<`. Therefore, the condition
179
- * expression is `a > b`.
180
- * 2. get a conditon expr from a condition statement.
181
- ```typescript
182
- let expr = (this.original as ArkIfStmt).getConditionExpr();
183
- ```
184
- */
185
- getConditionExpr(): ArkConditionExpr;
186
- setConditionExpr(newConditionExpr: ArkConditionExpr): void;
187
- isBranch(): boolean;
188
- getExpectedSuccessorCount(): number;
189
- toString(): string;
190
- getUses(): Value[];
191
- }
192
- export declare class ArkReturnStmt extends Stmt {
193
- private op;
194
- constructor(op: Value);
195
- getExpectedSuccessorCount(): number;
196
- getOp(): Value;
197
- setReturnValue(returnValue: Value): void;
198
- toString(): string;
199
- getUses(): Value[];
200
- }
201
- export declare class ArkReturnVoidStmt extends Stmt {
202
- constructor();
203
- getExpectedSuccessorCount(): number;
204
- toString(): string;
205
- }
206
- export declare class ArkThrowStmt extends Stmt {
207
- private op;
208
- constructor(op: Value);
209
- getOp(): Value;
210
- setOp(newOp: Value): void;
211
- toString(): string;
212
- getUses(): Value[];
213
- }
214
- /**
215
- * Statement of type alias definition combines with the left hand as {@link AliasType} and right hand as {@link AliasTypeExpr}.
216
- * @category core/base/stmt
217
- * @extends Stmt
218
- * @example
219
- ```typescript
220
- type A = string;
221
- type B = import('./abc').TypeB;
222
-
223
- let c = 123;
224
- declare type C = typeof c;
225
- ```
226
- */
227
- export declare class ArkAliasTypeDefineStmt extends Stmt {
228
- private aliasType;
229
- private aliasTypeExpr;
230
- constructor(aliasType: AliasType, typeAliasExpr: AliasTypeExpr);
231
- getAliasType(): AliasType;
232
- getAliasTypeExpr(): AliasTypeExpr;
233
- getAliasName(): string;
234
- toString(): string;
235
- getExprs(): AliasTypeExpr[];
236
- getTypeExprs(): AbstractTypeExpr[];
237
- }
1
+ import { Cfg } from '../graph/Cfg';
2
+ import { AbstractExpr, AbstractInvokeExpr, AliasTypeExpr, ArkConditionExpr } from './Expr';
3
+ import { AbstractFieldRef, ArkArrayRef } from './Ref';
4
+ import { Value } from './Value';
5
+ import { FullPosition, LineColPosition } from './Position';
6
+ import { ArkMetadata, ArkMetadataKind, ArkMetadataType } from '../model/ArkMetadata';
7
+ import { AliasType } from './Type';
8
+ import { AbstractTypeExpr } from './TypeExpr';
9
+ /**
10
+ * @category core/base/stmt
11
+ */
12
+ export declare abstract class Stmt {
13
+ protected text?: string;
14
+ protected originalText?: string;
15
+ protected originalPosition: LineColPosition;
16
+ protected cfg: Cfg;
17
+ protected operandOriginalPositions?: FullPosition[];
18
+ metadata?: ArkMetadata;
19
+ getMetadata(kind: ArkMetadataKind): ArkMetadataType | undefined;
20
+ setMetadata(kind: ArkMetadataKind, value: ArkMetadataType): void;
21
+ /** Return a list of values which are uesd in this statement */
22
+ getUses(): Value[];
23
+ replaceUse(oldUse: Value, newUse: Value): void;
24
+ /**
25
+ * Return the definition which is uesd in this statement. Generally, the definition is the left value of `=` in
26
+ * 3AC. For example, the definition in 3AC of `value = parameter0: @project-1/sample-1.ets: AnonymousClass-0` is
27
+ * `value`, and the definition in `$temp0 = staticinvoke <@_ProjectName/_FileName: xxx.create()>()` is `\$temp0`.
28
+ * @returns The definition in 3AC (may be a **null**).
29
+ * @example
30
+ * 1. get the def in stmt.
31
+ ```typescript
32
+ for (const block of this.blocks) {
33
+ for (const stmt of block.getStmts()) {
34
+ const defValue = stmt.getDef();
35
+ ...
36
+ }
37
+ }
38
+ ```
39
+ */
40
+ getDef(): Value | null;
41
+ replaceDef(oldDef: Value, newDef: Value): void;
42
+ getDefAndUses(): Value[];
43
+ /**
44
+ * Get the CFG (i.e., control flow graph) of an {@link ArkBody} in which the statement is.
45
+ * A CFG contains a set of basic blocks and statements corresponding to each basic block.
46
+ * Note that, "source code" and "three-address" are two types of {@link Stmt} in ArkAnalyzer.
47
+ * Source code {@link Stmt} represents the statement of ets/ts source code, while three-address code {@link Stmt}
48
+ * represents the statement after it has been converted into three-address code. Since the source code {@link
49
+ * Stmt} does not save its CFG reference, it returns **null**, while the `getCfg()` of the third address code
50
+ * {@link Stmt} will return its CFG reference.
51
+ * @returns The CFG (i.e., control flow graph) of an {@link ArkBody} in which the statement is.
52
+ * @example
53
+ * 1. get the ArkFile based on stmt.
54
+ ```typescript
55
+ const arkFile = stmt.getCfg()?.getDeclaringMethod().getDeclaringArkFile();
56
+ ```
57
+ 2. get the ArkMethod based on stmt.
58
+ ```typescript
59
+ let sourceMethod: ArkMethod = stmt.getCfg()?.getDeclaringMethod();
60
+ ```
61
+ */
62
+ getCfg(): Cfg;
63
+ setCfg(cfg: Cfg): void;
64
+ /**
65
+ * Return true if the following statement may not execute after this statement.
66
+ * The ArkIfStmt and ArkGotoStmt will return true.
67
+ */
68
+ isBranch(): boolean;
69
+ /** Return the number of statements which this statement may go to */
70
+ getExpectedSuccessorCount(): number;
71
+ containsInvokeExpr(): boolean;
72
+ /**
73
+ * Returns the method's invocation expression (including method signature and its arguments)
74
+ * in the current statement. An **undefined** will be returned if there is no method used in this statement.
75
+ * @returns the method's invocation expression from the statement. An **undefined** will be returned if there is
76
+ * no method can be found in this statement.
77
+ * @example
78
+ * 1. get invoke expr based on stmt.
79
+ ```typescript
80
+ let invoke = stmt.getInvokeExpr();
81
+ ```
82
+ */
83
+ getInvokeExpr(): AbstractInvokeExpr | undefined;
84
+ /**
85
+ * Returns an array of expressions in the statement.
86
+ * @returns An array of expressions in the statement.
87
+ * @example
88
+ * 1. Traverse expression of statement.
89
+
90
+ ```typescript
91
+ for (const expr of stmt.getExprs()) {
92
+ ...
93
+ }
94
+ ```
95
+ */
96
+ getExprs(): AbstractExpr[];
97
+ getTypeExprs(): AbstractTypeExpr[];
98
+ containsArrayRef(): boolean;
99
+ getArrayRef(): ArkArrayRef | undefined;
100
+ containsFieldRef(): boolean;
101
+ getFieldRef(): AbstractFieldRef | undefined;
102
+ setOriginPositionInfo(originPositionInfo: LineColPosition): void;
103
+ /**
104
+ * Returns the original position of the statement.
105
+ * The position consists of two parts: line number and column number.
106
+ * In the source file, the former (i.e., line number) indicates which line the statement is in,
107
+ * and the latter (i.e., column number) indicates the position of the statement in the line.
108
+ * The position is described as `LineColPosition(lineNo,colNum)` in ArkAnalyzer,
109
+ * and its default value is LineColPosition(-1,-1).
110
+ * @returns The original location of the statement.
111
+ * @example
112
+ * 1. Get the stmt position info to make some condition judgements.
113
+ ```typescript
114
+ for (const stmt of stmts) {
115
+ if (stmt.getOriginPositionInfo().getLineNo() === -1) {
116
+ stmt.setOriginPositionInfo(originalStmt.getOriginPositionInfo());
117
+ this.stmtToOriginalStmt.set(stmt, originalStmt);
118
+ }
119
+ }
120
+ ```
121
+ */
122
+ getOriginPositionInfo(): LineColPosition;
123
+ abstract toString(): string;
124
+ setText(text: string): void;
125
+ setOriginalText(originalText: string): void;
126
+ getOriginalText(): string | undefined;
127
+ setOperandOriginalPositions(operandOriginalPositions: FullPosition[]): void;
128
+ getOperandOriginalPositions(): FullPosition[] | undefined;
129
+ getOperandOriginalPosition(indexOrOperand: number | Value): FullPosition | null;
130
+ }
131
+ export declare class ArkAssignStmt extends Stmt {
132
+ private leftOp;
133
+ private rightOp;
134
+ constructor(leftOp: Value, rightOp: Value);
135
+ /**
136
+ * Returns the left operand of the assigning statement.
137
+ * @returns The left operand of the assigning statement.
138
+ * @example
139
+ * 1. If the statement is `a=b;`, the right operand is `a`; if the statement is `dd = cc + 5;`, the right operand
140
+ * is `cc`.
141
+ */
142
+ getLeftOp(): Value;
143
+ setLeftOp(newLeftOp: Value): void;
144
+ /**
145
+ * Returns the right operand of the assigning statement.
146
+ * @returns The right operand of the assigning statement.
147
+ * @example
148
+ * 1. If the statement is `a=b;`, the right operand is `b`; if the statement is `dd = cc + 5;`, the right operand
149
+ * is `cc + 5`.
150
+ * 2. Get the rightOp from stmt.
151
+ ```typescript
152
+ const rightOp = stmt.getRightOp();
153
+ ```
154
+ */
155
+ getRightOp(): Value;
156
+ setRightOp(rightOp: Value): void;
157
+ toString(): string;
158
+ getDef(): Value | null;
159
+ getUses(): Value[];
160
+ }
161
+ export declare class ArkInvokeStmt extends Stmt {
162
+ private invokeExpr;
163
+ constructor(invokeExpr: AbstractInvokeExpr);
164
+ replaceInvokeExpr(newExpr: AbstractInvokeExpr): void;
165
+ getInvokeExpr(): AbstractInvokeExpr;
166
+ toString(): string;
167
+ getUses(): Value[];
168
+ }
169
+ export declare class ArkIfStmt extends Stmt {
170
+ private conditionExpr;
171
+ constructor(conditionExpr: ArkConditionExpr);
172
+ /**
173
+ * The condition expression consisit of two values as operands and one binary operator as operator.
174
+ * The operator can indicate the relation between the two values, e.g., `<`, `<=`,`>`, `>=`, `==`, `!=`, `===`,
175
+ * `!==`.
176
+ * @returns a condition expression.
177
+ * @example
178
+ * 1. When a statement is `if (a > b)`, the operands are `a` and `b`, the operator is `<`. Therefore, the condition
179
+ * expression is `a > b`.
180
+ * 2. get a conditon expr from a condition statement.
181
+ ```typescript
182
+ let expr = (this.original as ArkIfStmt).getConditionExpr();
183
+ ```
184
+ */
185
+ getConditionExpr(): ArkConditionExpr;
186
+ setConditionExpr(newConditionExpr: ArkConditionExpr): void;
187
+ isBranch(): boolean;
188
+ getExpectedSuccessorCount(): number;
189
+ toString(): string;
190
+ getUses(): Value[];
191
+ }
192
+ export declare class ArkReturnStmt extends Stmt {
193
+ private op;
194
+ constructor(op: Value);
195
+ getExpectedSuccessorCount(): number;
196
+ getOp(): Value;
197
+ setReturnValue(returnValue: Value): void;
198
+ toString(): string;
199
+ getUses(): Value[];
200
+ }
201
+ export declare class ArkReturnVoidStmt extends Stmt {
202
+ constructor();
203
+ getExpectedSuccessorCount(): number;
204
+ toString(): string;
205
+ }
206
+ export declare class ArkThrowStmt extends Stmt {
207
+ private op;
208
+ constructor(op: Value);
209
+ getOp(): Value;
210
+ setOp(newOp: Value): void;
211
+ toString(): string;
212
+ getUses(): Value[];
213
+ }
214
+ /**
215
+ * Statement of type alias definition combines with the left hand as {@link AliasType} and right hand as {@link AliasTypeExpr}.
216
+ * @category core/base/stmt
217
+ * @extends Stmt
218
+ * @example
219
+ ```typescript
220
+ type A = string;
221
+ type B = import('./abc').TypeB;
222
+
223
+ let c = 123;
224
+ declare type C = typeof c;
225
+ ```
226
+ */
227
+ export declare class ArkAliasTypeDefineStmt extends Stmt {
228
+ private aliasType;
229
+ private aliasTypeExpr;
230
+ constructor(aliasType: AliasType, typeAliasExpr: AliasTypeExpr);
231
+ getAliasType(): AliasType;
232
+ getAliasTypeExpr(): AliasTypeExpr;
233
+ getAliasName(): string;
234
+ toString(): string;
235
+ getExprs(): AliasTypeExpr[];
236
+ getTypeExprs(): AbstractTypeExpr[];
237
+ }
238
238
  //# sourceMappingURL=Stmt.d.ts.map