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,107 +1,107 @@
1
- /**
2
- * @fileoverview RuleContext utility for rules
3
- * @author Nicholas C. Zakas
4
- */
5
- "use strict";
6
-
7
- //------------------------------------------------------------------------------
8
- // Constants
9
- //------------------------------------------------------------------------------
10
-
11
- var PASSTHROUGHS = [
12
- "getAllComments",
13
- "getAncestors",
14
- "getComments",
15
- "getFilename",
16
- "getFirstToken",
17
- "getFirstTokens",
18
- "getJSDocComment",
19
- "getLastToken",
20
- "getLastTokens",
21
- "getNodeByRangeIndex",
22
- "getScope",
23
- "getSource",
24
- "getSourceLines",
25
- "getTokenAfter",
26
- "getTokenBefore",
27
- "getTokenByRangeStart",
28
- "getTokens",
29
- "getTokensAfter",
30
- "getTokensBefore",
31
- "getTokensBetween",
32
- "markVariableAsUsed",
33
- "isMarkedAsUsed"
34
- ];
35
-
36
- //------------------------------------------------------------------------------
37
- // Rule Definition
38
- //------------------------------------------------------------------------------
39
-
40
- /**
41
- * Acts as an abstraction layer between rules and the main eslint object.
42
- * @constructor
43
- * @param {string} ruleId The ID of the rule using this object.
44
- * @param {eslint} eslint The eslint object.
45
- * @param {number} severity The configured severity level of the rule.
46
- * @param {array} options The configuration information to be added to the rule.
47
- * @param {object} settings The configuration settings passed from the config file.
48
- * @param {object} ecmaFeatures The ecmaFeatures settings passed from the config file.
49
- */
50
- function RuleContext(ruleId, eslint, severity, options, settings, ecmaFeatures) {
51
-
52
- /**
53
- * The read-only ID of the rule.
54
- */
55
- Object.defineProperty(this, "id", {
56
- value: ruleId
57
- });
58
-
59
- /**
60
- * The read-only options of the rule
61
- */
62
- Object.defineProperty(this, "options", {
63
- value: options
64
- });
65
-
66
- /**
67
- * The read-only settings shared between all rules
68
- */
69
- Object.defineProperty(this, "settings", {
70
- value: settings
71
- });
72
-
73
- /**
74
- * The read-only ecmaFeatures shared across all rules
75
- */
76
- Object.defineProperty(this, "ecmaFeatures", {
77
- value: Object.create(ecmaFeatures)
78
- });
79
- Object.freeze(this.ecmaFeatures);
80
-
81
- // copy over passthrough methods
82
- PASSTHROUGHS.forEach(function(name) {
83
- this[name] = function() {
84
- return eslint[name].apply(eslint, arguments);
85
- };
86
- }, this);
87
-
88
- /**
89
- * Passthrough to eslint.report() that automatically assigns the rule ID and severity.
90
- * @param {ASTNode} node The AST node related to the message.
91
- * @param {Object=} location The location of the error.
92
- * @param {string} message The message to display to the user.
93
- * @param {Object} opts Optional template data which produces a formatted message
94
- * with symbols being replaced by this object's values.
95
- * @returns {void}
96
- */
97
- this.report = function(node, location, message, opts) {
98
- eslint.report(ruleId, severity, node, location, message, opts);
99
- };
100
-
101
- }
102
-
103
- RuleContext.prototype = {
104
- constructor: RuleContext
105
- };
106
-
107
- module.exports = RuleContext;
1
+ /**
2
+ * @fileoverview RuleContext utility for rules
3
+ * @author Nicholas C. Zakas
4
+ */
5
+ "use strict";
6
+
7
+ //------------------------------------------------------------------------------
8
+ // Constants
9
+ //------------------------------------------------------------------------------
10
+
11
+ var PASSTHROUGHS = [
12
+ "getAllComments",
13
+ "getAncestors",
14
+ "getComments",
15
+ "getFilename",
16
+ "getFirstToken",
17
+ "getFirstTokens",
18
+ "getJSDocComment",
19
+ "getLastToken",
20
+ "getLastTokens",
21
+ "getNodeByRangeIndex",
22
+ "getScope",
23
+ "getSource",
24
+ "getSourceLines",
25
+ "getTokenAfter",
26
+ "getTokenBefore",
27
+ "getTokenByRangeStart",
28
+ "getTokens",
29
+ "getTokensAfter",
30
+ "getTokensBefore",
31
+ "getTokensBetween",
32
+ "markVariableAsUsed",
33
+ "isMarkedAsUsed"
34
+ ];
35
+
36
+ //------------------------------------------------------------------------------
37
+ // Rule Definition
38
+ //------------------------------------------------------------------------------
39
+
40
+ /**
41
+ * Acts as an abstraction layer between rules and the main eslint object.
42
+ * @constructor
43
+ * @param {string} ruleId The ID of the rule using this object.
44
+ * @param {eslint} eslint The eslint object.
45
+ * @param {number} severity The configured severity level of the rule.
46
+ * @param {array} options The configuration information to be added to the rule.
47
+ * @param {object} settings The configuration settings passed from the config file.
48
+ * @param {object} ecmaFeatures The ecmaFeatures settings passed from the config file.
49
+ */
50
+ function RuleContext(ruleId, eslint, severity, options, settings, ecmaFeatures) {
51
+
52
+ /**
53
+ * The read-only ID of the rule.
54
+ */
55
+ Object.defineProperty(this, "id", {
56
+ value: ruleId
57
+ });
58
+
59
+ /**
60
+ * The read-only options of the rule
61
+ */
62
+ Object.defineProperty(this, "options", {
63
+ value: options
64
+ });
65
+
66
+ /**
67
+ * The read-only settings shared between all rules
68
+ */
69
+ Object.defineProperty(this, "settings", {
70
+ value: settings
71
+ });
72
+
73
+ /**
74
+ * The read-only ecmaFeatures shared across all rules
75
+ */
76
+ Object.defineProperty(this, "ecmaFeatures", {
77
+ value: Object.create(ecmaFeatures)
78
+ });
79
+ Object.freeze(this.ecmaFeatures);
80
+
81
+ // copy over passthrough methods
82
+ PASSTHROUGHS.forEach(function(name) {
83
+ this[name] = function() {
84
+ return eslint[name].apply(eslint, arguments);
85
+ };
86
+ }, this);
87
+
88
+ /**
89
+ * Passthrough to eslint.report() that automatically assigns the rule ID and severity.
90
+ * @param {ASTNode} node The AST node related to the message.
91
+ * @param {Object=} location The location of the error.
92
+ * @param {string} message The message to display to the user.
93
+ * @param {Object} opts Optional template data which produces a formatted message
94
+ * with symbols being replaced by this object's values.
95
+ * @returns {void}
96
+ */
97
+ this.report = function(node, location, message, opts) {
98
+ eslint.report(ruleId, severity, node, location, message, opts);
99
+ };
100
+
101
+ }
102
+
103
+ RuleContext.prototype = {
104
+ constructor: RuleContext
105
+ };
106
+
107
+ module.exports = RuleContext;
@@ -1,65 +1,65 @@
1
- /**
2
- * @fileoverview Rule to flag wrapping non-iife in parens
3
- * @author Gyandeep Singh
4
- * @copyright 2015 Gyandeep Singh. All rights reserved.
5
- */
6
-
7
- "use strict";
8
-
9
- //------------------------------------------------------------------------------
10
- // Rule Definition
11
- //------------------------------------------------------------------------------
12
-
13
- module.exports = function(context) {
14
- var config = context.options[0] || {};
15
- var checkGetWithoutSet = config.getWithoutSet === true;
16
- var checkSetWithoutGet = config.setWithoutGet !== false;
17
-
18
- /**
19
- * Checks a object expression to see if it has setter and getter both present or none.
20
- * @param {ASTNode} node The node to check.
21
- * @returns {void}
22
- * @private
23
- */
24
- function checkLonelySetGet(node) {
25
- var isSetPresent = false;
26
- var isGetPresent = false;
27
- var propLength = node.properties.length;
28
-
29
- for (var i = 0; i < propLength; i++) {
30
- var propToCheck = node.properties[i].kind === "init" ? node.properties[i].key.name : node.properties[i].kind;
31
-
32
- switch (propToCheck) {
33
- case "set":
34
- isSetPresent = true;
35
- break;
36
-
37
- case "get":
38
- isGetPresent = true;
39
- break;
40
-
41
- default:
42
- // Do nothing
43
- }
44
-
45
- if (isSetPresent && isGetPresent) {
46
- break;
47
- }
48
- }
49
-
50
- if (checkSetWithoutGet && isSetPresent && !isGetPresent) {
51
- context.report(node, "Getter is not present");
52
- } else if (checkGetWithoutSet && isGetPresent && !isSetPresent) {
53
- context.report(node, "Setter is not present");
54
- }
55
- }
56
-
57
- return {
58
- "ObjectExpression": function (node) {
59
- if (checkSetWithoutGet || checkGetWithoutSet) {
60
- checkLonelySetGet(node);
61
- }
62
- }
63
- };
64
-
65
- };
1
+ /**
2
+ * @fileoverview Rule to flag wrapping non-iife in parens
3
+ * @author Gyandeep Singh
4
+ * @copyright 2015 Gyandeep Singh. All rights reserved.
5
+ */
6
+
7
+ "use strict";
8
+
9
+ //------------------------------------------------------------------------------
10
+ // Rule Definition
11
+ //------------------------------------------------------------------------------
12
+
13
+ module.exports = function(context) {
14
+ var config = context.options[0] || {};
15
+ var checkGetWithoutSet = config.getWithoutSet === true;
16
+ var checkSetWithoutGet = config.setWithoutGet !== false;
17
+
18
+ /**
19
+ * Checks a object expression to see if it has setter and getter both present or none.
20
+ * @param {ASTNode} node The node to check.
21
+ * @returns {void}
22
+ * @private
23
+ */
24
+ function checkLonelySetGet(node) {
25
+ var isSetPresent = false;
26
+ var isGetPresent = false;
27
+ var propLength = node.properties.length;
28
+
29
+ for (var i = 0; i < propLength; i++) {
30
+ var propToCheck = node.properties[i].kind === "init" ? node.properties[i].key.name : node.properties[i].kind;
31
+
32
+ switch (propToCheck) {
33
+ case "set":
34
+ isSetPresent = true;
35
+ break;
36
+
37
+ case "get":
38
+ isGetPresent = true;
39
+ break;
40
+
41
+ default:
42
+ // Do nothing
43
+ }
44
+
45
+ if (isSetPresent && isGetPresent) {
46
+ break;
47
+ }
48
+ }
49
+
50
+ if (checkSetWithoutGet && isSetPresent && !isGetPresent) {
51
+ context.report(node, "Getter is not present");
52
+ } else if (checkGetWithoutSet && isGetPresent && !isSetPresent) {
53
+ context.report(node, "Setter is not present");
54
+ }
55
+ }
56
+
57
+ return {
58
+ "ObjectExpression": function (node) {
59
+ if (checkSetWithoutGet || checkGetWithoutSet) {
60
+ checkLonelySetGet(node);
61
+ }
62
+ }
63
+ };
64
+
65
+ };
@@ -0,0 +1,180 @@
1
+ /**
2
+ * @fileoverview Disallows or enforces spaces inside of array brackets.
3
+ * @author Jamund Ferguson
4
+ * @copyright 2015 Jamund Ferguson. All rights reserved.
5
+ * @copyright 2014 Brandyn Bennett. All rights reserved.
6
+ * @copyright 2014 Michael Ficarra. No rights reserved.
7
+ * @copyright 2014 Vignesh Anand. All rights reserved.
8
+ */
9
+ "use strict";
10
+
11
+ //------------------------------------------------------------------------------
12
+ // Rule Definition
13
+ //------------------------------------------------------------------------------
14
+
15
+ module.exports = function(context) {
16
+ var spaced = context.options[0] === "always";
17
+
18
+ /**
19
+ * Determines whether an option is set, relative to the spacing option.
20
+ * If spaced is "always", then check whether option is set to false.
21
+ * If spaced is "never", then check whether option is set to true.
22
+ * @param {Object} option - The option to exclude.
23
+ * @returns {boolean} Whether or not the property is excluded.
24
+ */
25
+ function isOptionSet(option) {
26
+ return context.options[1] != null ? context.options[1][option] === !spaced : false;
27
+ }
28
+
29
+ var options = {
30
+ spaced: spaced,
31
+ singleElementException: isOptionSet("singleValue"),
32
+ objectsInArraysException: isOptionSet("objectsInArrays"),
33
+ arraysInArraysException: isOptionSet("arraysInArrays")
34
+ };
35
+
36
+ //--------------------------------------------------------------------------
37
+ // Helpers
38
+ //--------------------------------------------------------------------------
39
+
40
+ /**
41
+ * Determines whether two adjacent tokens are have whitespace between them.
42
+ * @param {Object} left - The left token object.
43
+ * @param {Object} right - The right token object.
44
+ * @returns {boolean} Whether or not there is space between the tokens.
45
+ */
46
+ function isSpaced(left, right) {
47
+ return left.range[1] < right.range[0];
48
+ }
49
+
50
+ /**
51
+ * Determines whether two adjacent tokens are on the same line.
52
+ * @param {Object} left - The left token object.
53
+ * @param {Object} right - The right token object.
54
+ * @returns {boolean} Whether or not the tokens are on the same line.
55
+ */
56
+ function isSameLine(left, right) {
57
+ return left.loc.start.line === right.loc.start.line;
58
+ }
59
+
60
+ /**
61
+ * Reports that there shouldn't be a space after the first token
62
+ * @param {ASTNode} node - The node to report in the event of an error.
63
+ * @param {Token} token - The token to use for the report.
64
+ * @returns {void}
65
+ */
66
+ function reportNoBeginningSpace(node, token) {
67
+ context.report(node, token.loc.start,
68
+ "There should be no space after '" + token.value + "'");
69
+ }
70
+
71
+ /**
72
+ * Reports that there shouldn't be a space before the last token
73
+ * @param {ASTNode} node - The node to report in the event of an error.
74
+ * @param {Token} token - The token to use for the report.
75
+ * @returns {void}
76
+ */
77
+ function reportNoEndingSpace(node, token) {
78
+ context.report(node, token.loc.start,
79
+ "There should be no space before '" + token.value + "'");
80
+ }
81
+
82
+ /**
83
+ * Reports that there should be a space after the first token
84
+ * @param {ASTNode} node - The node to report in the event of an error.
85
+ * @param {Token} token - The token to use for the report.
86
+ * @returns {void}
87
+ */
88
+ function reportRequiredBeginningSpace(node, token) {
89
+ context.report(node, token.loc.start,
90
+ "A space is required after '" + token.value + "'");
91
+ }
92
+
93
+ /**
94
+ * Reports that there should be a space before the last token
95
+ * @param {ASTNode} node - The node to report in the event of an error.
96
+ * @param {Token} token - The token to use for the report.
97
+ * @returns {void}
98
+ */
99
+ function reportRequiredEndingSpace(node, token) {
100
+ context.report(node, token.loc.start,
101
+ "A space is required before '" + token.value + "'");
102
+ }
103
+
104
+ /**
105
+ * Validates the spacing around array brackets
106
+ * @param {ASTNode} node - The node we're checking for spacing
107
+ * @returns {void}
108
+ */
109
+ function validateArraySpacing(node) {
110
+ if (node.elements.length === 0) {
111
+ return;
112
+ }
113
+
114
+ var first = context.getFirstToken(node),
115
+ second = context.getFirstToken(node, 1),
116
+ penultimate = context.getLastToken(node, 1),
117
+ last = context.getLastToken(node);
118
+
119
+ var openingBracketMustBeSpaced =
120
+ options.objectsInArraysException && second.value === "{" ||
121
+ options.arraysInArraysException && second.value === "[" ||
122
+ options.singleElementException && node.elements.length === 1
123
+ ? !options.spaced : options.spaced;
124
+
125
+ var closingBracketMustBeSpaced =
126
+ options.objectsInArraysException && penultimate.value === "}" ||
127
+ options.arraysInArraysException && penultimate.value === "]" ||
128
+ options.singleElementException && node.elements.length === 1
129
+ ? !options.spaced : options.spaced;
130
+
131
+ if (isSameLine(first, second)) {
132
+ if (openingBracketMustBeSpaced && !isSpaced(first, second)) {
133
+ reportRequiredBeginningSpace(node, first);
134
+ }
135
+ if (!openingBracketMustBeSpaced && isSpaced(first, second)) {
136
+ reportNoBeginningSpace(node, first);
137
+ }
138
+ }
139
+
140
+ if (isSameLine(penultimate, last)) {
141
+ if (closingBracketMustBeSpaced && !isSpaced(penultimate, last)) {
142
+ reportRequiredEndingSpace(node, last);
143
+ }
144
+ if (!closingBracketMustBeSpaced && isSpaced(penultimate, last)) {
145
+ reportNoEndingSpace(node, last);
146
+ }
147
+ }
148
+ }
149
+
150
+ //--------------------------------------------------------------------------
151
+ // Public
152
+ //--------------------------------------------------------------------------
153
+
154
+ return {
155
+ ArrayPattern: validateArraySpacing,
156
+ ArrayExpression: validateArraySpacing
157
+ };
158
+
159
+ };
160
+
161
+ module.exports.schema = [
162
+ {
163
+ "enum": ["always", "never"]
164
+ },
165
+ {
166
+ "type": "object",
167
+ "properties": {
168
+ "singleValue": {
169
+ "type": "boolean"
170
+ },
171
+ "objectsInArrays": {
172
+ "type": "boolean"
173
+ },
174
+ "arraysInArrays": {
175
+ "type": "boolean"
176
+ }
177
+ },
178
+ "additionalProperties": false
179
+ }
180
+ ];