arkanalyzer 1.0.19 → 1.0.21

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 (290) hide show
  1. package/lib/Config.d.ts +70 -70
  2. package/lib/Config.js +198 -198
  3. package/lib/Scene.d.ts +316 -310
  4. package/lib/Scene.d.ts.map +1 -1
  5. package/lib/Scene.js +1316 -1271
  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.d.ts.map +1 -1
  28. package/lib/callgraph/pointerAnalysis/PagBuilder.js +1399 -1397
  29. package/lib/callgraph/pointerAnalysis/PointerAnalysis.d.ts +72 -72
  30. package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +573 -573
  31. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.d.ts +15 -15
  32. package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.js +81 -81
  33. package/lib/callgraph/pointerAnalysis/PtsDS.d.ts +80 -80
  34. package/lib/callgraph/pointerAnalysis/PtsDS.js +308 -308
  35. package/lib/core/base/Constant.d.ts +48 -48
  36. package/lib/core/base/Constant.js +103 -103
  37. package/lib/core/base/Decorator.d.ts +15 -15
  38. package/lib/core/base/Decorator.js +46 -46
  39. package/lib/core/base/DefUseChain.d.ts +8 -8
  40. package/lib/core/base/DefUseChain.js +25 -25
  41. package/lib/core/base/Expr.d.ts +340 -340
  42. package/lib/core/base/Expr.js +917 -917
  43. package/lib/core/base/Local.d.ts +104 -104
  44. package/lib/core/base/Local.js +176 -176
  45. package/lib/core/base/Position.d.ts +30 -30
  46. package/lib/core/base/Position.js +147 -147
  47. package/lib/core/base/Ref.d.ts +173 -173
  48. package/lib/core/base/Ref.js +374 -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 +67 -67
  62. package/lib/core/common/ArkIRTransformer.js +690 -690
  63. package/lib/core/common/ArkValueTransformer.d.ts +89 -89
  64. package/lib/core/common/ArkValueTransformer.js +1478 -1478
  65. package/lib/core/common/Builtin.d.ts +36 -36
  66. package/lib/core/common/Builtin.js +81 -81
  67. package/lib/core/common/Const.d.ts +21 -21
  68. package/lib/core/common/Const.js +43 -43
  69. package/lib/core/common/DummyMainCreater.d.ts +46 -42
  70. package/lib/core/common/DummyMainCreater.d.ts.map +1 -1
  71. package/lib/core/common/DummyMainCreater.js +319 -300
  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 +36 -36
  77. package/lib/core/common/IRInference.d.ts.map +1 -1
  78. package/lib/core/common/IRInference.js +651 -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.js +712 -712
  83. package/lib/core/common/RefUseReplacer.d.ts +13 -13
  84. package/lib/core/common/RefUseReplacer.js +52 -52
  85. package/lib/core/common/SdkUtils.d.ts +8 -8
  86. package/lib/core/common/SdkUtils.js +105 -105
  87. package/lib/core/common/StmtDefReplacer.d.ts +12 -12
  88. package/lib/core/common/StmtDefReplacer.js +41 -41
  89. package/lib/core/common/StmtUseReplacer.d.ts +16 -16
  90. package/lib/core/common/StmtUseReplacer.js +108 -108
  91. package/lib/core/common/TSConst.d.ts +18 -18
  92. package/lib/core/common/TSConst.js +36 -36
  93. package/lib/core/common/TypeInference.d.ts +102 -102
  94. package/lib/core/common/TypeInference.js +748 -748
  95. package/lib/core/common/ValueUtil.d.ts +12 -12
  96. package/lib/core/common/ValueUtil.js +54 -54
  97. package/lib/core/common/VisibleValue.d.ts +36 -36
  98. package/lib/core/common/VisibleValue.js +212 -212
  99. package/lib/core/dataflow/DataflowProblem.d.ts +20 -20
  100. package/lib/core/dataflow/DataflowProblem.js +20 -20
  101. package/lib/core/dataflow/DataflowResult.d.ts +7 -7
  102. package/lib/core/dataflow/DataflowResult.js +26 -26
  103. package/lib/core/dataflow/DataflowSolver.d.ts +43 -43
  104. package/lib/core/dataflow/DataflowSolver.js +307 -307
  105. package/lib/core/dataflow/Edge.d.ts +11 -11
  106. package/lib/core/dataflow/Edge.js +31 -31
  107. package/lib/core/dataflow/Fact.d.ts +6 -6
  108. package/lib/core/dataflow/Fact.js +24 -24
  109. package/lib/core/dataflow/GenericDataFlow.d.ts +143 -0
  110. package/lib/core/dataflow/GenericDataFlow.d.ts.map +1 -0
  111. package/lib/core/dataflow/GenericDataFlow.js +109 -0
  112. package/lib/core/dataflow/ReachingDef.d.ts +63 -0
  113. package/lib/core/dataflow/ReachingDef.d.ts.map +1 -0
  114. package/lib/core/dataflow/ReachingDef.js +168 -0
  115. package/lib/core/dataflow/UndefinedVariable.d.ts +45 -45
  116. package/lib/core/dataflow/UndefinedVariable.js +288 -288
  117. package/lib/core/dataflow/Util.d.ts +9 -9
  118. package/lib/core/dataflow/Util.js +64 -64
  119. package/lib/core/graph/BaseExplicitGraph.d.ts +58 -63
  120. package/lib/core/graph/BaseExplicitGraph.d.ts.map +1 -1
  121. package/lib/core/graph/BaseExplicitGraph.js +157 -157
  122. package/lib/core/graph/BaseImplicitGraph.d.ts +78 -0
  123. package/lib/core/graph/BaseImplicitGraph.d.ts.map +1 -0
  124. package/lib/core/graph/BaseImplicitGraph.js +78 -0
  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 +8 -0
  136. package/lib/core/graph/GraphTraits.d.ts.map +1 -0
  137. package/lib/core/graph/GraphTraits.js +16 -0
  138. package/lib/core/graph/Scc.d.ts +61 -60
  139. package/lib/core/graph/Scc.d.ts.map +1 -1
  140. package/lib/core/graph/Scc.js +222 -222
  141. package/lib/core/graph/ViewTree.d.ts +114 -114
  142. package/lib/core/graph/ViewTree.js +16 -16
  143. package/lib/core/graph/builder/CfgBuilder.d.ts +176 -176
  144. package/lib/core/graph/builder/CfgBuilder.js +1139 -1139
  145. package/lib/core/graph/builder/ConditionBuilder.d.ts +15 -15
  146. package/lib/core/graph/builder/ConditionBuilder.js +252 -252
  147. package/lib/core/graph/builder/LoopBuilder.d.ts +20 -20
  148. package/lib/core/graph/builder/LoopBuilder.js +251 -251
  149. package/lib/core/graph/builder/SwitchBuilder.d.ts +11 -11
  150. package/lib/core/graph/builder/SwitchBuilder.js +152 -152
  151. package/lib/core/graph/builder/TrapBuilder.d.ts +16 -16
  152. package/lib/core/graph/builder/TrapBuilder.js +272 -272
  153. package/lib/core/graph/builder/ViewTreeBuilder.d.ts +203 -203
  154. package/lib/core/graph/builder/ViewTreeBuilder.js +1055 -1055
  155. package/lib/core/model/ArkBaseModel.d.ts +59 -59
  156. package/lib/core/model/ArkBaseModel.js +274 -274
  157. package/lib/core/model/ArkBody.d.ts +24 -24
  158. package/lib/core/model/ArkBody.js +65 -65
  159. package/lib/core/model/ArkClass.d.ts +206 -206
  160. package/lib/core/model/ArkClass.js +439 -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 +162 -162
  176. package/lib/core/model/ArkSignature.js +379 -379
  177. package/lib/core/model/builder/ArkClassBuilder.d.ts +12 -12
  178. package/lib/core/model/builder/ArkClassBuilder.js +454 -454
  179. package/lib/core/model/builder/ArkExportBuilder.d.ts +24 -24
  180. package/lib/core/model/builder/ArkExportBuilder.js +210 -210
  181. package/lib/core/model/builder/ArkFieldBuilder.d.ts +8 -8
  182. package/lib/core/model/builder/ArkFieldBuilder.js +193 -193
  183. package/lib/core/model/builder/ArkFileBuilder.d.ts +9 -9
  184. package/lib/core/model/builder/ArkFileBuilder.js +165 -165
  185. package/lib/core/model/builder/ArkImportBuilder.d.ts +4 -4
  186. package/lib/core/model/builder/ArkImportBuilder.js +128 -128
  187. package/lib/core/model/builder/ArkMethodBuilder.d.ts +63 -63
  188. package/lib/core/model/builder/ArkMethodBuilder.js +486 -486
  189. package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +5 -5
  190. package/lib/core/model/builder/ArkNamespaceBuilder.js +205 -205
  191. package/lib/core/model/builder/ArkSignatureBuilder.d.ts +8 -8
  192. package/lib/core/model/builder/ArkSignatureBuilder.js +40 -40
  193. package/lib/core/model/builder/BodyBuilder.d.ts +55 -30
  194. package/lib/core/model/builder/BodyBuilder.d.ts.map +1 -1
  195. package/lib/core/model/builder/BodyBuilder.js +542 -371
  196. package/lib/core/model/builder/builderUtils.d.ts +18 -18
  197. package/lib/core/model/builder/builderUtils.js +558 -558
  198. package/lib/index.d.ts +82 -80
  199. package/lib/index.d.ts.map +1 -1
  200. package/lib/index.js +201 -196
  201. package/lib/save/ArkStream.d.ts +23 -23
  202. package/lib/save/ArkStream.js +83 -83
  203. package/lib/save/DotPrinter.d.ts +43 -43
  204. package/lib/save/DotPrinter.js +170 -170
  205. package/lib/save/GraphPrinter.d.ts +16 -15
  206. package/lib/save/GraphPrinter.d.ts.map +1 -1
  207. package/lib/save/GraphPrinter.js +134 -134
  208. package/lib/save/JsonPrinter.d.ts +30 -30
  209. package/lib/save/JsonPrinter.js +580 -580
  210. package/lib/save/Printer.d.ts +12 -12
  211. package/lib/save/Printer.js +27 -27
  212. package/lib/save/PrinterBuilder.d.ts +53 -53
  213. package/lib/save/PrinterBuilder.js +145 -145
  214. package/lib/save/ViewTreePrinter.d.ts +14 -14
  215. package/lib/save/ViewTreePrinter.js +123 -123
  216. package/lib/save/arkir/ArkIRClassPrinter.d.ts +13 -13
  217. package/lib/save/arkir/ArkIRClassPrinter.js +92 -92
  218. package/lib/save/arkir/ArkIRFieldPrinter.d.ts +11 -11
  219. package/lib/save/arkir/ArkIRFieldPrinter.js +64 -64
  220. package/lib/save/arkir/ArkIRFilePrinter.d.ts +12 -12
  221. package/lib/save/arkir/ArkIRFilePrinter.js +54 -54
  222. package/lib/save/arkir/ArkIRMethodPrinter.d.ts +16 -16
  223. package/lib/save/arkir/ArkIRMethodPrinter.js +159 -159
  224. package/lib/save/arkir/ArkIRNamespacePrinter.d.ts +11 -11
  225. package/lib/save/arkir/ArkIRNamespacePrinter.js +66 -66
  226. package/lib/save/base/BasePrinter.d.ts +23 -23
  227. package/lib/save/base/BasePrinter.js +70 -70
  228. package/lib/save/base/ExportPrinter.d.ts +8 -8
  229. package/lib/save/base/ExportPrinter.js +67 -67
  230. package/lib/save/base/ImportPrinter.d.ts +9 -9
  231. package/lib/save/base/ImportPrinter.js +92 -92
  232. package/lib/save/base/PrinterUtils.d.ts +24 -24
  233. package/lib/save/base/PrinterUtils.js +208 -208
  234. package/lib/save/serializeArkIR.d.ts +8 -8
  235. package/lib/save/serializeArkIR.js +294 -294
  236. package/lib/save/source/SourceBase.d.ts +22 -22
  237. package/lib/save/source/SourceBase.js +64 -64
  238. package/lib/save/source/SourceBody.d.ts +58 -58
  239. package/lib/save/source/SourceBody.js +296 -296
  240. package/lib/save/source/SourceClass.d.ts +25 -25
  241. package/lib/save/source/SourceClass.js +187 -187
  242. package/lib/save/source/SourceField.d.ts +13 -13
  243. package/lib/save/source/SourceField.js +73 -73
  244. package/lib/save/source/SourceFilePrinter.d.ts +12 -12
  245. package/lib/save/source/SourceFilePrinter.js +69 -69
  246. package/lib/save/source/SourceMethod.d.ts +22 -22
  247. package/lib/save/source/SourceMethod.d.ts.map +1 -1
  248. package/lib/save/source/SourceMethod.js +196 -193
  249. package/lib/save/source/SourceNamespace.d.ts +11 -11
  250. package/lib/save/source/SourceNamespace.js +83 -83
  251. package/lib/save/source/SourceStmt.d.ts +178 -178
  252. package/lib/save/source/SourceStmt.js +838 -838
  253. package/lib/save/source/SourceTransformer.d.ts +46 -46
  254. package/lib/save/source/SourceTransformer.js +446 -446
  255. package/lib/transformer/FunctionTransformer.d.ts +2 -2
  256. package/lib/transformer/FunctionTransformer.js +17 -17
  257. package/lib/transformer/SceneTransformer.d.ts +2 -2
  258. package/lib/transformer/SceneTransformer.js +17 -17
  259. package/lib/transformer/StaticSingleAssignmentFormer.d.ts +12 -12
  260. package/lib/transformer/StaticSingleAssignmentFormer.js +259 -259
  261. package/lib/transformer/Transformer.d.ts +6 -6
  262. package/lib/transformer/Transformer.js +22 -22
  263. package/lib/utils/AstTreeUtils.d.ts +4 -4
  264. package/lib/utils/AstTreeUtils.js +26 -26
  265. package/lib/utils/CfgStructualAnalysis.d.ts +110 -110
  266. package/lib/utils/CfgStructualAnalysis.js +1277 -1277
  267. package/lib/utils/FileUtils.d.ts +18 -18
  268. package/lib/utils/FileUtils.js +135 -135
  269. package/lib/utils/SparseBitVector.d.ts +100 -100
  270. package/lib/utils/SparseBitVector.d.ts.map +1 -1
  271. package/lib/utils/SparseBitVector.js +445 -444
  272. package/lib/utils/callGraphUtils.d.ts +30 -30
  273. package/lib/utils/callGraphUtils.js +205 -205
  274. package/lib/utils/crypto_utils.d.ts +5 -5
  275. package/lib/utils/crypto_utils.js +57 -57
  276. package/lib/utils/entryMethodUtils.d.ts +13 -13
  277. package/lib/utils/entryMethodUtils.js +110 -110
  278. package/lib/utils/getAllFiles.d.ts +9 -9
  279. package/lib/utils/getAllFiles.js +90 -90
  280. package/lib/utils/json5parser.d.ts +6 -6
  281. package/lib/utils/json5parser.js +146 -146
  282. package/lib/utils/logger.d.ts +18 -18
  283. package/lib/utils/logger.d.ts.map +1 -1
  284. package/lib/utils/logger.js +97 -90
  285. package/lib/utils/pathTransfer.d.ts +1 -1
  286. package/lib/utils/pathTransfer.js +25 -25
  287. package/node_modules/json5/lib/cli.js +0 -0
  288. package/node_modules/ohos-typescript/bin/tsc +0 -0
  289. package/node_modules/ohos-typescript/bin/tsserver +0 -0
  290. package/package.json +3 -2
@@ -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