arkanalyzer 1.0.20 → 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.
- package/lib/Config.d.ts +70 -70
- package/lib/Config.js +198 -198
- package/lib/Scene.d.ts +316 -316
- package/lib/Scene.js +1316 -1316
- package/lib/callgraph/algorithm/AbstractAnalysis.d.ts +28 -28
- package/lib/callgraph/algorithm/AbstractAnalysis.js +144 -144
- package/lib/callgraph/algorithm/ClassHierarchyAnalysis.d.ts +10 -10
- package/lib/callgraph/algorithm/ClassHierarchyAnalysis.js +69 -69
- package/lib/callgraph/algorithm/RapidTypeAnalysis.d.ts +15 -15
- package/lib/callgraph/algorithm/RapidTypeAnalysis.js +146 -146
- package/lib/callgraph/common/Statistics.d.ts +57 -57
- package/lib/callgraph/common/Statistics.js +228 -228
- package/lib/callgraph/model/CallGraph.d.ts +96 -96
- package/lib/callgraph/model/CallGraph.js +354 -354
- package/lib/callgraph/model/builder/CallGraphBuilder.d.ts +15 -15
- package/lib/callgraph/model/builder/CallGraphBuilder.js +106 -106
- package/lib/callgraph/pointerAnalysis/Context.d.ts +37 -37
- package/lib/callgraph/pointerAnalysis/Context.js +155 -155
- package/lib/callgraph/pointerAnalysis/DummyCallCreator.d.ts +22 -22
- package/lib/callgraph/pointerAnalysis/DummyCallCreator.js +104 -104
- package/lib/callgraph/pointerAnalysis/PTAUtils.d.ts +5 -5
- package/lib/callgraph/pointerAnalysis/PTAUtils.js +46 -46
- package/lib/callgraph/pointerAnalysis/Pag.d.ts +261 -261
- package/lib/callgraph/pointerAnalysis/Pag.js +930 -930
- package/lib/callgraph/pointerAnalysis/PagBuilder.d.ts +157 -157
- package/lib/callgraph/pointerAnalysis/PagBuilder.js +1399 -1399
- package/lib/callgraph/pointerAnalysis/PointerAnalysis.d.ts +72 -72
- package/lib/callgraph/pointerAnalysis/PointerAnalysis.js +573 -573
- package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.d.ts +15 -15
- package/lib/callgraph/pointerAnalysis/PointerAnalysisConfig.js +81 -81
- package/lib/callgraph/pointerAnalysis/PtsDS.d.ts +80 -80
- package/lib/callgraph/pointerAnalysis/PtsDS.js +308 -308
- package/lib/core/base/Constant.d.ts +48 -48
- package/lib/core/base/Constant.js +103 -103
- package/lib/core/base/Decorator.d.ts +15 -15
- package/lib/core/base/Decorator.js +46 -46
- package/lib/core/base/DefUseChain.d.ts +8 -8
- package/lib/core/base/DefUseChain.js +25 -25
- package/lib/core/base/Expr.d.ts +340 -340
- package/lib/core/base/Expr.js +917 -917
- package/lib/core/base/Local.d.ts +104 -104
- package/lib/core/base/Local.js +176 -176
- package/lib/core/base/Position.d.ts +30 -30
- package/lib/core/base/Position.js +147 -147
- package/lib/core/base/Ref.d.ts +173 -173
- package/lib/core/base/Ref.js +374 -374
- package/lib/core/base/Stmt.d.ts +237 -237
- package/lib/core/base/Stmt.js +525 -525
- package/lib/core/base/Trap.d.ts +8 -8
- package/lib/core/base/Trap.js +30 -30
- package/lib/core/base/Type.d.ts +308 -308
- package/lib/core/base/Type.js +639 -639
- package/lib/core/base/TypeExpr.d.ts +71 -71
- package/lib/core/base/TypeExpr.js +155 -155
- package/lib/core/base/Value.d.ts +32 -32
- package/lib/core/base/Value.js +16 -16
- package/lib/core/common/ArkError.d.ts +14 -14
- package/lib/core/common/ArkError.js +28 -28
- package/lib/core/common/ArkIRTransformer.d.ts +67 -67
- package/lib/core/common/ArkIRTransformer.js +690 -690
- package/lib/core/common/ArkValueTransformer.d.ts +89 -89
- package/lib/core/common/ArkValueTransformer.js +1478 -1478
- package/lib/core/common/Builtin.d.ts +36 -36
- package/lib/core/common/Builtin.js +81 -81
- package/lib/core/common/Const.d.ts +21 -21
- package/lib/core/common/Const.js +43 -43
- package/lib/core/common/DummyMainCreater.d.ts +46 -46
- package/lib/core/common/DummyMainCreater.js +319 -319
- package/lib/core/common/EtsConst.d.ts +73 -73
- package/lib/core/common/EtsConst.js +1021 -1021
- package/lib/core/common/ExprUseReplacer.d.ts +21 -21
- package/lib/core/common/ExprUseReplacer.js +124 -124
- package/lib/core/common/IRInference.d.ts +36 -36
- package/lib/core/common/IRInference.d.ts.map +1 -1
- package/lib/core/common/IRInference.js +651 -648
- package/lib/core/common/IRUtils.d.ts +18 -18
- package/lib/core/common/IRUtils.js +141 -141
- package/lib/core/common/ModelUtils.d.ts +70 -70
- package/lib/core/common/ModelUtils.js +712 -712
- package/lib/core/common/RefUseReplacer.d.ts +13 -13
- package/lib/core/common/RefUseReplacer.js +52 -52
- package/lib/core/common/SdkUtils.d.ts +8 -8
- package/lib/core/common/SdkUtils.js +105 -105
- package/lib/core/common/StmtDefReplacer.d.ts +12 -12
- package/lib/core/common/StmtDefReplacer.js +41 -41
- package/lib/core/common/StmtUseReplacer.d.ts +16 -16
- package/lib/core/common/StmtUseReplacer.js +108 -108
- package/lib/core/common/TSConst.d.ts +18 -18
- package/lib/core/common/TSConst.js +36 -36
- package/lib/core/common/TypeInference.d.ts +102 -102
- package/lib/core/common/TypeInference.js +748 -748
- package/lib/core/common/ValueUtil.d.ts +12 -12
- package/lib/core/common/ValueUtil.js +54 -54
- package/lib/core/common/VisibleValue.d.ts +36 -36
- package/lib/core/common/VisibleValue.js +212 -212
- package/lib/core/dataflow/DataflowProblem.d.ts +20 -20
- package/lib/core/dataflow/DataflowProblem.js +20 -20
- package/lib/core/dataflow/DataflowResult.d.ts +7 -7
- package/lib/core/dataflow/DataflowResult.js +26 -26
- package/lib/core/dataflow/DataflowSolver.d.ts +43 -43
- package/lib/core/dataflow/DataflowSolver.js +307 -307
- package/lib/core/dataflow/Edge.d.ts +11 -11
- package/lib/core/dataflow/Edge.js +31 -31
- package/lib/core/dataflow/Fact.d.ts +6 -6
- package/lib/core/dataflow/Fact.js +24 -24
- package/lib/core/dataflow/GenericDataFlow.d.ts +142 -142
- package/lib/core/dataflow/GenericDataFlow.js +109 -109
- package/lib/core/dataflow/ReachingDef.d.ts +62 -62
- package/lib/core/dataflow/ReachingDef.js +168 -168
- package/lib/core/dataflow/UndefinedVariable.d.ts +45 -45
- package/lib/core/dataflow/UndefinedVariable.js +288 -288
- package/lib/core/dataflow/Util.d.ts +9 -9
- package/lib/core/dataflow/Util.js +64 -64
- package/lib/core/graph/BaseExplicitGraph.d.ts +58 -58
- package/lib/core/graph/BaseExplicitGraph.js +157 -157
- package/lib/core/graph/BaseImplicitGraph.d.ts +77 -77
- package/lib/core/graph/BaseImplicitGraph.js +78 -78
- package/lib/core/graph/BasicBlock.d.ts +104 -104
- package/lib/core/graph/BasicBlock.js +280 -280
- package/lib/core/graph/Cfg.d.ts +59 -59
- package/lib/core/graph/Cfg.js +282 -282
- package/lib/core/graph/DependsGraph.d.ts +35 -35
- package/lib/core/graph/DependsGraph.js +87 -87
- package/lib/core/graph/DominanceFinder.d.ts +15 -15
- package/lib/core/graph/DominanceFinder.js +121 -121
- package/lib/core/graph/DominanceTree.d.ts +12 -12
- package/lib/core/graph/DominanceTree.js +70 -70
- package/lib/core/graph/GraphTraits.d.ts +7 -7
- package/lib/core/graph/GraphTraits.js +16 -16
- package/lib/core/graph/Scc.d.ts +61 -61
- package/lib/core/graph/Scc.js +222 -222
- package/lib/core/graph/ViewTree.d.ts +114 -114
- package/lib/core/graph/ViewTree.js +16 -16
- package/lib/core/graph/builder/CfgBuilder.d.ts +176 -176
- package/lib/core/graph/builder/CfgBuilder.js +1139 -1139
- package/lib/core/graph/builder/ConditionBuilder.d.ts +15 -15
- package/lib/core/graph/builder/ConditionBuilder.js +252 -252
- package/lib/core/graph/builder/LoopBuilder.d.ts +20 -20
- package/lib/core/graph/builder/LoopBuilder.js +251 -251
- package/lib/core/graph/builder/SwitchBuilder.d.ts +11 -11
- package/lib/core/graph/builder/SwitchBuilder.js +152 -152
- package/lib/core/graph/builder/TrapBuilder.d.ts +16 -16
- package/lib/core/graph/builder/TrapBuilder.js +272 -272
- package/lib/core/graph/builder/ViewTreeBuilder.d.ts +203 -203
- package/lib/core/graph/builder/ViewTreeBuilder.js +1055 -1055
- package/lib/core/model/ArkBaseModel.d.ts +59 -59
- package/lib/core/model/ArkBaseModel.js +274 -274
- package/lib/core/model/ArkBody.d.ts +24 -24
- package/lib/core/model/ArkBody.js +65 -65
- package/lib/core/model/ArkClass.d.ts +206 -206
- package/lib/core/model/ArkClass.js +439 -439
- package/lib/core/model/ArkExport.d.ts +72 -72
- package/lib/core/model/ArkExport.js +147 -147
- package/lib/core/model/ArkField.d.ts +62 -62
- package/lib/core/model/ArkField.js +113 -113
- package/lib/core/model/ArkFile.d.ts +131 -131
- package/lib/core/model/ArkFile.js +267 -267
- package/lib/core/model/ArkImport.d.ts +44 -44
- package/lib/core/model/ArkImport.js +108 -108
- package/lib/core/model/ArkMetadata.d.ts +31 -31
- package/lib/core/model/ArkMetadata.js +55 -55
- package/lib/core/model/ArkMethod.d.ts +261 -261
- package/lib/core/model/ArkMethod.js +592 -592
- package/lib/core/model/ArkNamespace.d.ts +66 -66
- package/lib/core/model/ArkNamespace.js +209 -209
- package/lib/core/model/ArkSignature.d.ts +162 -162
- package/lib/core/model/ArkSignature.js +379 -379
- package/lib/core/model/builder/ArkClassBuilder.d.ts +12 -12
- package/lib/core/model/builder/ArkClassBuilder.js +454 -454
- package/lib/core/model/builder/ArkExportBuilder.d.ts +24 -24
- package/lib/core/model/builder/ArkExportBuilder.js +210 -210
- package/lib/core/model/builder/ArkFieldBuilder.d.ts +8 -8
- package/lib/core/model/builder/ArkFieldBuilder.js +193 -193
- package/lib/core/model/builder/ArkFileBuilder.d.ts +9 -9
- package/lib/core/model/builder/ArkFileBuilder.js +165 -165
- package/lib/core/model/builder/ArkImportBuilder.d.ts +4 -4
- package/lib/core/model/builder/ArkImportBuilder.js +128 -128
- package/lib/core/model/builder/ArkMethodBuilder.d.ts +63 -63
- package/lib/core/model/builder/ArkMethodBuilder.js +486 -486
- package/lib/core/model/builder/ArkNamespaceBuilder.d.ts +5 -5
- package/lib/core/model/builder/ArkNamespaceBuilder.js +205 -205
- package/lib/core/model/builder/ArkSignatureBuilder.d.ts +8 -8
- package/lib/core/model/builder/ArkSignatureBuilder.js +40 -40
- package/lib/core/model/builder/BodyBuilder.d.ts +55 -30
- package/lib/core/model/builder/BodyBuilder.d.ts.map +1 -1
- package/lib/core/model/builder/BodyBuilder.js +542 -371
- package/lib/core/model/builder/builderUtils.d.ts +18 -18
- package/lib/core/model/builder/builderUtils.js +558 -558
- package/lib/index.d.ts +82 -80
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +201 -196
- package/lib/save/ArkStream.d.ts +23 -23
- package/lib/save/ArkStream.js +83 -83
- package/lib/save/DotPrinter.d.ts +43 -43
- package/lib/save/DotPrinter.js +170 -170
- package/lib/save/GraphPrinter.d.ts +16 -16
- package/lib/save/GraphPrinter.js +134 -134
- package/lib/save/JsonPrinter.d.ts +30 -30
- package/lib/save/JsonPrinter.js +580 -580
- package/lib/save/Printer.d.ts +12 -12
- package/lib/save/Printer.js +27 -27
- package/lib/save/PrinterBuilder.d.ts +53 -53
- package/lib/save/PrinterBuilder.js +145 -145
- package/lib/save/ViewTreePrinter.d.ts +14 -14
- package/lib/save/ViewTreePrinter.js +123 -123
- package/lib/save/arkir/ArkIRClassPrinter.d.ts +13 -13
- package/lib/save/arkir/ArkIRClassPrinter.js +92 -92
- package/lib/save/arkir/ArkIRFieldPrinter.d.ts +11 -11
- package/lib/save/arkir/ArkIRFieldPrinter.js +64 -64
- package/lib/save/arkir/ArkIRFilePrinter.d.ts +12 -12
- package/lib/save/arkir/ArkIRFilePrinter.js +54 -54
- package/lib/save/arkir/ArkIRMethodPrinter.d.ts +16 -16
- package/lib/save/arkir/ArkIRMethodPrinter.js +159 -159
- package/lib/save/arkir/ArkIRNamespacePrinter.d.ts +11 -11
- package/lib/save/arkir/ArkIRNamespacePrinter.js +66 -66
- package/lib/save/base/BasePrinter.d.ts +23 -23
- package/lib/save/base/BasePrinter.js +70 -70
- package/lib/save/base/ExportPrinter.d.ts +8 -8
- package/lib/save/base/ExportPrinter.js +67 -67
- package/lib/save/base/ImportPrinter.d.ts +9 -9
- package/lib/save/base/ImportPrinter.js +92 -92
- package/lib/save/base/PrinterUtils.d.ts +24 -24
- package/lib/save/base/PrinterUtils.js +208 -208
- package/lib/save/serializeArkIR.d.ts +8 -8
- package/lib/save/serializeArkIR.js +294 -294
- package/lib/save/source/SourceBase.d.ts +22 -22
- package/lib/save/source/SourceBase.js +64 -64
- package/lib/save/source/SourceBody.d.ts +58 -58
- package/lib/save/source/SourceBody.js +296 -296
- package/lib/save/source/SourceClass.d.ts +25 -25
- package/lib/save/source/SourceClass.js +187 -187
- package/lib/save/source/SourceField.d.ts +13 -13
- package/lib/save/source/SourceField.js +73 -73
- package/lib/save/source/SourceFilePrinter.d.ts +12 -12
- package/lib/save/source/SourceFilePrinter.js +69 -69
- package/lib/save/source/SourceMethod.d.ts +22 -22
- package/lib/save/source/SourceMethod.d.ts.map +1 -1
- package/lib/save/source/SourceMethod.js +196 -193
- package/lib/save/source/SourceNamespace.d.ts +11 -11
- package/lib/save/source/SourceNamespace.js +83 -83
- package/lib/save/source/SourceStmt.d.ts +178 -178
- package/lib/save/source/SourceStmt.js +838 -838
- package/lib/save/source/SourceTransformer.d.ts +46 -46
- package/lib/save/source/SourceTransformer.js +446 -446
- package/lib/transformer/FunctionTransformer.d.ts +2 -2
- package/lib/transformer/FunctionTransformer.js +17 -17
- package/lib/transformer/SceneTransformer.d.ts +2 -2
- package/lib/transformer/SceneTransformer.js +17 -17
- package/lib/transformer/StaticSingleAssignmentFormer.d.ts +12 -12
- package/lib/transformer/StaticSingleAssignmentFormer.js +259 -259
- package/lib/transformer/Transformer.d.ts +6 -6
- package/lib/transformer/Transformer.js +22 -22
- package/lib/utils/AstTreeUtils.d.ts +4 -4
- package/lib/utils/AstTreeUtils.js +26 -26
- package/lib/utils/CfgStructualAnalysis.d.ts +110 -110
- package/lib/utils/CfgStructualAnalysis.js +1277 -1277
- package/lib/utils/FileUtils.d.ts +18 -18
- package/lib/utils/FileUtils.js +135 -135
- package/lib/utils/SparseBitVector.d.ts +100 -100
- package/lib/utils/SparseBitVector.js +445 -445
- package/lib/utils/callGraphUtils.d.ts +30 -30
- package/lib/utils/callGraphUtils.js +205 -205
- package/lib/utils/crypto_utils.d.ts +5 -5
- package/lib/utils/crypto_utils.js +57 -57
- package/lib/utils/entryMethodUtils.d.ts +13 -13
- package/lib/utils/entryMethodUtils.js +110 -110
- package/lib/utils/getAllFiles.d.ts +9 -9
- package/lib/utils/getAllFiles.js +90 -90
- package/lib/utils/json5parser.d.ts +6 -6
- package/lib/utils/json5parser.js +146 -146
- package/lib/utils/logger.d.ts +18 -18
- package/lib/utils/logger.d.ts.map +1 -1
- package/lib/utils/logger.js +97 -90
- package/lib/utils/pathTransfer.d.ts +1 -1
- package/lib/utils/pathTransfer.js +25 -25
- package/node_modules/json5/lib/cli.js +0 -0
- package/node_modules/ohos-typescript/bin/tsc +0 -0
- package/node_modules/ohos-typescript/bin/tsserver +0 -0
- package/package.json +3 -3
package/lib/core/base/Stmt.d.ts
CHANGED
|
@@ -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
|