eslint 0.22.0 → 0.24.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +20 -20
- package/README.md +111 -95
- package/bin/eslint.js +41 -41
- package/conf/environments.js +87 -81
- package/conf/eslint.json +186 -179
- package/lib/api.js +13 -12
- package/lib/cli-engine.js +441 -451
- package/lib/cli.js +196 -196
- package/lib/config-initializer.js +145 -145
- package/lib/config-validator.js +110 -110
- package/lib/config.js +428 -416
- package/lib/eslint.js +1072 -1073
- package/lib/file-finder.js +167 -167
- package/lib/formatters/checkstyle.js +68 -68
- package/lib/formatters/compact.js +53 -53
- package/lib/formatters/jslint-xml.js +40 -40
- package/lib/formatters/junit.js +63 -63
- package/lib/formatters/stylish.js +90 -90
- package/lib/formatters/tap.js +86 -86
- package/lib/ignored-paths.js +137 -137
- package/lib/load-rules.js +39 -39
- package/lib/options.js +132 -126
- package/lib/rule-context.js +107 -107
- package/lib/rules/accessor-pairs.js +65 -65
- package/lib/rules/array-bracket-spacing.js +180 -0
- package/lib/rules/block-scoped-var.js +339 -320
- package/lib/rules/brace-style.js +228 -228
- package/lib/rules/camelcase.js +111 -111
- package/lib/rules/comma-dangle.js +67 -64
- package/lib/rules/comma-spacing.js +191 -191
- package/lib/rules/comma-style.js +195 -195
- package/lib/rules/complexity.js +94 -94
- package/lib/rules/computed-property-spacing.js +144 -0
- package/lib/rules/consistent-return.js +75 -75
- package/lib/rules/consistent-this.js +119 -119
- package/lib/rules/constructor-super.js +108 -0
- package/lib/rules/curly.js +109 -109
- package/lib/rules/default-case.js +66 -66
- package/lib/rules/dot-location.js +63 -63
- package/lib/rules/dot-notation.js +119 -119
- package/lib/rules/eol-last.js +38 -38
- package/lib/rules/eqeqeq.js +96 -96
- package/lib/rules/func-names.js +45 -45
- package/lib/rules/func-style.js +49 -49
- package/lib/rules/generator-star-spacing.js +104 -87
- package/lib/rules/generator-star.js +76 -76
- package/lib/rules/global-strict.js +49 -49
- package/lib/rules/guard-for-in.js +32 -32
- package/lib/rules/handle-callback-err.js +81 -124
- package/lib/rules/indent.js +486 -486
- package/lib/rules/key-spacing.js +325 -325
- package/lib/rules/linebreak-style.js +44 -44
- package/lib/rules/lines-around-comment.js +228 -160
- package/lib/rules/max-depth.js +89 -89
- package/lib/rules/max-len.js +76 -76
- package/lib/rules/max-nested-callbacks.js +73 -73
- package/lib/rules/max-params.js +45 -45
- package/lib/rules/max-statements.js +61 -61
- package/lib/rules/new-cap.js +224 -224
- package/lib/rules/new-parens.js +29 -29
- package/lib/rules/newline-after-var.js +127 -127
- package/lib/rules/no-alert.js +153 -153
- package/lib/rules/no-array-constructor.js +31 -31
- package/lib/rules/no-bitwise.js +57 -57
- package/lib/rules/no-caller.js +29 -29
- package/lib/rules/no-catch-shadow.js +52 -52
- package/lib/rules/no-comma-dangle.js +45 -45
- package/lib/rules/no-cond-assign.js +123 -123
- package/lib/rules/no-console.js +27 -27
- package/lib/rules/no-constant-condition.js +73 -73
- package/lib/rules/no-continue.js +23 -23
- package/lib/rules/no-control-regex.js +58 -58
- package/lib/rules/no-debugger.js +22 -22
- package/lib/rules/no-delete-var.js +25 -25
- package/lib/rules/no-div-regex.js +27 -27
- package/lib/rules/no-dupe-args.js +89 -85
- package/lib/rules/no-dupe-keys.js +43 -43
- package/lib/rules/no-duplicate-case.js +67 -67
- package/lib/rules/no-else-return.js +125 -125
- package/lib/rules/no-empty-character-class.js +43 -43
- package/lib/rules/no-empty-class.js +45 -45
- package/lib/rules/no-empty-label.js +27 -27
- package/lib/rules/no-empty.js +49 -49
- package/lib/rules/no-eq-null.js +29 -29
- package/lib/rules/no-eval.js +26 -26
- package/lib/rules/no-ex-assign.js +42 -42
- package/lib/rules/no-extend-native.js +103 -103
- package/lib/rules/no-extra-bind.js +81 -81
- package/lib/rules/no-extra-boolean-cast.js +71 -71
- package/lib/rules/no-extra-parens.js +368 -355
- package/lib/rules/no-extra-semi.js +70 -23
- package/lib/rules/no-extra-strict.js +86 -86
- package/lib/rules/no-fallthrough.js +97 -97
- package/lib/rules/no-floating-decimal.js +30 -30
- package/lib/rules/no-func-assign.js +83 -83
- package/lib/rules/no-implied-eval.js +76 -76
- package/lib/rules/no-inline-comments.js +49 -49
- package/lib/rules/no-inner-declarations.js +78 -78
- package/lib/rules/no-invalid-regexp.js +53 -53
- package/lib/rules/no-irregular-whitespace.js +135 -135
- package/lib/rules/no-iterator.js +28 -28
- package/lib/rules/no-label-var.js +64 -64
- package/lib/rules/no-labels.js +44 -44
- package/lib/rules/no-lone-blocks.js +106 -27
- package/lib/rules/no-lonely-if.js +30 -30
- package/lib/rules/no-loop-func.js +58 -58
- package/lib/rules/no-mixed-requires.js +165 -165
- package/lib/rules/no-mixed-spaces-and-tabs.js +74 -74
- package/lib/rules/no-multi-spaces.js +119 -119
- package/lib/rules/no-multi-str.js +43 -43
- package/lib/rules/no-multiple-empty-lines.js +98 -98
- package/lib/rules/no-native-reassign.js +62 -62
- package/lib/rules/no-negated-in-lhs.js +25 -25
- package/lib/rules/no-nested-ternary.js +24 -24
- package/lib/rules/no-new-func.js +25 -25
- package/lib/rules/no-new-object.js +25 -25
- package/lib/rules/no-new-require.js +25 -25
- package/lib/rules/no-new-wrappers.js +26 -26
- package/lib/rules/no-new.js +27 -27
- package/lib/rules/no-obj-calls.js +28 -28
- package/lib/rules/no-octal-escape.js +39 -39
- package/lib/rules/no-octal.js +25 -25
- package/lib/rules/no-param-reassign.js +87 -87
- package/lib/rules/no-path-concat.js +39 -39
- package/lib/rules/no-plusplus.js +24 -24
- package/lib/rules/no-process-env.js +30 -30
- package/lib/rules/no-process-exit.js +33 -33
- package/lib/rules/no-proto.js +28 -28
- package/lib/rules/no-redeclare.js +68 -68
- package/lib/rules/no-regex-spaces.js +35 -35
- package/lib/rules/no-reserved-keys.js +56 -56
- package/lib/rules/no-restricted-modules.js +85 -85
- package/lib/rules/no-return-assign.js +53 -24
- package/lib/rules/no-script-url.js +34 -34
- package/lib/rules/no-self-compare.js +29 -29
- package/lib/rules/no-sequences.js +94 -94
- package/lib/rules/no-shadow-restricted-names.js +51 -51
- package/lib/rules/no-shadow.js +181 -136
- package/lib/rules/no-space-before-semi.js +98 -98
- package/lib/rules/no-spaced-func.js +37 -37
- package/lib/rules/no-sparse-arrays.js +33 -33
- package/lib/rules/no-sync.js +30 -30
- package/lib/rules/no-ternary.js +24 -24
- package/lib/rules/no-this-before-super.js +144 -0
- package/lib/rules/no-throw-literal.js +33 -33
- package/lib/rules/no-trailing-spaces.js +74 -63
- package/lib/rules/no-undef-init.js +28 -28
- package/lib/rules/no-undef.js +92 -92
- package/lib/rules/no-undefined.js +27 -27
- package/lib/rules/no-underscore-dangle.js +73 -73
- package/lib/rules/no-unexpected-multiline.js +58 -0
- package/lib/rules/no-unneeded-ternary.js +48 -48
- package/lib/rules/no-unreachable.js +98 -98
- package/lib/rules/no-unused-expressions.js +76 -76
- package/lib/rules/no-unused-vars.js +252 -250
- package/lib/rules/no-use-before-define.js +105 -105
- package/lib/rules/no-var.js +26 -26
- package/lib/rules/no-void.js +28 -28
- package/lib/rules/no-warning-comments.js +102 -102
- package/lib/rules/no-with.js +22 -22
- package/lib/rules/no-wrap-func.js +65 -65
- package/lib/rules/object-curly-spacing.js +231 -206
- package/lib/rules/object-shorthand.js +74 -73
- package/lib/rules/one-var.js +311 -304
- package/lib/rules/operator-assignment.js +118 -118
- package/lib/rules/operator-linebreak.js +114 -114
- package/lib/rules/padded-blocks.js +98 -98
- package/lib/rules/prefer-const.js +91 -0
- package/lib/rules/quote-props.js +72 -72
- package/lib/rules/quotes.js +92 -92
- package/lib/rules/radix.js +41 -41
- package/lib/rules/semi-spacing.js +167 -167
- package/lib/rules/semi.js +136 -136
- package/lib/rules/sort-vars.js +49 -49
- package/lib/rules/space-after-function-name.js +49 -49
- package/lib/rules/space-after-keywords.js +82 -82
- package/lib/rules/space-before-blocks.js +91 -91
- package/lib/rules/space-before-function-paren.js +139 -139
- package/lib/rules/space-before-function-parentheses.js +139 -139
- package/lib/rules/space-in-brackets.js +305 -305
- package/lib/rules/space-in-parens.js +281 -281
- package/lib/rules/space-infix-ops.js +106 -106
- package/lib/rules/space-return-throw-case.js +38 -38
- package/lib/rules/space-unary-ops.js +124 -133
- package/lib/rules/spaced-comment.js +143 -0
- package/lib/rules/spaced-line-comment.js +89 -89
- package/lib/rules/strict.js +242 -242
- package/lib/rules/use-isnan.js +26 -26
- package/lib/rules/valid-jsdoc.js +215 -215
- package/lib/rules/valid-typeof.js +42 -42
- package/lib/rules/vars-on-top.js +115 -115
- package/lib/rules/wrap-iife.js +48 -48
- package/lib/rules/wrap-regex.js +38 -38
- package/lib/rules/yoda.js +242 -225
- package/lib/rules.js +88 -88
- package/lib/timing.js +109 -109
- package/lib/token-store.js +201 -201
- package/lib/util/traverse.js +105 -105
- package/lib/util.js +125 -85
- package/package.json +6 -6
- package/CHANGELOG.md +0 -1638
package/lib/rules/no-shadow.js
CHANGED
@@ -1,136 +1,181 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag on declaring variables already declared in the outer scope
|
3
|
-
* @author Ilya Volodin
|
4
|
-
* @copyright 2013 Ilya Volodin. All rights reserved.
|
5
|
-
*/
|
6
|
-
|
7
|
-
"use strict";
|
8
|
-
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
// Rule Definition
|
11
|
-
//------------------------------------------------------------------------------
|
12
|
-
|
13
|
-
module.exports = function(context) {
|
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
|
-
var
|
45
|
-
var
|
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
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag on declaring variables already declared in the outer scope
|
3
|
+
* @author Ilya Volodin
|
4
|
+
* @copyright 2013 Ilya Volodin. All rights reserved.
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
// Rule Definition
|
11
|
+
//------------------------------------------------------------------------------
|
12
|
+
|
13
|
+
module.exports = function(context) {
|
14
|
+
|
15
|
+
var options = {
|
16
|
+
hoist: (context.options[0] && context.options[0].hoist) || "functions"
|
17
|
+
};
|
18
|
+
|
19
|
+
/**
|
20
|
+
* Checks if a variable of the class name in the class scope of ClassDeclaration.
|
21
|
+
*
|
22
|
+
* ClassDeclaration creates two variables of its name into its outer scope and its class scope.
|
23
|
+
* So we should ignore the variable in the class scope.
|
24
|
+
*
|
25
|
+
* @param {Object} variable The variable to check.
|
26
|
+
* @returns {boolean} Whether or not the variable of the class name in the class scope of ClassDeclaration.
|
27
|
+
*/
|
28
|
+
function isDuplicatedClassNameVariable(variable) {
|
29
|
+
var block = variable.scope.block;
|
30
|
+
return block.type === "ClassDeclaration" && block.id === variable.identifiers[0];
|
31
|
+
}
|
32
|
+
|
33
|
+
/**
|
34
|
+
* Checks if a variable is inside the initializer of scopeVar.
|
35
|
+
*
|
36
|
+
* To avoid reporting at declarations such as `var a = function a() {};`.
|
37
|
+
* But it should report `var a = function(a) {};` or `var a = function() { function a() {} };`.
|
38
|
+
*
|
39
|
+
* @param {Object} variable The variable to check.
|
40
|
+
* @param {Object} scopeVar The scope variable to look for.
|
41
|
+
* @returns {boolean} Whether or not the variable is inside initializer of scopeVar.
|
42
|
+
*/
|
43
|
+
function isOnInitializer(variable, scopeVar) {
|
44
|
+
var outerScope = scopeVar.scope;
|
45
|
+
var outerDef = scopeVar.defs[0];
|
46
|
+
var outer = outerDef && outerDef.parent && outerDef.parent.range;
|
47
|
+
var innerScope = variable.scope;
|
48
|
+
var innerDef = variable.defs[0];
|
49
|
+
var inner = innerDef && innerDef.name.range;
|
50
|
+
|
51
|
+
return (
|
52
|
+
outer != null &&
|
53
|
+
inner != null &&
|
54
|
+
outer[0] < inner[0] &&
|
55
|
+
inner[1] < outer[1] &&
|
56
|
+
((innerDef.type === "FunctionName" && innerDef.node.type === "FunctionExpression") || innerDef.node.type === "ClassExpression") &&
|
57
|
+
outerScope === innerScope.upper
|
58
|
+
);
|
59
|
+
}
|
60
|
+
|
61
|
+
/**
|
62
|
+
* Get a range of a variable's identifier node.
|
63
|
+
* @param {Object} variable The variable to get.
|
64
|
+
* @returns {Array|undefined} The range of the variable's identifier node.
|
65
|
+
*/
|
66
|
+
function getNameRange(variable) {
|
67
|
+
var def = variable.defs[0];
|
68
|
+
return def && def.name.range;
|
69
|
+
}
|
70
|
+
|
71
|
+
/**
|
72
|
+
* Checks if a variable is in TDZ of scopeVar.
|
73
|
+
* @param {Object} variable The variable to check.
|
74
|
+
* @param {Object} scopeVar The variable of TDZ.
|
75
|
+
* @returns {boolean} Whether or not the variable is in TDZ of scopeVar.
|
76
|
+
*/
|
77
|
+
function isInTdz(variable, scopeVar) {
|
78
|
+
var outerDef = scopeVar.defs[0];
|
79
|
+
var inner = getNameRange(variable);
|
80
|
+
var outer = getNameRange(scopeVar);
|
81
|
+
return (
|
82
|
+
inner != null &&
|
83
|
+
outer != null &&
|
84
|
+
inner[1] < outer[0] &&
|
85
|
+
// Excepts FunctionDeclaration if is {"hoist":"function"}.
|
86
|
+
(options.hoist !== "functions" || outerDef == null || outerDef.node.type !== "FunctionDeclaration")
|
87
|
+
);
|
88
|
+
}
|
89
|
+
|
90
|
+
/**
|
91
|
+
* Checks if a variable is contained in the list of given scope variables.
|
92
|
+
* @param {Object} variable The variable to check.
|
93
|
+
* @param {Array} scopeVars The scope variables to look for.
|
94
|
+
* @returns {boolean} Whether or not the variable is contains in the list of scope variables.
|
95
|
+
*/
|
96
|
+
function isContainedInScopeVars(variable, scopeVars) {
|
97
|
+
return scopeVars.some(function (scopeVar) {
|
98
|
+
return (
|
99
|
+
scopeVar.identifiers.length > 0 &&
|
100
|
+
variable.name === scopeVar.name &&
|
101
|
+
!isDuplicatedClassNameVariable(scopeVar) &&
|
102
|
+
!isOnInitializer(variable, scopeVar) &&
|
103
|
+
!(options.hoist !== "all" && isInTdz(variable, scopeVar))
|
104
|
+
);
|
105
|
+
});
|
106
|
+
}
|
107
|
+
|
108
|
+
/**
|
109
|
+
* Checks if the given variables are shadowed in the given scope.
|
110
|
+
* @param {Array} variables The variables to look for
|
111
|
+
* @param {Object} scope The scope to be checked.
|
112
|
+
* @returns {Array} Variables which are not declared in the given scope.
|
113
|
+
*/
|
114
|
+
function checkShadowsInScope(variables, scope) {
|
115
|
+
|
116
|
+
var passedVars = [];
|
117
|
+
|
118
|
+
variables.forEach(function (variable) {
|
119
|
+
// "arguments" is a special case that has no identifiers (#1759)
|
120
|
+
if (variable.identifiers.length > 0 && isContainedInScopeVars(variable, scope.variables)) {
|
121
|
+
context.report(
|
122
|
+
variable.identifiers[0],
|
123
|
+
"{{name}} is already declared in the upper scope.",
|
124
|
+
{name: variable.name});
|
125
|
+
} else {
|
126
|
+
passedVars.push(variable);
|
127
|
+
}
|
128
|
+
});
|
129
|
+
|
130
|
+
return passedVars;
|
131
|
+
}
|
132
|
+
|
133
|
+
/**
|
134
|
+
* Checks the current context for shadowed variables.
|
135
|
+
* @param {Scope} scope - Fixme
|
136
|
+
* @returns {void}
|
137
|
+
*/
|
138
|
+
function checkForShadows(scope) {
|
139
|
+
var variables = scope.variables.filter(function(variable) {
|
140
|
+
return (
|
141
|
+
// Skip "arguments".
|
142
|
+
variable.identifiers.length > 0 &&
|
143
|
+
// Skip variables of a class name in the class scope of ClassDeclaration.
|
144
|
+
!isDuplicatedClassNameVariable(variable)
|
145
|
+
);
|
146
|
+
});
|
147
|
+
|
148
|
+
// iterate through the array of variables and find duplicates with the upper scope
|
149
|
+
var upper = scope.upper;
|
150
|
+
while (upper && variables.length) {
|
151
|
+
variables = checkShadowsInScope(variables, upper);
|
152
|
+
upper = upper.upper;
|
153
|
+
}
|
154
|
+
}
|
155
|
+
|
156
|
+
return {
|
157
|
+
"Program:exit": function () {
|
158
|
+
var globalScope = context.getScope(),
|
159
|
+
stack = globalScope.childScopes.slice(),
|
160
|
+
scope;
|
161
|
+
|
162
|
+
while (stack.length) {
|
163
|
+
scope = stack.pop();
|
164
|
+
stack.push.apply(stack, scope.childScopes);
|
165
|
+
checkForShadows(scope);
|
166
|
+
}
|
167
|
+
}
|
168
|
+
};
|
169
|
+
|
170
|
+
};
|
171
|
+
|
172
|
+
module.exports.schema = [
|
173
|
+
{
|
174
|
+
"type": "object",
|
175
|
+
"properties": {
|
176
|
+
"hoist": {
|
177
|
+
"enum": ["all", "functions", "never"]
|
178
|
+
}
|
179
|
+
}
|
180
|
+
}
|
181
|
+
];
|
@@ -1,98 +1,98 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to disallow whitespace before the semicolon
|
3
|
-
* @author Jonathan Kingston
|
4
|
-
* @copyright 2015 Mathias Schreck
|
5
|
-
* @copyright 2014 Jonathan Kingston
|
6
|
-
*/
|
7
|
-
|
8
|
-
"use strict";
|
9
|
-
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
// Rule Definition
|
12
|
-
//------------------------------------------------------------------------------
|
13
|
-
|
14
|
-
module.exports = function(context) {
|
15
|
-
|
16
|
-
/**
|
17
|
-
* Determines whether two adjacent tokens are have whitespace between them.
|
18
|
-
* @param {Object} left - The left token object.
|
19
|
-
* @param {Object} right - The right token object.
|
20
|
-
* @returns {boolean} Whether or not there is space between the tokens.
|
21
|
-
*/
|
22
|
-
function isSpaced(left, right) {
|
23
|
-
return left.range[1] < right.range[0];
|
24
|
-
}
|
25
|
-
|
26
|
-
/**
|
27
|
-
* Checks whether two tokens are on the same line.
|
28
|
-
* @param {Object} left The leftmost token.
|
29
|
-
* @param {Object} right The rightmost token.
|
30
|
-
* @returns {boolean} True if the tokens are on the same line, false if not.
|
31
|
-
* @private
|
32
|
-
*/
|
33
|
-
function isSameLine(left, right) {
|
34
|
-
return left.loc.end.line === right.loc.start.line;
|
35
|
-
}
|
36
|
-
|
37
|
-
/**
|
38
|
-
* Checks if a given token has leading whitespace.
|
39
|
-
* @param {Object} token The token to check.
|
40
|
-
* @returns {boolean} True if the given token has leading space, false if not.
|
41
|
-
*/
|
42
|
-
function hasLeadingSpace(token) {
|
43
|
-
var tokenBefore = context.getTokenBefore(token);
|
44
|
-
return isSameLine(tokenBefore, token) && isSpaced(tokenBefore, token);
|
45
|
-
}
|
46
|
-
|
47
|
-
/**
|
48
|
-
* Checks if the given token is a semicolon.
|
49
|
-
* @param {Token} token The token to check.
|
50
|
-
* @returns {boolean} Whether or not the given token is a semicolon.
|
51
|
-
*/
|
52
|
-
function isSemicolon(token) {
|
53
|
-
return token.type === "Punctuator" && token.value === ";";
|
54
|
-
}
|
55
|
-
|
56
|
-
/**
|
57
|
-
* Reports if the given token has leading space.
|
58
|
-
* @param {Token} token The semicolon token to check.
|
59
|
-
* @param {ASTNode} node The corresponding node of the token.
|
60
|
-
* @returns {void}
|
61
|
-
*/
|
62
|
-
function checkSemiTokenForLeadingSpace(token, node) {
|
63
|
-
if (isSemicolon(token) && hasLeadingSpace(token)) {
|
64
|
-
context.report(node, token.loc.start, "Unexpected whitespace before semicolon.");
|
65
|
-
}
|
66
|
-
}
|
67
|
-
|
68
|
-
/**
|
69
|
-
* Checks leading space before the semicolon with the assumption that the last token is the semicolon.
|
70
|
-
* @param {ASTNode} node The node to check.
|
71
|
-
* @returns {void}
|
72
|
-
*/
|
73
|
-
function checkNode(node) {
|
74
|
-
var token = context.getLastToken(node);
|
75
|
-
checkSemiTokenForLeadingSpace(token, node);
|
76
|
-
}
|
77
|
-
|
78
|
-
return {
|
79
|
-
"VariableDeclaration": checkNode,
|
80
|
-
"ExpressionStatement": checkNode,
|
81
|
-
"BreakStatement": checkNode,
|
82
|
-
"ContinueStatement": checkNode,
|
83
|
-
"DebuggerStatement": checkNode,
|
84
|
-
"ReturnStatement": checkNode,
|
85
|
-
"ThrowStatement": checkNode,
|
86
|
-
"ForStatement": function (node) {
|
87
|
-
if (node.init) {
|
88
|
-
checkSemiTokenForLeadingSpace(context.getTokenAfter(node.init), node);
|
89
|
-
}
|
90
|
-
|
91
|
-
if (node.test) {
|
92
|
-
checkSemiTokenForLeadingSpace(context.getTokenAfter(node.test), node);
|
93
|
-
}
|
94
|
-
}
|
95
|
-
};
|
96
|
-
};
|
97
|
-
|
98
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to disallow whitespace before the semicolon
|
3
|
+
* @author Jonathan Kingston
|
4
|
+
* @copyright 2015 Mathias Schreck
|
5
|
+
* @copyright 2014 Jonathan Kingston
|
6
|
+
*/
|
7
|
+
|
8
|
+
"use strict";
|
9
|
+
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
// Rule Definition
|
12
|
+
//------------------------------------------------------------------------------
|
13
|
+
|
14
|
+
module.exports = function(context) {
|
15
|
+
|
16
|
+
/**
|
17
|
+
* Determines whether two adjacent tokens are have whitespace between them.
|
18
|
+
* @param {Object} left - The left token object.
|
19
|
+
* @param {Object} right - The right token object.
|
20
|
+
* @returns {boolean} Whether or not there is space between the tokens.
|
21
|
+
*/
|
22
|
+
function isSpaced(left, right) {
|
23
|
+
return left.range[1] < right.range[0];
|
24
|
+
}
|
25
|
+
|
26
|
+
/**
|
27
|
+
* Checks whether two tokens are on the same line.
|
28
|
+
* @param {Object} left The leftmost token.
|
29
|
+
* @param {Object} right The rightmost token.
|
30
|
+
* @returns {boolean} True if the tokens are on the same line, false if not.
|
31
|
+
* @private
|
32
|
+
*/
|
33
|
+
function isSameLine(left, right) {
|
34
|
+
return left.loc.end.line === right.loc.start.line;
|
35
|
+
}
|
36
|
+
|
37
|
+
/**
|
38
|
+
* Checks if a given token has leading whitespace.
|
39
|
+
* @param {Object} token The token to check.
|
40
|
+
* @returns {boolean} True if the given token has leading space, false if not.
|
41
|
+
*/
|
42
|
+
function hasLeadingSpace(token) {
|
43
|
+
var tokenBefore = context.getTokenBefore(token);
|
44
|
+
return isSameLine(tokenBefore, token) && isSpaced(tokenBefore, token);
|
45
|
+
}
|
46
|
+
|
47
|
+
/**
|
48
|
+
* Checks if the given token is a semicolon.
|
49
|
+
* @param {Token} token The token to check.
|
50
|
+
* @returns {boolean} Whether or not the given token is a semicolon.
|
51
|
+
*/
|
52
|
+
function isSemicolon(token) {
|
53
|
+
return token.type === "Punctuator" && token.value === ";";
|
54
|
+
}
|
55
|
+
|
56
|
+
/**
|
57
|
+
* Reports if the given token has leading space.
|
58
|
+
* @param {Token} token The semicolon token to check.
|
59
|
+
* @param {ASTNode} node The corresponding node of the token.
|
60
|
+
* @returns {void}
|
61
|
+
*/
|
62
|
+
function checkSemiTokenForLeadingSpace(token, node) {
|
63
|
+
if (isSemicolon(token) && hasLeadingSpace(token)) {
|
64
|
+
context.report(node, token.loc.start, "Unexpected whitespace before semicolon.");
|
65
|
+
}
|
66
|
+
}
|
67
|
+
|
68
|
+
/**
|
69
|
+
* Checks leading space before the semicolon with the assumption that the last token is the semicolon.
|
70
|
+
* @param {ASTNode} node The node to check.
|
71
|
+
* @returns {void}
|
72
|
+
*/
|
73
|
+
function checkNode(node) {
|
74
|
+
var token = context.getLastToken(node);
|
75
|
+
checkSemiTokenForLeadingSpace(token, node);
|
76
|
+
}
|
77
|
+
|
78
|
+
return {
|
79
|
+
"VariableDeclaration": checkNode,
|
80
|
+
"ExpressionStatement": checkNode,
|
81
|
+
"BreakStatement": checkNode,
|
82
|
+
"ContinueStatement": checkNode,
|
83
|
+
"DebuggerStatement": checkNode,
|
84
|
+
"ReturnStatement": checkNode,
|
85
|
+
"ThrowStatement": checkNode,
|
86
|
+
"ForStatement": function (node) {
|
87
|
+
if (node.init) {
|
88
|
+
checkSemiTokenForLeadingSpace(context.getTokenAfter(node.init), node);
|
89
|
+
}
|
90
|
+
|
91
|
+
if (node.test) {
|
92
|
+
checkSemiTokenForLeadingSpace(context.getTokenAfter(node.test), node);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
};
|
96
|
+
};
|
97
|
+
|
98
|
+
module.exports.schema = [];
|
@@ -1,37 +1,37 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to check that spaced function application
|
3
|
-
* @author Matt DuVall <http://www.mattduvall.com>
|
4
|
-
*/
|
5
|
-
|
6
|
-
"use strict";
|
7
|
-
|
8
|
-
//------------------------------------------------------------------------------
|
9
|
-
// Rule Definition
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
|
12
|
-
module.exports = function(context) {
|
13
|
-
|
14
|
-
function detectOpenSpaces(node) {
|
15
|
-
var lastCalleeToken = context.getLastToken(node.callee);
|
16
|
-
var tokens = context.getTokens(node);
|
17
|
-
var i = tokens.indexOf(lastCalleeToken), l = tokens.length;
|
18
|
-
while (i < l && tokens[i].value !== "(") {
|
19
|
-
++i;
|
20
|
-
}
|
21
|
-
if (i >= l) {
|
22
|
-
return;
|
23
|
-
}
|
24
|
-
// look for a space between the callee and the open paren
|
25
|
-
if (tokens[i - 1].range[1] !== tokens[i].range[0]) {
|
26
|
-
context.report(node, "Unexpected space between function name and paren.");
|
27
|
-
}
|
28
|
-
}
|
29
|
-
|
30
|
-
return {
|
31
|
-
"CallExpression": detectOpenSpaces,
|
32
|
-
"NewExpression": detectOpenSpaces
|
33
|
-
};
|
34
|
-
|
35
|
-
};
|
36
|
-
|
37
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to check that spaced function application
|
3
|
+
* @author Matt DuVall <http://www.mattduvall.com>
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
//------------------------------------------------------------------------------
|
9
|
+
// Rule Definition
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
|
12
|
+
module.exports = function(context) {
|
13
|
+
|
14
|
+
function detectOpenSpaces(node) {
|
15
|
+
var lastCalleeToken = context.getLastToken(node.callee);
|
16
|
+
var tokens = context.getTokens(node);
|
17
|
+
var i = tokens.indexOf(lastCalleeToken), l = tokens.length;
|
18
|
+
while (i < l && tokens[i].value !== "(") {
|
19
|
+
++i;
|
20
|
+
}
|
21
|
+
if (i >= l) {
|
22
|
+
return;
|
23
|
+
}
|
24
|
+
// look for a space between the callee and the open paren
|
25
|
+
if (tokens[i - 1].range[1] !== tokens[i].range[0]) {
|
26
|
+
context.report(node, "Unexpected space between function name and paren.");
|
27
|
+
}
|
28
|
+
}
|
29
|
+
|
30
|
+
return {
|
31
|
+
"CallExpression": detectOpenSpaces,
|
32
|
+
"NewExpression": detectOpenSpaces
|
33
|
+
};
|
34
|
+
|
35
|
+
};
|
36
|
+
|
37
|
+
module.exports.schema = [];
|
@@ -1,33 +1,33 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Disallow sparse arrays
|
3
|
-
* @author Nicholas C. Zakas
|
4
|
-
*/
|
5
|
-
"use strict";
|
6
|
-
|
7
|
-
//------------------------------------------------------------------------------
|
8
|
-
// Rule Definition
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
|
11
|
-
module.exports = function(context) {
|
12
|
-
|
13
|
-
|
14
|
-
//--------------------------------------------------------------------------
|
15
|
-
// Public
|
16
|
-
//--------------------------------------------------------------------------
|
17
|
-
|
18
|
-
return {
|
19
|
-
|
20
|
-
"ArrayExpression": function(node) {
|
21
|
-
|
22
|
-
var emptySpot = node.elements.indexOf(null) > -1;
|
23
|
-
|
24
|
-
if (emptySpot) {
|
25
|
-
context.report(node, "Unexpected comma in middle of array.");
|
26
|
-
}
|
27
|
-
}
|
28
|
-
|
29
|
-
};
|
30
|
-
|
31
|
-
};
|
32
|
-
|
33
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Disallow sparse arrays
|
3
|
+
* @author Nicholas C. Zakas
|
4
|
+
*/
|
5
|
+
"use strict";
|
6
|
+
|
7
|
+
//------------------------------------------------------------------------------
|
8
|
+
// Rule Definition
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
|
11
|
+
module.exports = function(context) {
|
12
|
+
|
13
|
+
|
14
|
+
//--------------------------------------------------------------------------
|
15
|
+
// Public
|
16
|
+
//--------------------------------------------------------------------------
|
17
|
+
|
18
|
+
return {
|
19
|
+
|
20
|
+
"ArrayExpression": function(node) {
|
21
|
+
|
22
|
+
var emptySpot = node.elements.indexOf(null) > -1;
|
23
|
+
|
24
|
+
if (emptySpot) {
|
25
|
+
context.report(node, "Unexpected comma in middle of array.");
|
26
|
+
}
|
27
|
+
}
|
28
|
+
|
29
|
+
};
|
30
|
+
|
31
|
+
};
|
32
|
+
|
33
|
+
module.exports.schema = [];
|