2017-05-28 00:38:50 +02:00
"use strict" ;
/ * *
* @ 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 .
* /
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
var tslib _1 = require ( "tslib" ) ;
var tsutils _1 = require ( "tsutils" ) ;
var ts = require ( "typescript" ) ;
var Lint = require ( "../index" ) ;
var OPTION _ALLOW _NULL _CHECK = "allow-null-check" ;
var OPTION _ALLOW _UNDEFINED _CHECK = "allow-undefined-check" ;
var Rule = ( function ( _super ) {
tslib _1 . _ _extends ( Rule , _super ) ;
function Rule ( ) {
return _super !== null && _super . apply ( this , arguments ) || this ;
}
Rule . prototype . apply = function ( sourceFile ) {
return this . applyWithFunction ( sourceFile , walk , {
allowNull : this . ruleArguments . indexOf ( OPTION _ALLOW _NULL _CHECK ) !== - 1 ,
allowUndefined : this . ruleArguments . indexOf ( OPTION _ALLOW _UNDEFINED _CHECK ) !== - 1 ,
} ) ;
} ;
2017-08-14 05:01:11 +02:00
/* tslint:disable:object-literal-sort-keys */
Rule . metadata = {
ruleName : "triple-equals" ,
description : "Requires `===` and `!==` in place of `==` and `!=`." ,
optionsDescription : ( _a = [ "\n Two arguments may be optionally provided:\n\n * `\"allow-null-check\"` allows `==` and `!=` when comparing to `null`.\n * `\"allow-undefined-check\"` allows `==` and `!=` when comparing to `undefined`." ] , _a . raw = [ "\n Two arguments may be optionally provided:\n\n * \\`\"allow-null-check\"\\` allows \\`==\\` and \\`!=\\` when comparing to \\`null\\`.\n * \\`\"allow-undefined-check\"\\` allows \\`==\\` and \\`!=\\` when comparing to \\`undefined\\`." ] , Lint . Utils . dedent ( _a ) ) ,
options : {
type : "array" ,
items : {
type : "string" ,
enum : [ OPTION _ALLOW _NULL _CHECK , OPTION _ALLOW _UNDEFINED _CHECK ] ,
} ,
minLength : 0 ,
maxLength : 2 ,
} ,
optionExamples : [
true ,
[ true , "allow-null-check" ] ,
[ true , "allow-undefined-check" ] ,
] ,
type : "functionality" ,
typescriptOnly : false ,
} ;
/* tslint:enable:object-literal-sort-keys */
Rule . EQ _FAILURE _STRING = "== should be ===" ;
Rule . NEQ _FAILURE _STRING = "!= should be !==" ;
2017-05-28 00:38:50 +02:00
return Rule ;
} ( Lint . Rules . AbstractRule ) ) ;
exports . Rule = Rule ;
function walk ( ctx ) {
return ts . forEachChild ( ctx . sourceFile , function cb ( node ) {
if ( tsutils _1 . isBinaryExpression ( node ) ) {
if ( ( node . operatorToken . kind === ts . SyntaxKind . EqualsEqualsToken ||
node . operatorToken . kind === ts . SyntaxKind . ExclamationEqualsToken ) &&
! ( isExpressionAllowed ( node . right , ctx . options ) || isExpressionAllowed ( node . left , ctx . options ) ) ) {
ctx . addFailureAtNode ( node . operatorToken , node . operatorToken . kind === ts . SyntaxKind . EqualsEqualsToken
? Rule . EQ _FAILURE _STRING
: Rule . NEQ _FAILURE _STRING ) ;
}
}
return ts . forEachChild ( node , cb ) ;
} ) ;
}
function isExpressionAllowed ( node , options ) {
if ( node . kind === ts . SyntaxKind . NullKeyword ) {
return options . allowNull ;
}
return options . allowUndefined &&
node . kind === ts . SyntaxKind . Identifier &&
node . originalKeywordKind === ts . SyntaxKind . UndefinedKeyword ;
}
var _a ;