This repository has been archived by the owner on Mar 25, 2021. It is now read-only.
/
ruleWalker.ts
126 lines (104 loc) · 4.08 KB
/
ruleWalker.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/**
* @license
* Copyright 2013 Palantir Technologies, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import * as ts from "typescript";
import { Fix, IOptions, Replacement, RuleFailure } from "../rule/rule";
import { SyntaxWalker } from "./syntaxWalker";
import { IWalker } from "./walker";
/**
* @deprecated
* RuleWalker-based rules are slow,
* so it's generally preferable to use applyWithFunction instead of applyWithWalker.
* @see https://github.com/palantir/tslint/issues/2522
*/
export class RuleWalker extends SyntaxWalker implements IWalker {
private readonly limit: number;
private readonly options?: any[];
private readonly failures: RuleFailure[];
private readonly ruleName: string;
constructor(private readonly sourceFile: ts.SourceFile, options: IOptions) {
super();
this.failures = [];
this.options = options.ruleArguments;
this.limit = this.sourceFile.getFullWidth();
this.ruleName = options.ruleName;
}
public getSourceFile(): ts.SourceFile {
return this.sourceFile;
}
public getLineAndCharacterOfPosition(position: number): ts.LineAndCharacter {
return this.sourceFile.getLineAndCharacterOfPosition(position);
}
public getFailures(): RuleFailure[] {
return this.failures;
}
public getLimit() {
return this.limit;
}
public getOptions(): any {
return this.options;
}
public hasOption(option: string): boolean {
if (this.options !== undefined) {
return this.options.indexOf(option) !== -1;
} else {
return false;
}
}
/** @deprecated Prefer `addFailureAt` and its variants. */
public createFailure(start: number, width: number, failure: string, fix?: Fix): RuleFailure {
const from = start > this.limit ? this.limit : start;
const to = start + width > this.limit ? this.limit : start + width;
return new RuleFailure(this.sourceFile, from, to, failure, this.ruleName, fix);
}
/** @deprecated Prefer `addFailureAt` and its variants. */
public addFailure(failure: RuleFailure) {
this.failures.push(failure);
}
/** Add a failure with any arbitrary span. Prefer `addFailureAtNode` if possible. */
public addFailureAt(start: number, width: number, failure: string, fix?: Fix) {
// tslint:disable-next-line deprecation
this.addFailure(this.createFailure(start, width, failure, fix));
}
/** Like `addFailureAt` but uses start and end instead of start and width. */
public addFailureFromStartToEnd(start: number, end: number, failure: string, fix?: Fix) {
this.addFailureAt(start, end - start, failure, fix);
}
/** Add a failure using a node's span. */
public addFailureAtNode(node: ts.Node, failure: string, fix?: Fix) {
this.addFailureAt(
node.getStart(this.sourceFile),
node.getWidth(this.sourceFile),
failure,
fix,
);
}
public createReplacement(start: number, length: number, text: string): Replacement {
return new Replacement(start, length, text);
}
public appendText(start: number, text: string): Replacement {
return this.createReplacement(start, 0, text);
}
public deleteText(start: number, length: number): Replacement {
return this.createReplacement(start, length, "");
}
public deleteFromTo(start: number, end: number): Replacement {
return this.createReplacement(start, end - start, "");
}
public getRuleName(): string {
return this.ruleName;
}
}