2017-05-28 00:38:50 +02:00
"use strict" ;
/ * *
* @ license
* Copyright 2016 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 ts = require ( "typescript" ) ;
var Lint = require ( "../index" ) ;
var OPTION _FUNCTION _IN _METHOD = "check-function-in-method" ;
var DEPRECATED _OPTION _FUNCTION _IN _METHOD = "no-this-in-function-in-method" ;
var Rule = ( function ( _super ) {
tslib _1 . _ _extends ( Rule , _super ) ;
function Rule ( ) {
return _super !== null && _super . apply ( this , arguments ) || this ;
}
Rule . prototype . apply = function ( sourceFile ) {
var _this = this ;
var hasOption = function ( name ) { return _this . ruleArguments . indexOf ( name ) !== - 1 ; } ;
var checkFuncInMethod = hasOption ( DEPRECATED _OPTION _FUNCTION _IN _METHOD ) || hasOption ( OPTION _FUNCTION _IN _METHOD ) ;
return this . applyWithFunction ( sourceFile , walk , checkFuncInMethod ) ;
} ;
2017-08-14 05:01:11 +02:00
/* tslint:disable:object-literal-sort-keys */
Rule . metadata = {
ruleName : "no-invalid-this" ,
description : "Disallows using the `this` keyword outside of classes." ,
rationale : "See [the rule's author's rationale here.](https://github.com/palantir/tslint/pull/1105#issue-147549402)" ,
optionsDescription : ( _a = [ "\n One argument may be optionally provided:\n\n * `" , "` disallows using the `this` keyword in functions within class methods." ] , _a . raw = [ "\n One argument may be optionally provided:\n\n * \\`" , "\\` disallows using the \\`this\\` keyword in functions within class methods." ] , Lint . Utils . dedent ( _a , OPTION _FUNCTION _IN _METHOD ) ) ,
options : {
type : "array" ,
items : {
type : "string" ,
enum : [ OPTION _FUNCTION _IN _METHOD ] ,
} ,
minLength : 0 ,
maxLength : 1 ,
} ,
optionExamples : [ true , [ true , OPTION _FUNCTION _IN _METHOD ] ] ,
type : "functionality" ,
typescriptOnly : false ,
} ;
/* tslint:enable:object-literal-sort-keys */
Rule . FAILURE _STRING _OUTSIDE = "the \"this\" keyword is disallowed outside of a class body" ;
Rule . FAILURE _STRING _INSIDE = "the \"this\" keyword is disallowed in function bodies inside class methods, " +
"use arrow functions instead" ;
2017-05-28 00:38:50 +02:00
return Rule ;
} ( Lint . Rules . AbstractRule ) ) ;
exports . Rule = Rule ;
function walk ( ctx ) {
var sourceFile = ctx . sourceFile , checkFuncInMethod = ctx . options ;
var inClass = false ;
var inFunctionInClass = false ;
ts . forEachChild ( sourceFile , function cb ( node ) {
switch ( node . kind ) {
case ts . SyntaxKind . ClassDeclaration :
case ts . SyntaxKind . ClassExpression :
if ( ! inClass ) {
inClass = true ;
ts . forEachChild ( node , cb ) ;
inClass = false ;
return ;
}
break ;
case ts . SyntaxKind . FunctionDeclaration :
case ts . SyntaxKind . FunctionExpression :
if ( inClass ) {
inFunctionInClass = true ;
ts . forEachChild ( node , cb ) ;
inFunctionInClass = false ;
return ;
}
break ;
case ts . SyntaxKind . ThisKeyword :
if ( ! inClass ) {
ctx . addFailureAtNode ( node , Rule . FAILURE _STRING _OUTSIDE ) ;
}
else if ( checkFuncInMethod && inFunctionInClass ) {
ctx . addFailureAtNode ( node , Rule . FAILURE _STRING _INSIDE ) ;
}
return ;
}
ts . forEachChild ( node , cb ) ;
} ) ;
}
var _a ;