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.
Files changed (201) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +111 -95
  3. package/bin/eslint.js +41 -41
  4. package/conf/environments.js +87 -81
  5. package/conf/eslint.json +186 -179
  6. package/lib/api.js +13 -12
  7. package/lib/cli-engine.js +441 -451
  8. package/lib/cli.js +196 -196
  9. package/lib/config-initializer.js +145 -145
  10. package/lib/config-validator.js +110 -110
  11. package/lib/config.js +428 -416
  12. package/lib/eslint.js +1072 -1073
  13. package/lib/file-finder.js +167 -167
  14. package/lib/formatters/checkstyle.js +68 -68
  15. package/lib/formatters/compact.js +53 -53
  16. package/lib/formatters/jslint-xml.js +40 -40
  17. package/lib/formatters/junit.js +63 -63
  18. package/lib/formatters/stylish.js +90 -90
  19. package/lib/formatters/tap.js +86 -86
  20. package/lib/ignored-paths.js +137 -137
  21. package/lib/load-rules.js +39 -39
  22. package/lib/options.js +132 -126
  23. package/lib/rule-context.js +107 -107
  24. package/lib/rules/accessor-pairs.js +65 -65
  25. package/lib/rules/array-bracket-spacing.js +180 -0
  26. package/lib/rules/block-scoped-var.js +339 -320
  27. package/lib/rules/brace-style.js +228 -228
  28. package/lib/rules/camelcase.js +111 -111
  29. package/lib/rules/comma-dangle.js +67 -64
  30. package/lib/rules/comma-spacing.js +191 -191
  31. package/lib/rules/comma-style.js +195 -195
  32. package/lib/rules/complexity.js +94 -94
  33. package/lib/rules/computed-property-spacing.js +144 -0
  34. package/lib/rules/consistent-return.js +75 -75
  35. package/lib/rules/consistent-this.js +119 -119
  36. package/lib/rules/constructor-super.js +108 -0
  37. package/lib/rules/curly.js +109 -109
  38. package/lib/rules/default-case.js +66 -66
  39. package/lib/rules/dot-location.js +63 -63
  40. package/lib/rules/dot-notation.js +119 -119
  41. package/lib/rules/eol-last.js +38 -38
  42. package/lib/rules/eqeqeq.js +96 -96
  43. package/lib/rules/func-names.js +45 -45
  44. package/lib/rules/func-style.js +49 -49
  45. package/lib/rules/generator-star-spacing.js +104 -87
  46. package/lib/rules/generator-star.js +76 -76
  47. package/lib/rules/global-strict.js +49 -49
  48. package/lib/rules/guard-for-in.js +32 -32
  49. package/lib/rules/handle-callback-err.js +81 -124
  50. package/lib/rules/indent.js +486 -486
  51. package/lib/rules/key-spacing.js +325 -325
  52. package/lib/rules/linebreak-style.js +44 -44
  53. package/lib/rules/lines-around-comment.js +228 -160
  54. package/lib/rules/max-depth.js +89 -89
  55. package/lib/rules/max-len.js +76 -76
  56. package/lib/rules/max-nested-callbacks.js +73 -73
  57. package/lib/rules/max-params.js +45 -45
  58. package/lib/rules/max-statements.js +61 -61
  59. package/lib/rules/new-cap.js +224 -224
  60. package/lib/rules/new-parens.js +29 -29
  61. package/lib/rules/newline-after-var.js +127 -127
  62. package/lib/rules/no-alert.js +153 -153
  63. package/lib/rules/no-array-constructor.js +31 -31
  64. package/lib/rules/no-bitwise.js +57 -57
  65. package/lib/rules/no-caller.js +29 -29
  66. package/lib/rules/no-catch-shadow.js +52 -52
  67. package/lib/rules/no-comma-dangle.js +45 -45
  68. package/lib/rules/no-cond-assign.js +123 -123
  69. package/lib/rules/no-console.js +27 -27
  70. package/lib/rules/no-constant-condition.js +73 -73
  71. package/lib/rules/no-continue.js +23 -23
  72. package/lib/rules/no-control-regex.js +58 -58
  73. package/lib/rules/no-debugger.js +22 -22
  74. package/lib/rules/no-delete-var.js +25 -25
  75. package/lib/rules/no-div-regex.js +27 -27
  76. package/lib/rules/no-dupe-args.js +89 -85
  77. package/lib/rules/no-dupe-keys.js +43 -43
  78. package/lib/rules/no-duplicate-case.js +67 -67
  79. package/lib/rules/no-else-return.js +125 -125
  80. package/lib/rules/no-empty-character-class.js +43 -43
  81. package/lib/rules/no-empty-class.js +45 -45
  82. package/lib/rules/no-empty-label.js +27 -27
  83. package/lib/rules/no-empty.js +49 -49
  84. package/lib/rules/no-eq-null.js +29 -29
  85. package/lib/rules/no-eval.js +26 -26
  86. package/lib/rules/no-ex-assign.js +42 -42
  87. package/lib/rules/no-extend-native.js +103 -103
  88. package/lib/rules/no-extra-bind.js +81 -81
  89. package/lib/rules/no-extra-boolean-cast.js +71 -71
  90. package/lib/rules/no-extra-parens.js +368 -355
  91. package/lib/rules/no-extra-semi.js +70 -23
  92. package/lib/rules/no-extra-strict.js +86 -86
  93. package/lib/rules/no-fallthrough.js +97 -97
  94. package/lib/rules/no-floating-decimal.js +30 -30
  95. package/lib/rules/no-func-assign.js +83 -83
  96. package/lib/rules/no-implied-eval.js +76 -76
  97. package/lib/rules/no-inline-comments.js +49 -49
  98. package/lib/rules/no-inner-declarations.js +78 -78
  99. package/lib/rules/no-invalid-regexp.js +53 -53
  100. package/lib/rules/no-irregular-whitespace.js +135 -135
  101. package/lib/rules/no-iterator.js +28 -28
  102. package/lib/rules/no-label-var.js +64 -64
  103. package/lib/rules/no-labels.js +44 -44
  104. package/lib/rules/no-lone-blocks.js +106 -27
  105. package/lib/rules/no-lonely-if.js +30 -30
  106. package/lib/rules/no-loop-func.js +58 -58
  107. package/lib/rules/no-mixed-requires.js +165 -165
  108. package/lib/rules/no-mixed-spaces-and-tabs.js +74 -74
  109. package/lib/rules/no-multi-spaces.js +119 -119
  110. package/lib/rules/no-multi-str.js +43 -43
  111. package/lib/rules/no-multiple-empty-lines.js +98 -98
  112. package/lib/rules/no-native-reassign.js +62 -62
  113. package/lib/rules/no-negated-in-lhs.js +25 -25
  114. package/lib/rules/no-nested-ternary.js +24 -24
  115. package/lib/rules/no-new-func.js +25 -25
  116. package/lib/rules/no-new-object.js +25 -25
  117. package/lib/rules/no-new-require.js +25 -25
  118. package/lib/rules/no-new-wrappers.js +26 -26
  119. package/lib/rules/no-new.js +27 -27
  120. package/lib/rules/no-obj-calls.js +28 -28
  121. package/lib/rules/no-octal-escape.js +39 -39
  122. package/lib/rules/no-octal.js +25 -25
  123. package/lib/rules/no-param-reassign.js +87 -87
  124. package/lib/rules/no-path-concat.js +39 -39
  125. package/lib/rules/no-plusplus.js +24 -24
  126. package/lib/rules/no-process-env.js +30 -30
  127. package/lib/rules/no-process-exit.js +33 -33
  128. package/lib/rules/no-proto.js +28 -28
  129. package/lib/rules/no-redeclare.js +68 -68
  130. package/lib/rules/no-regex-spaces.js +35 -35
  131. package/lib/rules/no-reserved-keys.js +56 -56
  132. package/lib/rules/no-restricted-modules.js +85 -85
  133. package/lib/rules/no-return-assign.js +53 -24
  134. package/lib/rules/no-script-url.js +34 -34
  135. package/lib/rules/no-self-compare.js +29 -29
  136. package/lib/rules/no-sequences.js +94 -94
  137. package/lib/rules/no-shadow-restricted-names.js +51 -51
  138. package/lib/rules/no-shadow.js +181 -136
  139. package/lib/rules/no-space-before-semi.js +98 -98
  140. package/lib/rules/no-spaced-func.js +37 -37
  141. package/lib/rules/no-sparse-arrays.js +33 -33
  142. package/lib/rules/no-sync.js +30 -30
  143. package/lib/rules/no-ternary.js +24 -24
  144. package/lib/rules/no-this-before-super.js +144 -0
  145. package/lib/rules/no-throw-literal.js +33 -33
  146. package/lib/rules/no-trailing-spaces.js +74 -63
  147. package/lib/rules/no-undef-init.js +28 -28
  148. package/lib/rules/no-undef.js +92 -92
  149. package/lib/rules/no-undefined.js +27 -27
  150. package/lib/rules/no-underscore-dangle.js +73 -73
  151. package/lib/rules/no-unexpected-multiline.js +58 -0
  152. package/lib/rules/no-unneeded-ternary.js +48 -48
  153. package/lib/rules/no-unreachable.js +98 -98
  154. package/lib/rules/no-unused-expressions.js +76 -76
  155. package/lib/rules/no-unused-vars.js +252 -250
  156. package/lib/rules/no-use-before-define.js +105 -105
  157. package/lib/rules/no-var.js +26 -26
  158. package/lib/rules/no-void.js +28 -28
  159. package/lib/rules/no-warning-comments.js +102 -102
  160. package/lib/rules/no-with.js +22 -22
  161. package/lib/rules/no-wrap-func.js +65 -65
  162. package/lib/rules/object-curly-spacing.js +231 -206
  163. package/lib/rules/object-shorthand.js +74 -73
  164. package/lib/rules/one-var.js +311 -304
  165. package/lib/rules/operator-assignment.js +118 -118
  166. package/lib/rules/operator-linebreak.js +114 -114
  167. package/lib/rules/padded-blocks.js +98 -98
  168. package/lib/rules/prefer-const.js +91 -0
  169. package/lib/rules/quote-props.js +72 -72
  170. package/lib/rules/quotes.js +92 -92
  171. package/lib/rules/radix.js +41 -41
  172. package/lib/rules/semi-spacing.js +167 -167
  173. package/lib/rules/semi.js +136 -136
  174. package/lib/rules/sort-vars.js +49 -49
  175. package/lib/rules/space-after-function-name.js +49 -49
  176. package/lib/rules/space-after-keywords.js +82 -82
  177. package/lib/rules/space-before-blocks.js +91 -91
  178. package/lib/rules/space-before-function-paren.js +139 -139
  179. package/lib/rules/space-before-function-parentheses.js +139 -139
  180. package/lib/rules/space-in-brackets.js +305 -305
  181. package/lib/rules/space-in-parens.js +281 -281
  182. package/lib/rules/space-infix-ops.js +106 -106
  183. package/lib/rules/space-return-throw-case.js +38 -38
  184. package/lib/rules/space-unary-ops.js +124 -133
  185. package/lib/rules/spaced-comment.js +143 -0
  186. package/lib/rules/spaced-line-comment.js +89 -89
  187. package/lib/rules/strict.js +242 -242
  188. package/lib/rules/use-isnan.js +26 -26
  189. package/lib/rules/valid-jsdoc.js +215 -215
  190. package/lib/rules/valid-typeof.js +42 -42
  191. package/lib/rules/vars-on-top.js +115 -115
  192. package/lib/rules/wrap-iife.js +48 -48
  193. package/lib/rules/wrap-regex.js +38 -38
  194. package/lib/rules/yoda.js +242 -225
  195. package/lib/rules.js +88 -88
  196. package/lib/timing.js +109 -109
  197. package/lib/token-store.js +201 -201
  198. package/lib/util/traverse.js +105 -105
  199. package/lib/util.js +125 -85
  200. package/package.json +6 -6
  201. 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
- // Rule Definition
9
- //------------------------------------------------------------------------------
10
-
11
- module.exports = function(context) {
12
-
13
- return {
14
-
15
- "ReturnStatement": function(node) {
16
- if (node.argument && node.argument.type === "AssignmentExpression") {
17
- context.report(node, "Return statement should not contain assignment.");
18
- }
19
- }
20
- };
21
-
22
- };
23
-
24
- module.exports.schema = [];
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 = [];