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
@@ -1,68 +1,68 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag when the same variable is declared more then once.
|
3
|
-
* @author Ilya Volodin
|
4
|
-
*/
|
5
|
-
|
6
|
-
"use strict";
|
7
|
-
|
8
|
-
//------------------------------------------------------------------------------
|
9
|
-
// Rule Definition
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
|
12
|
-
module.exports = function(context) {
|
13
|
-
|
14
|
-
/**
|
15
|
-
* Find variables in a given scope and flag redeclared ones.
|
16
|
-
* @param {Scope} scope An escope scope object.
|
17
|
-
* @returns {void}
|
18
|
-
* @private
|
19
|
-
*/
|
20
|
-
function findVariablesInScope(scope) {
|
21
|
-
scope.variables.forEach(function(variable) {
|
22
|
-
if (variable.identifiers && variable.identifiers.length > 1) {
|
23
|
-
variable.identifiers.sort(function(a, b) {
|
24
|
-
return a.range[1] - b.range[1];
|
25
|
-
});
|
26
|
-
|
27
|
-
for (var i = 1, l = variable.identifiers.length; i < l; i++) {
|
28
|
-
context.report(variable.identifiers[i], "{{a}} is already defined", {a: variable.name});
|
29
|
-
}
|
30
|
-
}
|
31
|
-
});
|
32
|
-
|
33
|
-
}
|
34
|
-
|
35
|
-
/**
|
36
|
-
* Find variables in a given node's associated scope.
|
37
|
-
* @param {ASTNode} node The node to check.
|
38
|
-
* @returns {void}
|
39
|
-
* @private
|
40
|
-
*/
|
41
|
-
function findVariables(node) {
|
42
|
-
var scope = context.getScope();
|
43
|
-
|
44
|
-
findVariablesInScope(scope);
|
45
|
-
|
46
|
-
// globalReturn means one extra scope to check
|
47
|
-
if (node.type === "Program" && context.ecmaFeatures.globalReturn) {
|
48
|
-
findVariablesInScope(scope.childScopes[0]);
|
49
|
-
}
|
50
|
-
}
|
51
|
-
|
52
|
-
if (context.ecmaFeatures.blockBindings) {
|
53
|
-
return {
|
54
|
-
"Program": findVariables,
|
55
|
-
"BlockStatement": findVariables,
|
56
|
-
"SwitchStatement": findVariables
|
57
|
-
};
|
58
|
-
} else {
|
59
|
-
return {
|
60
|
-
"Program": findVariables,
|
61
|
-
"FunctionDeclaration": findVariables,
|
62
|
-
"FunctionExpression": findVariables,
|
63
|
-
"ArrowFunctionExpression": findVariables
|
64
|
-
};
|
65
|
-
}
|
66
|
-
};
|
67
|
-
|
68
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag when the same variable is declared more then once.
|
3
|
+
* @author Ilya Volodin
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
//------------------------------------------------------------------------------
|
9
|
+
// Rule Definition
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
|
12
|
+
module.exports = function(context) {
|
13
|
+
|
14
|
+
/**
|
15
|
+
* Find variables in a given scope and flag redeclared ones.
|
16
|
+
* @param {Scope} scope An escope scope object.
|
17
|
+
* @returns {void}
|
18
|
+
* @private
|
19
|
+
*/
|
20
|
+
function findVariablesInScope(scope) {
|
21
|
+
scope.variables.forEach(function(variable) {
|
22
|
+
if (variable.identifiers && variable.identifiers.length > 1) {
|
23
|
+
variable.identifiers.sort(function(a, b) {
|
24
|
+
return a.range[1] - b.range[1];
|
25
|
+
});
|
26
|
+
|
27
|
+
for (var i = 1, l = variable.identifiers.length; i < l; i++) {
|
28
|
+
context.report(variable.identifiers[i], "{{a}} is already defined", {a: variable.name});
|
29
|
+
}
|
30
|
+
}
|
31
|
+
});
|
32
|
+
|
33
|
+
}
|
34
|
+
|
35
|
+
/**
|
36
|
+
* Find variables in a given node's associated scope.
|
37
|
+
* @param {ASTNode} node The node to check.
|
38
|
+
* @returns {void}
|
39
|
+
* @private
|
40
|
+
*/
|
41
|
+
function findVariables(node) {
|
42
|
+
var scope = context.getScope();
|
43
|
+
|
44
|
+
findVariablesInScope(scope);
|
45
|
+
|
46
|
+
// globalReturn means one extra scope to check
|
47
|
+
if (node.type === "Program" && (context.ecmaFeatures.globalReturn || context.ecmaFeatures.modules)) {
|
48
|
+
findVariablesInScope(scope.childScopes[0]);
|
49
|
+
}
|
50
|
+
}
|
51
|
+
|
52
|
+
if (context.ecmaFeatures.blockBindings) {
|
53
|
+
return {
|
54
|
+
"Program": findVariables,
|
55
|
+
"BlockStatement": findVariables,
|
56
|
+
"SwitchStatement": findVariables
|
57
|
+
};
|
58
|
+
} else {
|
59
|
+
return {
|
60
|
+
"Program": findVariables,
|
61
|
+
"FunctionDeclaration": findVariables,
|
62
|
+
"FunctionExpression": findVariables,
|
63
|
+
"ArrowFunctionExpression": findVariables
|
64
|
+
};
|
65
|
+
}
|
66
|
+
};
|
67
|
+
|
68
|
+
module.exports.schema = [];
|
@@ -1,35 +1,35 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to count multiple spaces in regular expressions
|
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
|
-
return {
|
15
|
-
|
16
|
-
"Literal": function(node) {
|
17
|
-
var token = context.getFirstToken(node),
|
18
|
-
nodeType = token.type,
|
19
|
-
nodeValue = token.value,
|
20
|
-
multipleSpacesRegex = /( {2,})+?/,
|
21
|
-
regexResults;
|
22
|
-
|
23
|
-
if (nodeType === "RegularExpression") {
|
24
|
-
regexResults = multipleSpacesRegex.exec(nodeValue);
|
25
|
-
|
26
|
-
if (regexResults !== null) {
|
27
|
-
context.report(node, "Spaces are hard to count. Use {" + regexResults[0].length + "}.");
|
28
|
-
}
|
29
|
-
}
|
30
|
-
}
|
31
|
-
};
|
32
|
-
|
33
|
-
};
|
34
|
-
|
35
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to count multiple spaces in regular expressions
|
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
|
+
return {
|
15
|
+
|
16
|
+
"Literal": function(node) {
|
17
|
+
var token = context.getFirstToken(node),
|
18
|
+
nodeType = token.type,
|
19
|
+
nodeValue = token.value,
|
20
|
+
multipleSpacesRegex = /( {2,})+?/,
|
21
|
+
regexResults;
|
22
|
+
|
23
|
+
if (nodeType === "RegularExpression") {
|
24
|
+
regexResults = multipleSpacesRegex.exec(nodeValue);
|
25
|
+
|
26
|
+
if (regexResults !== null) {
|
27
|
+
context.report(node, "Spaces are hard to count. Use {" + regexResults[0].length + "}.");
|
28
|
+
}
|
29
|
+
}
|
30
|
+
}
|
31
|
+
};
|
32
|
+
|
33
|
+
};
|
34
|
+
|
35
|
+
module.exports.schema = [];
|
@@ -1,56 +1,56 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to disallow reserved words being used as keys
|
3
|
-
* @author Emil Bay
|
4
|
-
* @copyright 2014 Emil Bay. All rights reserved.
|
5
|
-
*/
|
6
|
-
|
7
|
-
"use strict";
|
8
|
-
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
// Rule Definition
|
11
|
-
//------------------------------------------------------------------------------
|
12
|
-
|
13
|
-
module.exports = function(context) {
|
14
|
-
|
15
|
-
var MESSAGE = "Reserved word '{{key}}' used as key.";
|
16
|
-
|
17
|
-
var reservedWords = [
|
18
|
-
"abstract",
|
19
|
-
"boolean", "break", "byte",
|
20
|
-
"case", "catch", "char", "class", "const", "continue",
|
21
|
-
"debugger", "default", "delete", "do", "double",
|
22
|
-
"else", "enum", "export", "extends",
|
23
|
-
"final", "finally", "float", "for", "function",
|
24
|
-
"goto",
|
25
|
-
"if", "implements", "import", "in", "instanceof", "int", "interface",
|
26
|
-
"long",
|
27
|
-
"native", "new",
|
28
|
-
"package", "private", "protected", "public",
|
29
|
-
"return",
|
30
|
-
"short", "static", "super", "switch", "synchronized",
|
31
|
-
"this", "throw", "throws", "transient", "try", "typeof",
|
32
|
-
"var", "void", "volatile",
|
33
|
-
"while", "with"
|
34
|
-
];
|
35
|
-
|
36
|
-
return {
|
37
|
-
|
38
|
-
"ObjectExpression": function(node) {
|
39
|
-
node.properties.forEach(function(property) {
|
40
|
-
|
41
|
-
if (property.key.type === "Identifier") {
|
42
|
-
var keyName = property.key.name;
|
43
|
-
|
44
|
-
if (reservedWords.indexOf("" + keyName) !== -1) {
|
45
|
-
context.report(node, MESSAGE, { key: keyName });
|
46
|
-
}
|
47
|
-
}
|
48
|
-
|
49
|
-
});
|
50
|
-
|
51
|
-
}
|
52
|
-
};
|
53
|
-
|
54
|
-
};
|
55
|
-
|
56
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to disallow reserved words being used as keys
|
3
|
+
* @author Emil Bay
|
4
|
+
* @copyright 2014 Emil Bay. All rights reserved.
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
// Rule Definition
|
11
|
+
//------------------------------------------------------------------------------
|
12
|
+
|
13
|
+
module.exports = function(context) {
|
14
|
+
|
15
|
+
var MESSAGE = "Reserved word '{{key}}' used as key.";
|
16
|
+
|
17
|
+
var reservedWords = [
|
18
|
+
"abstract",
|
19
|
+
"boolean", "break", "byte",
|
20
|
+
"case", "catch", "char", "class", "const", "continue",
|
21
|
+
"debugger", "default", "delete", "do", "double",
|
22
|
+
"else", "enum", "export", "extends",
|
23
|
+
"final", "finally", "float", "for", "function",
|
24
|
+
"goto",
|
25
|
+
"if", "implements", "import", "in", "instanceof", "int", "interface",
|
26
|
+
"long",
|
27
|
+
"native", "new",
|
28
|
+
"package", "private", "protected", "public",
|
29
|
+
"return",
|
30
|
+
"short", "static", "super", "switch", "synchronized",
|
31
|
+
"this", "throw", "throws", "transient", "try", "typeof",
|
32
|
+
"var", "void", "volatile",
|
33
|
+
"while", "with"
|
34
|
+
];
|
35
|
+
|
36
|
+
return {
|
37
|
+
|
38
|
+
"ObjectExpression": function(node) {
|
39
|
+
node.properties.forEach(function(property) {
|
40
|
+
|
41
|
+
if (property.key.type === "Identifier") {
|
42
|
+
var keyName = property.key.name;
|
43
|
+
|
44
|
+
if (reservedWords.indexOf("" + keyName) !== -1) {
|
45
|
+
context.report(node, MESSAGE, { key: keyName });
|
46
|
+
}
|
47
|
+
}
|
48
|
+
|
49
|
+
});
|
50
|
+
|
51
|
+
}
|
52
|
+
};
|
53
|
+
|
54
|
+
};
|
55
|
+
|
56
|
+
module.exports.schema = [];
|
@@ -1,85 +1,85 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Restrict usage of specified node modules.
|
3
|
-
* @author Christian Schulz
|
4
|
-
*/
|
5
|
-
"use strict";
|
6
|
-
|
7
|
-
//------------------------------------------------------------------------------
|
8
|
-
// Rule Definition
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
|
11
|
-
module.exports = function (context) {
|
12
|
-
// trim restricted module names
|
13
|
-
var restrictedModules = context.options;
|
14
|
-
|
15
|
-
// if no modules are restricted we don't need to check the CallExpressions
|
16
|
-
if (restrictedModules.length === 0) {
|
17
|
-
return {};
|
18
|
-
}
|
19
|
-
|
20
|
-
/**
|
21
|
-
* Function to check if a node is a string literal.
|
22
|
-
* @param {ASTNode} node The node to check.
|
23
|
-
* @returns {boolean} If the node is a string literal.
|
24
|
-
*/
|
25
|
-
function isString(node) {
|
26
|
-
return node && node.type === "Literal" && typeof node.value === "string";
|
27
|
-
}
|
28
|
-
|
29
|
-
/**
|
30
|
-
* Function to check if a node is a require call.
|
31
|
-
* @param {ASTNode} node The node to check.
|
32
|
-
* @returns {boolean} If the node is a require call.
|
33
|
-
*/
|
34
|
-
function isRequireCall(node) {
|
35
|
-
return node.callee.type === "Identifier" && node.callee.name === "require";
|
36
|
-
}
|
37
|
-
|
38
|
-
/**
|
39
|
-
* Function to check if a node has an argument that is an restricted module and return its name.
|
40
|
-
* @param {ASTNode} node The node to check
|
41
|
-
* @returns {undefined|String} restricted module name or undefined if node argument isn't restricted.
|
42
|
-
*/
|
43
|
-
function getRestrictedModuleName(node) {
|
44
|
-
var moduleName;
|
45
|
-
|
46
|
-
// node has arguments and first argument is string
|
47
|
-
if (node.arguments.length && isString(node.arguments[0])) {
|
48
|
-
var argumentValue = node.arguments[0].value.trim();
|
49
|
-
|
50
|
-
// check if argument value is in restricted modules array
|
51
|
-
if (restrictedModules.indexOf(argumentValue) !== -1) {
|
52
|
-
moduleName = argumentValue;
|
53
|
-
}
|
54
|
-
}
|
55
|
-
|
56
|
-
return moduleName;
|
57
|
-
}
|
58
|
-
|
59
|
-
return {
|
60
|
-
"CallExpression": function (node) {
|
61
|
-
if (isRequireCall(node)) {
|
62
|
-
var restrictedModuleName = getRestrictedModuleName(node);
|
63
|
-
|
64
|
-
if (restrictedModuleName) {
|
65
|
-
context.report(node, "'{{moduleName}}' module is restricted from being used.", {
|
66
|
-
moduleName: restrictedModuleName
|
67
|
-
});
|
68
|
-
}
|
69
|
-
}
|
70
|
-
}
|
71
|
-
};
|
72
|
-
};
|
73
|
-
|
74
|
-
module.exports.schema = {
|
75
|
-
"type": "array",
|
76
|
-
"items": [
|
77
|
-
{
|
78
|
-
"enum": [0, 1, 2]
|
79
|
-
}
|
80
|
-
],
|
81
|
-
"additionalItems": {
|
82
|
-
"type": "string"
|
83
|
-
},
|
84
|
-
"uniqueItems": true
|
85
|
-
};
|
1
|
+
/**
|
2
|
+
* @fileoverview Restrict usage of specified node modules.
|
3
|
+
* @author Christian Schulz
|
4
|
+
*/
|
5
|
+
"use strict";
|
6
|
+
|
7
|
+
//------------------------------------------------------------------------------
|
8
|
+
// Rule Definition
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
|
11
|
+
module.exports = function (context) {
|
12
|
+
// trim restricted module names
|
13
|
+
var restrictedModules = context.options;
|
14
|
+
|
15
|
+
// if no modules are restricted we don't need to check the CallExpressions
|
16
|
+
if (restrictedModules.length === 0) {
|
17
|
+
return {};
|
18
|
+
}
|
19
|
+
|
20
|
+
/**
|
21
|
+
* Function to check if a node is a string literal.
|
22
|
+
* @param {ASTNode} node The node to check.
|
23
|
+
* @returns {boolean} If the node is a string literal.
|
24
|
+
*/
|
25
|
+
function isString(node) {
|
26
|
+
return node && node.type === "Literal" && typeof node.value === "string";
|
27
|
+
}
|
28
|
+
|
29
|
+
/**
|
30
|
+
* Function to check if a node is a require call.
|
31
|
+
* @param {ASTNode} node The node to check.
|
32
|
+
* @returns {boolean} If the node is a require call.
|
33
|
+
*/
|
34
|
+
function isRequireCall(node) {
|
35
|
+
return node.callee.type === "Identifier" && node.callee.name === "require";
|
36
|
+
}
|
37
|
+
|
38
|
+
/**
|
39
|
+
* Function to check if a node has an argument that is an restricted module and return its name.
|
40
|
+
* @param {ASTNode} node The node to check
|
41
|
+
* @returns {undefined|String} restricted module name or undefined if node argument isn't restricted.
|
42
|
+
*/
|
43
|
+
function getRestrictedModuleName(node) {
|
44
|
+
var moduleName;
|
45
|
+
|
46
|
+
// node has arguments and first argument is string
|
47
|
+
if (node.arguments.length && isString(node.arguments[0])) {
|
48
|
+
var argumentValue = node.arguments[0].value.trim();
|
49
|
+
|
50
|
+
// check if argument value is in restricted modules array
|
51
|
+
if (restrictedModules.indexOf(argumentValue) !== -1) {
|
52
|
+
moduleName = argumentValue;
|
53
|
+
}
|
54
|
+
}
|
55
|
+
|
56
|
+
return moduleName;
|
57
|
+
}
|
58
|
+
|
59
|
+
return {
|
60
|
+
"CallExpression": function (node) {
|
61
|
+
if (isRequireCall(node)) {
|
62
|
+
var restrictedModuleName = getRestrictedModuleName(node);
|
63
|
+
|
64
|
+
if (restrictedModuleName) {
|
65
|
+
context.report(node, "'{{moduleName}}' module is restricted from being used.", {
|
66
|
+
moduleName: restrictedModuleName
|
67
|
+
});
|
68
|
+
}
|
69
|
+
}
|
70
|
+
}
|
71
|
+
};
|
72
|
+
};
|
73
|
+
|
74
|
+
module.exports.schema = {
|
75
|
+
"type": "array",
|
76
|
+
"items": [
|
77
|
+
{
|
78
|
+
"enum": [0, 1, 2]
|
79
|
+
}
|
80
|
+
],
|
81
|
+
"additionalItems": {
|
82
|
+
"type": "string"
|
83
|
+
},
|
84
|
+
"uniqueItems": true
|
85
|
+
};
|
@@ -1,24 +1,53 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag when return statement contains assignment
|
3
|
-
* @author Ilya Volodin
|
4
|
-
*/
|
5
|
-
"use strict";
|
6
|
-
|
7
|
-
//------------------------------------------------------------------------------
|
8
|
-
//
|
9
|
-
//------------------------------------------------------------------------------
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
}
|
23
|
-
|
24
|
-
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag when return statement contains assignment
|
3
|
+
* @author Ilya Volodin
|
4
|
+
*/
|
5
|
+
"use strict";
|
6
|
+
|
7
|
+
//------------------------------------------------------------------------------
|
8
|
+
// Helpers
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Checks whether or not a node is an `AssignmentExpression`.
|
13
|
+
* @param {Node|null} node - A node to check.
|
14
|
+
* @returns {boolean} Whether or not the node is an `AssignmentExpression`.
|
15
|
+
*/
|
16
|
+
function isAssignment(node) {
|
17
|
+
return node != null && node.type === "AssignmentExpression";
|
18
|
+
}
|
19
|
+
|
20
|
+
/**
|
21
|
+
* Checks whether or not a node is enclosed in parentheses.
|
22
|
+
* @param {Node|null} node - A node to check.
|
23
|
+
* @param {RuleContext} context - The current context.
|
24
|
+
* @returns {boolean} Whether or not the node is enclosed in parentheses.
|
25
|
+
*/
|
26
|
+
function isEnclosedInParens(node, context) {
|
27
|
+
var prevToken = context.getTokenBefore(node);
|
28
|
+
var nextToken = context.getTokenAfter(node);
|
29
|
+
|
30
|
+
return prevToken.value === "(" && nextToken.value === ")";
|
31
|
+
}
|
32
|
+
|
33
|
+
//------------------------------------------------------------------------------
|
34
|
+
// Rule Definition
|
35
|
+
//------------------------------------------------------------------------------
|
36
|
+
|
37
|
+
module.exports = function(context) {
|
38
|
+
var always = (context.options[0] || "except-parens") !== "except-parens";
|
39
|
+
|
40
|
+
return {
|
41
|
+
"ReturnStatement": function(node) {
|
42
|
+
if (isAssignment(node.argument) && (always || !isEnclosedInParens(node.argument, context))) {
|
43
|
+
context.report(node, "Return statement should not contain assignment.");
|
44
|
+
}
|
45
|
+
}
|
46
|
+
};
|
47
|
+
};
|
48
|
+
|
49
|
+
module.exports.schema = [
|
50
|
+
{
|
51
|
+
"enum": ["except-parens", "always"]
|
52
|
+
}
|
53
|
+
];
|
@@ -1,34 +1,34 @@
|
|
1
|
-
/**
|
2
|
-
* @fileoverview Rule to flag when using javascript: urls
|
3
|
-
* @author Ilya Volodin
|
4
|
-
*/
|
5
|
-
/*jshint scripturl: true */
|
6
|
-
/*eslint no-script-url: 0*/
|
7
|
-
|
8
|
-
"use strict";
|
9
|
-
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
// Rule Definition
|
12
|
-
//------------------------------------------------------------------------------
|
13
|
-
|
14
|
-
module.exports = function(context) {
|
15
|
-
|
16
|
-
return {
|
17
|
-
|
18
|
-
"Literal": function(node) {
|
19
|
-
|
20
|
-
var value;
|
21
|
-
|
22
|
-
if (node.value && typeof node.value === "string") {
|
23
|
-
value = node.value.toLowerCase();
|
24
|
-
|
25
|
-
if (value.indexOf("javascript:") === 0) {
|
26
|
-
context.report(node, "Script URL is a form of eval.");
|
27
|
-
}
|
28
|
-
}
|
29
|
-
}
|
30
|
-
};
|
31
|
-
|
32
|
-
};
|
33
|
-
|
34
|
-
module.exports.schema = [];
|
1
|
+
/**
|
2
|
+
* @fileoverview Rule to flag when using javascript: urls
|
3
|
+
* @author Ilya Volodin
|
4
|
+
*/
|
5
|
+
/*jshint scripturl: true */
|
6
|
+
/*eslint no-script-url: 0*/
|
7
|
+
|
8
|
+
"use strict";
|
9
|
+
|
10
|
+
//------------------------------------------------------------------------------
|
11
|
+
// Rule Definition
|
12
|
+
//------------------------------------------------------------------------------
|
13
|
+
|
14
|
+
module.exports = function(context) {
|
15
|
+
|
16
|
+
return {
|
17
|
+
|
18
|
+
"Literal": function(node) {
|
19
|
+
|
20
|
+
var value;
|
21
|
+
|
22
|
+
if (node.value && typeof node.value === "string") {
|
23
|
+
value = node.value.toLowerCase();
|
24
|
+
|
25
|
+
if (value.indexOf("javascript:") === 0) {
|
26
|
+
context.report(node, "Script URL is a form of eval.");
|
27
|
+
}
|
28
|
+
}
|
29
|
+
}
|
30
|
+
};
|
31
|
+
|
32
|
+
};
|
33
|
+
|
34
|
+
module.exports.schema = [];
|