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
package/LICENSE CHANGED
@@ -1,20 +1,20 @@
1
- ESLint
2
- Copyright (c) 2013 Nicholas C. Zakas. All rights reserved.
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy
5
- of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction, including without limitation the rights
7
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
- copies of the Software, and to permit persons to whom the Software is
9
- furnished to do so, subject to the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be included in
12
- all copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20
- THE SOFTWARE.
1
+ ESLint
2
+ Copyright (c) 2013 Nicholas C. Zakas. All rights reserved.
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in
12
+ all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20
+ THE SOFTWARE.
package/README.md CHANGED
@@ -1,95 +1,111 @@
1
- [![NPM version][npm-image]][npm-url]
2
- [![build status][travis-image]][travis-url]
3
- [![Test coverage][coveralls-image]][coveralls-url]
4
- [![Downloads][downloads-image]][downloads-url]
5
- [![Bountysource](https://www.bountysource.com/badge/tracker?tracker_id=282608)](https://www.bountysource.com/trackers/282608-eslint?utm_source=282608&utm_medium=shield&utm_campaign=TRACKER_BADGE)
6
- [![Join the chat at https://gitter.im/eslint/eslint](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/eslint/eslint?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
7
-
8
- # ESLint
9
-
10
- [Website](http://eslint.org) | [Configuring](http://eslint.org/docs/user-guide/configuring) | [Rules](http://eslint.org/docs/rules/) | [Contributing](http://eslint.org/docs/developer-guide/contributing) | [Twitter](https://twitter.com/geteslint) | [Mailing List](https://groups.google.com/group/eslint)
11
-
12
- ESLint is a tool for identifying and reporting on patterns found in ECMAScript/JavaScript code. In many ways, it is similar to JSLint and JSHint with a few exceptions:
13
-
14
- * ESLint uses [Espree](https://github.com/eslint/espree) for JavaScript parsing.
15
- * ESLint uses an AST to evaluate patterns in code.
16
- * ESLint is completely pluggable, every single rule is a plugin and you can add more at runtime.
17
-
18
- ## Installation
19
-
20
- You can install ESLint using npm:
21
-
22
- npm install -g eslint
23
-
24
- ## Usage
25
-
26
- If it's your first time using ESLint, you should set up a config file using `--init`:
27
-
28
- eslint --init
29
-
30
- After that, you can run ESLint on any JavaScript file:
31
-
32
- eslint test.js test2.js
33
-
34
- ## Frequently Asked Questions
35
-
36
- ### Why don't you like JSHint???
37
-
38
- I do like JSHint. And I like Anton and Rick. Neither of those were deciding factors in creating this tool. The fact is that I've had a dire need for a JavaScript tool with pluggable linting rules. I had hoped JSHint would be able to do this, however after chatting with Anton, I found that the planned plugin infrastructure wasn't going to suit my purpose.
39
-
40
- ### I'm not giving up JSHint for this!
41
-
42
- That's not really a question, but I got it. I'm not trying to convince you that ESLint is better than JSHint. The only thing I know is that ESLint is better than JSHint for what I'm doing. In the off chance you're doing something similar, it might be better for you. Otherwise, keep using JSHint, I'm certainly not going to tell you to stop using it.
43
-
44
- ### How does ESLint performance compare to JSHint and JSCS?
45
-
46
- ESLint is slower than JSHint, usually 2-3x slower on a single file. This is because ESLint uses Espree to construct an AST before it can evaluate your code whereas JSHint evaluates your code as it's being parsed. The speed is also based on the number of rules you enable; the more rules you enable, the slower the process.
47
-
48
- Despite being slower, we believe that ESLint is fast enough to replace JSHint without causing significant pain.
49
-
50
- ESLint is faster than JSCS, as ESLint uses a single-pass traversal for analysis whereas JSCS using a querying model.
51
-
52
- If you are using both JSHint and JSCS on your files, then using just ESLint will be faster.
53
-
54
- ### Is ESLint just linting or does it also check style?
55
-
56
- ESLint does both traditional linting (looking for problematic patterns) and style checking (enforcement of conventions). You can use it for both.
57
-
58
- ### Who is using ESLint?
59
-
60
- The following projects are using ESLint to validate their JavaScript:
61
-
62
- * [Drupal](https://www.drupal.org/node/2274223)
63
- * [Esprima](https://github.com/ariya/esprima)
64
- * [io.js](https://github.com/iojs/io.js/commit/f9dd34d301ab385ae316769b85ef916f9b70b6f6)
65
- * [WebKit](https://bugs.webkit.org/show_bug.cgi?id=125048)
66
-
67
- In addition, the following companies are using ESLint internally to validate their JavaScript:
68
-
69
- * [Box](https://box.com)
70
- * [CustomInk](https://customink.com)
71
- * [Fitbit](http://www.fitbit.com)
72
- * [HolidayCheck](http://holidaycheck.de)
73
- * [the native web](http://www.thenativeweb.io)
74
-
75
- ### What about ECMAScript 6 support?
76
-
77
- ESLint has full support for ECMAScript 6. By default, this support is off. You can enable ECMAScript 6 support through [configuration](http://eslint.org/docs/user-guide/configuring).
78
-
79
- ### Does ESLint support JSX?
80
-
81
- Yes, ESLint natively supports parsing JSX syntax (this must be enabled in configuration). Please note that supporting JSX syntax *is not* the same as supporting React. React applies specific semantics to JSX syntax that ESLint doesn't recognize. We recommend using [eslint-plugin-react](https://www.npmjs.com/package/eslint-plugin-react) if you are using React and want React semantics.
82
-
83
- ### Where to ask for help?
84
-
85
- Join our [Mailing List](https://groups.google.com/group/eslint) or [Chatroom](https://gitter.im/eslint/eslint)
86
-
87
-
88
- [npm-image]: https://img.shields.io/npm/v/eslint.svg?style=flat-square
89
- [npm-url]: https://npmjs.org/package/eslint
90
- [travis-image]: https://img.shields.io/travis/eslint/eslint/master.svg?style=flat-square
91
- [travis-url]: https://travis-ci.org/eslint/eslint
92
- [coveralls-image]: https://img.shields.io/coveralls/eslint/eslint/master.svg?style=flat-square
93
- [coveralls-url]: https://coveralls.io/r/eslint/eslint?branch=master
94
- [downloads-image]: http://img.shields.io/npm/dm/eslint.svg?style=flat-square
95
- [downloads-url]: https://npmjs.org/package/eslint
1
+ [![NPM version][npm-image]][npm-url]
2
+ [![build status][travis-image]][travis-url]
3
+ [![Test coverage][coveralls-image]][coveralls-url]
4
+ [![Downloads][downloads-image]][downloads-url]
5
+ [![Bountysource](https://www.bountysource.com/badge/tracker?tracker_id=282608)](https://www.bountysource.com/trackers/282608-eslint?utm_source=282608&utm_medium=shield&utm_campaign=TRACKER_BADGE)
6
+ [![Join the chat at https://gitter.im/eslint/eslint](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/eslint/eslint?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
7
+
8
+ # ESLint
9
+
10
+ [Website](http://eslint.org) | [Configuring](http://eslint.org/docs/user-guide/configuring) | [Rules](http://eslint.org/docs/rules/) | [Contributing](http://eslint.org/docs/developer-guide/contributing) | [Twitter](https://twitter.com/geteslint) | [Mailing List](https://groups.google.com/group/eslint)
11
+
12
+ ESLint is a tool for identifying and reporting on patterns found in ECMAScript/JavaScript code. In many ways, it is similar to JSLint and JSHint with a few exceptions:
13
+
14
+ * ESLint uses [Espree](https://github.com/eslint/espree) for JavaScript parsing.
15
+ * ESLint uses an AST to evaluate patterns in code.
16
+ * ESLint is completely pluggable, every single rule is a plugin and you can add more at runtime.
17
+
18
+ ## Installation
19
+
20
+ You can install ESLint using npm:
21
+
22
+ npm install -g eslint
23
+
24
+ ## Usage
25
+
26
+ If it's your first time using ESLint, you should set up a config file using `--init`:
27
+
28
+ eslint --init
29
+
30
+ After that, you can run ESLint on any JavaScript file:
31
+
32
+ eslint test.js test2.js
33
+
34
+ ## Team
35
+
36
+ These folks keep the project moving and are resources for help:
37
+
38
+ * Nicholas C. Zakas ([@nzakas](https://github.com/nzakas)) - project lead
39
+ * Ilya Volodin ([@ilyavolodin](https://github.com/ilyavolodin)) - reviewer
40
+ * Brandon Mills ([@btmills](https://github.com/btmills)) - reviewer
41
+ * Mathias Schreck ([@lo1tuma](https://github.com/lo1tuma)) - committer
42
+ * Gyandeep Singh ([@gyandeeps](https://github.com/gyandeeps)) - committer
43
+ * Jamund Ferguson ([@xjamundx](https://github.com/xjamundx)) - committer
44
+
45
+
46
+ ## Frequently Asked Questions
47
+
48
+ ### Why don't you like JSHint???
49
+
50
+ I do like JSHint. And I like Anton and Rick. Neither of those were deciding factors in creating this tool. The fact is that I've had a dire need for a JavaScript tool with pluggable linting rules. I had hoped JSHint would be able to do this, however after chatting with Anton, I found that the planned plugin infrastructure wasn't going to suit my purpose.
51
+
52
+ ### I'm not giving up JSHint for this!
53
+
54
+ That's not really a question, but I got it. I'm not trying to convince you that ESLint is better than JSHint. The only thing I know is that ESLint is better than JSHint for what I'm doing. In the off chance you're doing something similar, it might be better for you. Otherwise, keep using JSHint, I'm certainly not going to tell you to stop using it.
55
+
56
+ ### How does ESLint performance compare to JSHint and JSCS?
57
+
58
+ ESLint is slower than JSHint, usually 2-3x slower on a single file. This is because ESLint uses Espree to construct an AST before it can evaluate your code whereas JSHint evaluates your code as it's being parsed. The speed is also based on the number of rules you enable; the more rules you enable, the slower the process.
59
+
60
+ Despite being slower, we believe that ESLint is fast enough to replace JSHint without causing significant pain.
61
+
62
+ ESLint is faster than JSCS, as ESLint uses a single-pass traversal for analysis whereas JSCS using a querying model.
63
+
64
+ If you are using both JSHint and JSCS on your files, then using just ESLint will be faster.
65
+
66
+ ### Is ESLint just linting or does it also check style?
67
+
68
+ ESLint does both traditional linting (looking for problematic patterns) and style checking (enforcement of conventions). You can use it for both.
69
+
70
+ ### Who is using ESLint?
71
+
72
+ The following projects are using ESLint to validate their JavaScript:
73
+
74
+ * [Drupal](https://www.drupal.org/node/2274223)
75
+ * [Esprima](https://github.com/ariya/esprima)
76
+ * [io.js](https://github.com/iojs/io.js/commit/f9dd34d301ab385ae316769b85ef916f9b70b6f6)
77
+ * [WebKit](https://bugs.webkit.org/show_bug.cgi?id=125048)
78
+
79
+ In addition, the following companies are using ESLint internally to validate their JavaScript:
80
+
81
+ * [Box](https://box.com)
82
+ * [CustomInk](https://customink.com)
83
+ * [Fitbit](http://www.fitbit.com)
84
+ * [HolidayCheck](http://holidaycheck.de)
85
+ * [the native web](http://www.thenativeweb.io)
86
+
87
+ ### What about ECMAScript 6 support?
88
+
89
+ ESLint has full support for ECMAScript 6. By default, this support is off. You can enable ECMAScript 6 support through [configuration](http://eslint.org/docs/user-guide/configuring).
90
+
91
+ ### Does ESLint support JSX?
92
+
93
+ Yes, ESLint natively supports parsing JSX syntax (this must be enabled in [configuration](http://eslint.org/docs/user-guide/configuring).). Please note that supporting JSX syntax *is not* the same as supporting React. React applies specific semantics to JSX syntax that ESLint doesn't recognize. We recommend using [eslint-plugin-react](https://www.npmjs.com/package/eslint-plugin-react) if you are using React and want React semantics.
94
+
95
+ ### What about ECMAScript 7/2016 and experimental features?
96
+
97
+ ESLint doesn't natively support experimental ECMAScript language features. You can use [babel-eslint](https://github.com/babel/babel-eslint) to use any option available in Babel.
98
+
99
+ ### Where to ask for help?
100
+
101
+ Join our [Mailing List](https://groups.google.com/group/eslint) or [Chatroom](https://gitter.im/eslint/eslint)
102
+
103
+
104
+ [npm-image]: https://img.shields.io/npm/v/eslint.svg?style=flat-square
105
+ [npm-url]: https://npmjs.org/package/eslint
106
+ [travis-image]: https://img.shields.io/travis/eslint/eslint/master.svg?style=flat-square
107
+ [travis-url]: https://travis-ci.org/eslint/eslint
108
+ [coveralls-image]: https://img.shields.io/coveralls/eslint/eslint/master.svg?style=flat-square
109
+ [coveralls-url]: https://coveralls.io/r/eslint/eslint?branch=master
110
+ [downloads-image]: http://img.shields.io/npm/dm/eslint.svg?style=flat-square
111
+ [downloads-url]: https://npmjs.org/package/eslint
package/bin/eslint.js CHANGED
@@ -1,41 +1,41 @@
1
- #!/usr/bin/env node
2
- var concat = require("concat-stream"),
3
- configInit = require("../lib/config-initializer"),
4
- cli = require("../lib/cli");
5
-
6
- var exitCode = 0,
7
- useStdIn = (process.argv.indexOf("--stdin") > -1),
8
- init = (process.argv.indexOf("--init") > -1);
9
-
10
- if (useStdIn) {
11
- process.stdin.pipe(concat({ encoding: "string" }, function(text) {
12
- try {
13
- exitCode = cli.execute(process.argv, text);
14
- } catch (ex) {
15
- console.error(ex.message);
16
- console.error(ex.stack);
17
- exitCode = 1;
18
- }
19
- }));
20
- } else if (init) {
21
- configInit.initializeConfig(function(err) {
22
- if (err) {
23
- exitCode = 1;
24
- console.error(err.message);
25
- console.error(err.stack);
26
- } else {
27
- console.log("Successfully created .eslintrc file in " + process.cwd());
28
- exitCode = 0;
29
- }
30
- });
31
- } else {
32
- exitCode = cli.execute(process.argv);
33
- }
34
-
35
- /*
36
- * Wait for the stdout buffer to drain.
37
- * See https://github.com/eslint/eslint/issues/317
38
- */
39
- process.on("exit", function() {
40
- process.exit(exitCode);
41
- });
1
+ #!/usr/bin/env node
2
+ var concat = require("concat-stream"),
3
+ configInit = require("../lib/config-initializer"),
4
+ cli = require("../lib/cli");
5
+
6
+ var exitCode = 0,
7
+ useStdIn = (process.argv.indexOf("--stdin") > -1),
8
+ init = (process.argv.indexOf("--init") > -1);
9
+
10
+ if (useStdIn) {
11
+ process.stdin.pipe(concat({ encoding: "string" }, function(text) {
12
+ try {
13
+ exitCode = cli.execute(process.argv, text);
14
+ } catch (ex) {
15
+ console.error(ex.message);
16
+ console.error(ex.stack);
17
+ exitCode = 1;
18
+ }
19
+ }));
20
+ } else if (init) {
21
+ configInit.initializeConfig(function(err) {
22
+ if (err) {
23
+ exitCode = 1;
24
+ console.error(err.message);
25
+ console.error(err.stack);
26
+ } else {
27
+ console.log("Successfully created .eslintrc file in " + process.cwd());
28
+ exitCode = 0;
29
+ }
30
+ });
31
+ } else {
32
+ exitCode = cli.execute(process.argv);
33
+ }
34
+
35
+ /*
36
+ * Wait for the stdout buffer to drain.
37
+ * See https://github.com/eslint/eslint/issues/317
38
+ */
39
+ process.on("exit", function() {
40
+ process.exit(exitCode);
41
+ });
@@ -1,81 +1,87 @@
1
- /**
2
- * @fileoverview Defines environment settings and globals.
3
- * @author Elan Shanker
4
- * @copyright 2014 Elan Shanker. All rights reserved.
5
- */
6
- "use strict";
7
-
8
- var globals = require("globals");
9
-
10
- module.exports = {
11
- builtin: globals.builtin,
12
- browser: {
13
- globals: globals.browser
14
- },
15
- node: {
16
- globals: globals.node,
17
- ecmaFeatures: {
18
- globalReturn: true
19
- },
20
- rules: {
21
- "no-catch-shadow": 0,
22
- "no-console": 0,
23
- "no-mixed-requires": 2,
24
- "no-new-require": 2,
25
- "no-path-concat": 2,
26
- "no-process-exit": 2,
27
- "global-strict": [0, "always"],
28
- "handle-callback-err": [2, "err"]
29
- }
30
- },
31
- worker: {
32
- globals: globals.worker
33
- },
34
- amd: {
35
- globals: globals.amd
36
- },
37
- mocha: {
38
- globals: globals.mocha
39
- },
40
- jasmine: {
41
- globals: globals.jasmine
42
- },
43
- phantomjs: {
44
- globals: globals.phantom
45
- },
46
- jquery: {
47
- globals: globals.jquery
48
- },
49
- prototypejs: {
50
- globals: globals.prototypejs
51
- },
52
- shelljs: {
53
- globals: globals.shelljs
54
- },
55
- meteor: {
56
- globals: globals.meteor
57
- },
58
- es6: {
59
- ecmaFeatures: {
60
- arrowFunctions: true,
61
- blockBindings: true,
62
- regexUFlag: true,
63
- regexYFlag: true,
64
- templateStrings: true,
65
- binaryLiterals: true,
66
- octalLiterals: true,
67
- unicodeCodePointEscapes: true,
68
- superInFunctions: true,
69
- defaultParams: true,
70
- restParams: true,
71
- forOf: true,
72
- objectLiteralComputedProperties: true,
73
- objectLiteralShorthandMethods: true,
74
- objectLiteralShorthandProperties: true,
75
- objectLiteralDuplicateProperties: true,
76
- generators: true,
77
- destructuring: true,
78
- classes: true
79
- }
80
- }
81
- };
1
+ /**
2
+ * @fileoverview Defines environment settings and globals.
3
+ * @author Elan Shanker
4
+ * @copyright 2014 Elan Shanker. All rights reserved.
5
+ */
6
+ "use strict";
7
+
8
+ var globals = require("globals");
9
+
10
+ module.exports = {
11
+ builtin: globals.builtin,
12
+ browser: {
13
+ globals: globals.browser
14
+ },
15
+ node: {
16
+ globals: globals.node,
17
+ ecmaFeatures: {
18
+ globalReturn: true
19
+ },
20
+ rules: {
21
+ "no-catch-shadow": 0,
22
+ "no-console": 0,
23
+ "no-mixed-requires": 2,
24
+ "no-new-require": 2,
25
+ "no-path-concat": 2,
26
+ "no-process-exit": 2,
27
+ "global-strict": [0, "always"],
28
+ "handle-callback-err": [2, "err"]
29
+ }
30
+ },
31
+ worker: {
32
+ globals: globals.worker
33
+ },
34
+ amd: {
35
+ globals: globals.amd
36
+ },
37
+ mocha: {
38
+ globals: globals.mocha
39
+ },
40
+ jasmine: {
41
+ globals: globals.jasmine
42
+ },
43
+ phantomjs: {
44
+ globals: globals.phantom
45
+ },
46
+ jquery: {
47
+ globals: globals.jquery
48
+ },
49
+ prototypejs: {
50
+ globals: globals.prototypejs
51
+ },
52
+ shelljs: {
53
+ globals: globals.shelljs
54
+ },
55
+ meteor: {
56
+ globals: globals.meteor
57
+ },
58
+ mongo: {
59
+ globals: globals.mongo
60
+ },
61
+ applescript: {
62
+ globals: globals.applescript
63
+ },
64
+ es6: {
65
+ ecmaFeatures: {
66
+ arrowFunctions: true,
67
+ blockBindings: true,
68
+ regexUFlag: true,
69
+ regexYFlag: true,
70
+ templateStrings: true,
71
+ binaryLiterals: true,
72
+ octalLiterals: true,
73
+ unicodeCodePointEscapes: true,
74
+ superInFunctions: true,
75
+ defaultParams: true,
76
+ restParams: true,
77
+ forOf: true,
78
+ objectLiteralComputedProperties: true,
79
+ objectLiteralShorthandMethods: true,
80
+ objectLiteralShorthandProperties: true,
81
+ objectLiteralDuplicateProperties: true,
82
+ generators: true,
83
+ destructuring: true,
84
+ classes: true
85
+ }
86
+ }
87
+ };