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-sync.js
CHANGED
@@ -1,30 +1,30 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to check for properties whose identifier ends with the string Sync
|
3
|
-
* @author Matt DuVall<http://mattduvall.com/>
|
4
|
-
*/
|
5
|
-
|
6
|
-
/*jshint node:true*/
|
7
|
-
|
8
|
-
"use strict";
|
9
|
-
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
// Rule Definition
|
12
|
-
//------------------------------------------------------------------------------
|
13
|
-
|
14
|
-
module.exports = function(context) {
|
15
|
-
|
16
|
-
return {
|
17
|
-
|
18
|
-
"MemberExpression": function(node) {
|
19
|
-
var propertyName = node.property.name,
|
20
|
-
syncRegex = /.*Sync$/;
|
21
|
-
|
22
|
-
if (syncRegex.exec(propertyName) !== null) {
|
23
|
-
context.report(node, "Unexpected sync method: '" + propertyName + "'.");
|
24
|
-
}
|
25
|
-
}
|
26
|
-
};
|
27
|
-
|
28
|
-
};
|
29
|
-
|
30
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to check for properties whose identifier ends with the string Sync
|
3
|
+
* @author Matt DuVall<http://mattduvall.com/>
|
4
|
+
*/
|
5
|
+
|
6
|
+
/*jshint node:true*/
|
7
|
+
|
8
|
+
"use strict";
|
9
|
+
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
// Rule Definition
|
12
|
+
//------------------------------------------------------------------------------
|
13
|
+
|
14
|
+
module.exports = function(context) {
|
15
|
+
|
16
|
+
return {
|
17
|
+
|
18
|
+
"MemberExpression": function(node) {
|
19
|
+
var propertyName = node.property.name,
|
20
|
+
syncRegex = /.*Sync$/;
|
21
|
+
|
22
|
+
if (syncRegex.exec(propertyName) !== null) {
|
23
|
+
context.report(node, "Unexpected sync method: '" + propertyName + "'.");
|
24
|
+
}
|
25
|
+
}
|
26
|
+
};
|
27
|
+
|
28
|
+
};
|
29
|
+
|
30
|
+
module.exports.schema = [];
|
package/lib/rules/no-ternary.js
CHANGED
@@ -1,24 +1,24 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag use of ternary operators.
|
3
|
-
* @author Ian Christian Myers
|
4
|
-
*/
|
5
|
-
|
6
|
-
"use strict";
|
7
|
-
|
8
|
-
//------------------------------------------------------------------------------
|
9
|
-
// Rule Definition
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
|
12
|
-
module.exports = function(context) {
|
13
|
-
|
14
|
-
return {
|
15
|
-
|
16
|
-
"ConditionalExpression": function(node) {
|
17
|
-
context.report(node, "Ternary operator used.");
|
18
|
-
}
|
19
|
-
|
20
|
-
};
|
21
|
-
|
22
|
-
};
|
23
|
-
|
24
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag use of ternary operators.
|
3
|
+
* @author Ian Christian Myers
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
//------------------------------------------------------------------------------
|
9
|
+
// Rule Definition
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
|
12
|
+
module.exports = function(context) {
|
13
|
+
|
14
|
+
return {
|
15
|
+
|
16
|
+
"ConditionalExpression": function(node) {
|
17
|
+
context.report(node, "Ternary operator used.");
|
18
|
+
}
|
19
|
+
|
20
|
+
};
|
21
|
+
|
22
|
+
};
|
23
|
+
|
24
|
+
module.exports.schema = [];
|
@@ -0,0 +1,144 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview A rule to disallow using `this`/`super` before `super()`.
|
3
|
+
* @author Toru Nagashima
|
4
|
+
* @copyright 2015 Toru Nagashima. All rights reserved.
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
// Rule Definition
|
11
|
+
//------------------------------------------------------------------------------
|
12
|
+
|
13
|
+
module.exports = function(context) {
|
14
|
+
|
15
|
+
/**
|
16
|
+
* Searches a class node that a node is belonging to.
|
17
|
+
* @param {Node} node - A node to start searching.
|
18
|
+
* @returns {ClassDeclaration|ClassExpression|null} the found class node, or `null`.
|
19
|
+
*/
|
20
|
+
function getClassInAncestor(node) {
|
21
|
+
while (node != null) {
|
22
|
+
if (node.type === "ClassDeclaration" || node.type === "ClassExpression") {
|
23
|
+
return node;
|
24
|
+
}
|
25
|
+
node = node.parent;
|
26
|
+
}
|
27
|
+
/* istanbul ignore next */
|
28
|
+
return null;
|
29
|
+
}
|
30
|
+
|
31
|
+
/**
|
32
|
+
* Checks whether or not a node is the null literal.
|
33
|
+
* @param {Node} node - A node to check.
|
34
|
+
* @returns {boolean} whether or not a node is the null literal.
|
35
|
+
*/
|
36
|
+
function isNullLiteral(node) {
|
37
|
+
return node != null && node.type === "Literal" && node.value === null;
|
38
|
+
}
|
39
|
+
|
40
|
+
/**
|
41
|
+
* Checks whether or not a node is the callee of a call expression.
|
42
|
+
* @param {Node} node - A node to check.
|
43
|
+
* @returns {boolean} whether or not a node is the callee of a call expression.
|
44
|
+
*/
|
45
|
+
function isCallee(node) {
|
46
|
+
return node != null && node.parent.type === "CallExpression" && node.parent.callee === node;
|
47
|
+
}
|
48
|
+
|
49
|
+
/**
|
50
|
+
* Checks whether or not the current traversal context is before `super()`.
|
51
|
+
* @param {object} item - A checking context.
|
52
|
+
* @returns {boolean} whether or not the current traversal context is before `super()`.
|
53
|
+
*/
|
54
|
+
function isBeforeSuperCalling(item) {
|
55
|
+
return (
|
56
|
+
item != null &&
|
57
|
+
item.scope === context.getScope().variableScope.upper.variableScope &&
|
58
|
+
item.superCalled === false
|
59
|
+
);
|
60
|
+
}
|
61
|
+
|
62
|
+
var stack = [];
|
63
|
+
|
64
|
+
return {
|
65
|
+
/**
|
66
|
+
* Start checking.
|
67
|
+
* @param {MethodDefinition} node - A target node.
|
68
|
+
* @returns {void}
|
69
|
+
*/
|
70
|
+
"MethodDefinition": function(node) {
|
71
|
+
if (node.kind !== "constructor") {
|
72
|
+
return;
|
73
|
+
}
|
74
|
+
stack.push({
|
75
|
+
thisOrSuperBeforeSuperCalled: [],
|
76
|
+
superCalled: false,
|
77
|
+
scope: context.getScope().variableScope
|
78
|
+
});
|
79
|
+
},
|
80
|
+
|
81
|
+
/**
|
82
|
+
* Treats the result of checking and reports invalid `this`/`super`.
|
83
|
+
* @param {MethodDefinition} node - A target node.
|
84
|
+
* @returns {void}
|
85
|
+
*/
|
86
|
+
"MethodDefinition:exit": function(node) {
|
87
|
+
if (node.kind !== "constructor") {
|
88
|
+
return;
|
89
|
+
}
|
90
|
+
var result = stack.pop();
|
91
|
+
|
92
|
+
// Skip if it has no extends or `extends null`.
|
93
|
+
var classNode = getClassInAncestor(node);
|
94
|
+
if (classNode == null || classNode.superClass == null || isNullLiteral(classNode.superClass)) {
|
95
|
+
return;
|
96
|
+
}
|
97
|
+
|
98
|
+
// Reports.
|
99
|
+
result.thisOrSuperBeforeSuperCalled.forEach(function(thisOrSuper) {
|
100
|
+
var type = (thisOrSuper.type === "Super" ? "super" : "this");
|
101
|
+
context.report(thisOrSuper, "\"{{type}}\" is not allowed before super()", {type: type});
|
102
|
+
});
|
103
|
+
},
|
104
|
+
|
105
|
+
/**
|
106
|
+
* Marks the node if is before `super()`.
|
107
|
+
* @param {ThisExpression} node - A target node.
|
108
|
+
* @returns {void}
|
109
|
+
*/
|
110
|
+
"ThisExpression": function(node) {
|
111
|
+
var item = stack[stack.length - 1];
|
112
|
+
if (isBeforeSuperCalling(item)) {
|
113
|
+
item.thisOrSuperBeforeSuperCalled.push(node);
|
114
|
+
}
|
115
|
+
},
|
116
|
+
|
117
|
+
/**
|
118
|
+
* Marks the node if is before `super()`. (exclude `super()` itself)
|
119
|
+
* @param {Super} node - A target node.
|
120
|
+
* @returns {void}
|
121
|
+
*/
|
122
|
+
"Super": function(node) {
|
123
|
+
var item = stack[stack.length - 1];
|
124
|
+
if (isBeforeSuperCalling(item) && isCallee(node) === false) {
|
125
|
+
item.thisOrSuperBeforeSuperCalled.push(node);
|
126
|
+
}
|
127
|
+
},
|
128
|
+
|
129
|
+
/**
|
130
|
+
* Marks `super()` called.
|
131
|
+
* To catch `super(this.a);`, marks on `CallExpression:exit`.
|
132
|
+
* @param {CallExpression} node - A target node.
|
133
|
+
* @returns {void}
|
134
|
+
*/
|
135
|
+
"CallExpression:exit": function(node) {
|
136
|
+
var item = stack[stack.length - 1];
|
137
|
+
if (isBeforeSuperCalling(item) && node.callee.type === "Super") {
|
138
|
+
item.superCalled = true;
|
139
|
+
}
|
140
|
+
}
|
141
|
+
};
|
142
|
+
};
|
143
|
+
|
144
|
+
module.exports.schema = [];
|
@@ -1,33 +1,33 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to restrict what can be thrown as an exception.
|
3
|
-
* @author Dieter Oberkofler
|
4
|
-
* @copyright 2015 Dieter Oberkofler. All rights reserved.
|
5
|
-
*/
|
6
|
-
|
7
|
-
"use strict";
|
8
|
-
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
// Rule Definition
|
11
|
-
//------------------------------------------------------------------------------
|
12
|
-
|
13
|
-
module.exports = function(context) {
|
14
|
-
|
15
|
-
return {
|
16
|
-
|
17
|
-
"ThrowStatement": function(node) {
|
18
|
-
|
19
|
-
if (node.argument.type === "Literal") {
|
20
|
-
context.report(node, "Do not throw a literal.");
|
21
|
-
} else if (node.argument.type === "Identifier") {
|
22
|
-
if (node.argument.name === "undefined") {
|
23
|
-
context.report(node, "Do not throw undefined.");
|
24
|
-
}
|
25
|
-
}
|
26
|
-
|
27
|
-
}
|
28
|
-
|
29
|
-
};
|
30
|
-
|
31
|
-
};
|
32
|
-
|
33
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to restrict what can be thrown as an exception.
|
3
|
+
* @author Dieter Oberkofler
|
4
|
+
* @copyright 2015 Dieter Oberkofler. All rights reserved.
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
// Rule Definition
|
11
|
+
//------------------------------------------------------------------------------
|
12
|
+
|
13
|
+
module.exports = function(context) {
|
14
|
+
|
15
|
+
return {
|
16
|
+
|
17
|
+
"ThrowStatement": function(node) {
|
18
|
+
|
19
|
+
if (node.argument.type === "Literal") {
|
20
|
+
context.report(node, "Do not throw a literal.");
|
21
|
+
} else if (node.argument.type === "Identifier") {
|
22
|
+
if (node.argument.name === "undefined") {
|
23
|
+
context.report(node, "Do not throw undefined.");
|
24
|
+
}
|
25
|
+
}
|
26
|
+
|
27
|
+
}
|
28
|
+
|
29
|
+
};
|
30
|
+
|
31
|
+
};
|
32
|
+
|
33
|
+
module.exports.schema = [];
|
@@ -1,63 +1,74 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Disallow trailing spaces at the end of lines.
|
3
|
-
* @author Nodeca Team <https://github.com/nodeca>
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
//--------------------------------------------------------------------------
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
lines = src.
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
};
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
1
|
+
/**
|
2
|
+
* @fileoverview Disallow trailing spaces at the end of lines.
|
3
|
+
* @author Nodeca Team <https://github.com/nodeca>
|
4
|
+
* @copyright 2015 Greg Cochard
|
5
|
+
*/
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
//------------------------------------------------------------------------------
|
9
|
+
// Rule Definition
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
|
12
|
+
module.exports = function(context) {
|
13
|
+
|
14
|
+
var BLANK_CLASS = "[ \t\u00a0\u2000-\u200b\u2028\u2029\u3000]",
|
15
|
+
SKIP_BLANK = "^" + BLANK_CLASS + "*$",
|
16
|
+
NONBLANK = BLANK_CLASS + "$";
|
17
|
+
|
18
|
+
var options = context.options[0] || {},
|
19
|
+
skipBlankLines = options.skipBlankLines || false;
|
20
|
+
|
21
|
+
|
22
|
+
//--------------------------------------------------------------------------
|
23
|
+
// Public
|
24
|
+
//--------------------------------------------------------------------------
|
25
|
+
|
26
|
+
return {
|
27
|
+
|
28
|
+
"Program": function checkTrailingSpaces(node) {
|
29
|
+
|
30
|
+
// Let's hack. Since Espree does not return whitespace nodes,
|
31
|
+
// fetch the source code and do matching via regexps.
|
32
|
+
|
33
|
+
var src = context.getSource(),
|
34
|
+
re = new RegExp(NONBLANK),
|
35
|
+
skipMatch = new RegExp(SKIP_BLANK),
|
36
|
+
matches, lines = src.split(/\r?\n/), location;
|
37
|
+
|
38
|
+
for (var i = 0, ii = lines.length; i < ii; i++) {
|
39
|
+
|
40
|
+
matches = re.exec(lines[i]);
|
41
|
+
if (matches) {
|
42
|
+
|
43
|
+
// If the line has only whitespace, and skipBlankLines
|
44
|
+
// is true, don't report it
|
45
|
+
if (skipBlankLines && skipMatch.test(lines[i])) {
|
46
|
+
continue;
|
47
|
+
}
|
48
|
+
location = {
|
49
|
+
line: i + 1,
|
50
|
+
column: lines[i].length - matches[0].length + 1
|
51
|
+
};
|
52
|
+
|
53
|
+
// Passing node is a bit dirty, because message data will contain
|
54
|
+
// big text in `source`. But... who cares :) ?
|
55
|
+
// One more kludge will not make worse the bloody wizardry of this plugin.
|
56
|
+
context.report(node, location, "Trailing spaces not allowed.");
|
57
|
+
}
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
};
|
62
|
+
};
|
63
|
+
|
64
|
+
module.exports.schema = [
|
65
|
+
{
|
66
|
+
"type": "object",
|
67
|
+
"properties": {
|
68
|
+
"skipBlankLines": {
|
69
|
+
"type": "boolean"
|
70
|
+
}
|
71
|
+
},
|
72
|
+
"additionalProperties": false
|
73
|
+
}
|
74
|
+
];
|
@@ -1,28 +1,28 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag when initializing to undefined
|
3
|
-
* @author Ilya Volodin
|
4
|
-
*/
|
5
|
-
|
6
|
-
"use strict";
|
7
|
-
|
8
|
-
//------------------------------------------------------------------------------
|
9
|
-
// Rule Definition
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
|
12
|
-
module.exports = function(context) {
|
13
|
-
|
14
|
-
return {
|
15
|
-
|
16
|
-
"VariableDeclarator": function(node) {
|
17
|
-
var name = node.id.name;
|
18
|
-
var init = node.init && node.init.name;
|
19
|
-
|
20
|
-
if (init === "undefined") {
|
21
|
-
context.report(node, "It's not necessary to initialize '{{name}}' to undefined.", { name: name });
|
22
|
-
}
|
23
|
-
}
|
24
|
-
};
|
25
|
-
|
26
|
-
};
|
27
|
-
|
28
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag when initializing to undefined
|
3
|
+
* @author Ilya Volodin
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
//------------------------------------------------------------------------------
|
9
|
+
// Rule Definition
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
|
12
|
+
module.exports = function(context) {
|
13
|
+
|
14
|
+
return {
|
15
|
+
|
16
|
+
"VariableDeclarator": function(node) {
|
17
|
+
var name = node.id.name;
|
18
|
+
var init = node.init && node.init.name;
|
19
|
+
|
20
|
+
if (init === "undefined") {
|
21
|
+
context.report(node, "It's not necessary to initialize '{{name}}' to undefined.", { name: name });
|
22
|
+
}
|
23
|
+
}
|
24
|
+
};
|
25
|
+
|
26
|
+
};
|
27
|
+
|
28
|
+
module.exports.schema = [];
|