From 19a1de10084941d06ca761abbf8ba12a1f869df1 Mon Sep 17 00:00:00 2001 From: Rob Lourens Date: Sun, 7 Oct 2018 17:07:58 -0700 Subject: [PATCH] Fix #525 - safe/consistent .tsx file type checks --- src/noFunctionExpressionRule.ts | 4 +++- src/preferTypeCastRule.ts | 3 ++- src/utils/AstUtils.ts | 2 +- 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/noFunctionExpressionRule.ts b/src/noFunctionExpressionRule.ts index 0682bafaf..bc173215b 100644 --- a/src/noFunctionExpressionRule.ts +++ b/src/noFunctionExpressionRule.ts @@ -1,6 +1,7 @@ import * as ts from 'typescript'; import * as Lint from 'tslint'; +import { AstUtils } from './utils/AstUtils'; import {ErrorTolerantWalker} from './utils/ErrorTolerantWalker'; import {ExtendedMetadata} from './utils/ExtendedMetadata'; @@ -37,7 +38,8 @@ class NoFunctionExpressionRuleWalker extends ErrorTolerantWalker { constructor(sourceFile: ts.SourceFile, options: Lint.IOptions) { super(sourceFile, options); - if (sourceFile.fileName.endsWith('tsx')) { + + if (AstUtils.getLanguageVariant(sourceFile) === ts.LanguageVariant.JSX) { this.allowGenericFunctionExpression = true; } } diff --git a/src/preferTypeCastRule.ts b/src/preferTypeCastRule.ts index 381ad6d56..8521bf1c7 100644 --- a/src/preferTypeCastRule.ts +++ b/src/preferTypeCastRule.ts @@ -1,6 +1,7 @@ import * as ts from 'typescript'; import * as Lint from 'tslint'; +import { AstUtils } from './utils/AstUtils'; import {ErrorTolerantWalker} from './utils/ErrorTolerantWalker'; import {ExtendedMetadata} from './utils/ExtendedMetadata'; @@ -34,7 +35,7 @@ export class Rule extends Lint.Rules.AbstractRule { class PreferTypeCastRuleWalker extends ErrorTolerantWalker { protected visitSourceFile(node: ts.SourceFile): void { - if (/.*\.tsx/.test(node.fileName) === false) { + if (AstUtils.getLanguageVariant(node) === ts.LanguageVariant.Standard) { super.visitSourceFile(node); } } diff --git a/src/utils/AstUtils.ts b/src/utils/AstUtils.ts index 4bbf5b1cb..526d63329 100644 --- a/src/utils/AstUtils.ts +++ b/src/utils/AstUtils.ts @@ -6,7 +6,7 @@ import * as ts from 'typescript'; export module AstUtils { export function getLanguageVariant(node: ts.SourceFile): ts.LanguageVariant { - if (/.*\.tsx/i.test(node.fileName)) { + if (node.fileName.endsWith('.tsx')) { return ts.LanguageVariant.JSX; } else { return ts.LanguageVariant.Standard;