Skip to content

Commit

Permalink
Single line ignore switches (palantir#1175)
Browse files Browse the repository at this point in the history
  • Loading branch information
patsissons authored and jkillian committed Apr 29, 2016
1 parent d133c0c commit a20178a
Showing 3 changed files with 57 additions and 8 deletions.
44 changes: 37 additions & 7 deletions src/enableDisableRules.ts
Original file line number Diff line number Diff line change
@@ -40,21 +40,30 @@ export class EnableDisableRulesWalker extends SkippableTokenAwareRuleWalker {
scanner.getToken() === ts.SyntaxKind.SingleLineCommentTrivia) {
const commentText = scanner.getTokenText();
const startPosition = scanner.getTokenPos();
this.handlePossibleTslintSwitch(commentText, startPosition);
this.handlePossibleTslintSwitch(commentText, startPosition, node, scanner);
}
});
}

private handlePossibleTslintSwitch(commentText: string, startingPosition: number) {
private getStartOfLinePosition(node: ts.SourceFile, position: number, lineOffset = 0) {
return node.getPositionOfLineAndCharacter(
node.getLineAndCharacterOfPosition(position).line + lineOffset, 0
);
}

private handlePossibleTslintSwitch(commentText: string, startingPosition: number, node: ts.SourceFile, scanner: ts.Scanner) {
// regex is: start of string followed by "/*" or "//" followed by any amount of whitespace followed by "tslint:"
if (commentText.match(/^(\/\*|\/\/)\s*tslint:/)) {
const commentTextParts = commentText.split(":");
// regex is: start of string followed by either "enable" or "disable"
// followed optionally by -line or -next-line
// followed by either whitespace or end of string
const enableOrDisableMatch = commentTextParts[1].match(/^(enable|disable)(\s|$)/);
const enableOrDisableMatch = commentTextParts[1].match(/^(enable|disable)(-(line|next-line))?(\s|$)/);

if (enableOrDisableMatch != null) {
const isEnabled = enableOrDisableMatch[1] === "enable";
const isCurrentLine = enableOrDisableMatch[3] === "line";
const isNextLine = enableOrDisableMatch[3] === "next-line";
let rulesList = ["all"];
if (commentTextParts.length > 2) {
rulesList = commentTextParts[2].split(/\s+/);
@@ -63,10 +72,31 @@ export class EnableDisableRulesWalker extends SkippableTokenAwareRuleWalker {
if (!(ruleToAdd in this.enableDisableRuleMap)) {
this.enableDisableRuleMap[ruleToAdd] = [];
}
this.enableDisableRuleMap[ruleToAdd].push({
isEnabled: isEnabled,
position: startingPosition,
});
if (isCurrentLine) {
// start at the beginning of the current line
this.enableDisableRuleMap[ruleToAdd].push({
isEnabled: isEnabled,
position: this.getStartOfLinePosition(node, startingPosition),
});
// end at the beginning of the next line
this.enableDisableRuleMap[ruleToAdd].push({
isEnabled: !isEnabled,
position: scanner.getTextPos() + 1,
});
} else {
// start at the current position
this.enableDisableRuleMap[ruleToAdd].push({
isEnabled: isEnabled,
position: startingPosition,
});
// end at the beginning of the line following the next line
if (isNextLine) {
this.enableDisableRuleMap[ruleToAdd].push({
isEnabled: !isEnabled,
position: this.getStartOfLinePosition(node, startingPosition, 2),
});
}
}
}
}
}
14 changes: 14 additions & 0 deletions test/files/enabledisable.test.ts
Original file line number Diff line number Diff line change
@@ -27,5 +27,19 @@ re = /`/;
var AAAaA = 'test'
// tslint:enable

var AAAaA = 'test' // tslint:disable-line
var AAAaA = 'test' /* tslint:disable-line */

// tslint:disable-next-line:quotemark variable-name
var AAAaA = 'test'
/* tslint:disable-next-line:quotemark variable-name */
var AAAaA = 'test'

// tslint:disable
var AAAaA = 'test' // tslint:enable-line:quotemark
// tslint:enable-next-line:variable-name
var AAAaA = 'test'
// tslint:enable

/* tslint:disable:quotemark */
var s = 'xxx';
7 changes: 6 additions & 1 deletion test/ruleDisableEnableTests.ts
Original file line number Diff line number Diff line change
@@ -50,6 +50,9 @@ describe("Enable and Disable Rules", () => {
const expectedFailure5 = quotemarkFailure([10, 13], [10, 19]);
const expectedFailure6 = quotemarkFailure([16, 13], [16, 19]);

const expectedFailure7 = quotemarkFailure([39, 13], [39, 19]);
const expectedFailure8 = variableNameFailure([41, 5], [41, 10]);

const ll = new Linter(relativePath, source, options);
const result = ll.lint();
const parsedResult = JSON.parse(result.output);
@@ -66,6 +69,8 @@ describe("Enable and Disable Rules", () => {
TestUtils.assertContainsFailure(actualFailures, expectedFailure4);
TestUtils.assertContainsFailure(actualFailures, expectedFailure5);
TestUtils.assertContainsFailure(actualFailures, expectedFailure6);
assert.lengthOf(actualFailures, 6);
TestUtils.assertContainsFailure(actualFailures, expectedFailure7);
TestUtils.assertContainsFailure(actualFailures, expectedFailure8);
assert.lengthOf(actualFailures, 8);
});
});

0 comments on commit a20178a

Please sign in to comment.