eslint 0.22.0 → 0.24.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +20 -20
- package/README.md +111 -95
- package/bin/eslint.js +41 -41
- package/conf/environments.js +87 -81
- package/conf/eslint.json +186 -179
- package/lib/api.js +13 -12
- package/lib/cli-engine.js +441 -451
- package/lib/cli.js +196 -196
- package/lib/config-initializer.js +145 -145
- package/lib/config-validator.js +110 -110
- package/lib/config.js +428 -416
- package/lib/eslint.js +1072 -1073
- package/lib/file-finder.js +167 -167
- package/lib/formatters/checkstyle.js +68 -68
- package/lib/formatters/compact.js +53 -53
- package/lib/formatters/jslint-xml.js +40 -40
- package/lib/formatters/junit.js +63 -63
- package/lib/formatters/stylish.js +90 -90
- package/lib/formatters/tap.js +86 -86
- package/lib/ignored-paths.js +137 -137
- package/lib/load-rules.js +39 -39
- package/lib/options.js +132 -126
- package/lib/rule-context.js +107 -107
- package/lib/rules/accessor-pairs.js +65 -65
- package/lib/rules/array-bracket-spacing.js +180 -0
- package/lib/rules/block-scoped-var.js +339 -320
- package/lib/rules/brace-style.js +228 -228
- package/lib/rules/camelcase.js +111 -111
- package/lib/rules/comma-dangle.js +67 -64
- package/lib/rules/comma-spacing.js +191 -191
- package/lib/rules/comma-style.js +195 -195
- package/lib/rules/complexity.js +94 -94
- package/lib/rules/computed-property-spacing.js +144 -0
- package/lib/rules/consistent-return.js +75 -75
- package/lib/rules/consistent-this.js +119 -119
- package/lib/rules/constructor-super.js +108 -0
- package/lib/rules/curly.js +109 -109
- package/lib/rules/default-case.js +66 -66
- package/lib/rules/dot-location.js +63 -63
- package/lib/rules/dot-notation.js +119 -119
- package/lib/rules/eol-last.js +38 -38
- package/lib/rules/eqeqeq.js +96 -96
- package/lib/rules/func-names.js +45 -45
- package/lib/rules/func-style.js +49 -49
- package/lib/rules/generator-star-spacing.js +104 -87
- package/lib/rules/generator-star.js +76 -76
- package/lib/rules/global-strict.js +49 -49
- package/lib/rules/guard-for-in.js +32 -32
- package/lib/rules/handle-callback-err.js +81 -124
- package/lib/rules/indent.js +486 -486
- package/lib/rules/key-spacing.js +325 -325
- package/lib/rules/linebreak-style.js +44 -44
- package/lib/rules/lines-around-comment.js +228 -160
- package/lib/rules/max-depth.js +89 -89
- package/lib/rules/max-len.js +76 -76
- package/lib/rules/max-nested-callbacks.js +73 -73
- package/lib/rules/max-params.js +45 -45
- package/lib/rules/max-statements.js +61 -61
- package/lib/rules/new-cap.js +224 -224
- package/lib/rules/new-parens.js +29 -29
- package/lib/rules/newline-after-var.js +127 -127
- package/lib/rules/no-alert.js +153 -153
- package/lib/rules/no-array-constructor.js +31 -31
- package/lib/rules/no-bitwise.js +57 -57
- package/lib/rules/no-caller.js +29 -29
- package/lib/rules/no-catch-shadow.js +52 -52
- package/lib/rules/no-comma-dangle.js +45 -45
- package/lib/rules/no-cond-assign.js +123 -123
- package/lib/rules/no-console.js +27 -27
- package/lib/rules/no-constant-condition.js +73 -73
- package/lib/rules/no-continue.js +23 -23
- package/lib/rules/no-control-regex.js +58 -58
- package/lib/rules/no-debugger.js +22 -22
- package/lib/rules/no-delete-var.js +25 -25
- package/lib/rules/no-div-regex.js +27 -27
- package/lib/rules/no-dupe-args.js +89 -85
- package/lib/rules/no-dupe-keys.js +43 -43
- package/lib/rules/no-duplicate-case.js +67 -67
- package/lib/rules/no-else-return.js +125 -125
- package/lib/rules/no-empty-character-class.js +43 -43
- package/lib/rules/no-empty-class.js +45 -45
- package/lib/rules/no-empty-label.js +27 -27
- package/lib/rules/no-empty.js +49 -49
- package/lib/rules/no-eq-null.js +29 -29
- package/lib/rules/no-eval.js +26 -26
- package/lib/rules/no-ex-assign.js +42 -42
- package/lib/rules/no-extend-native.js +103 -103
- package/lib/rules/no-extra-bind.js +81 -81
- package/lib/rules/no-extra-boolean-cast.js +71 -71
- package/lib/rules/no-extra-parens.js +368 -355
- package/lib/rules/no-extra-semi.js +70 -23
- package/lib/rules/no-extra-strict.js +86 -86
- package/lib/rules/no-fallthrough.js +97 -97
- package/lib/rules/no-floating-decimal.js +30 -30
- package/lib/rules/no-func-assign.js +83 -83
- package/lib/rules/no-implied-eval.js +76 -76
- package/lib/rules/no-inline-comments.js +49 -49
- package/lib/rules/no-inner-declarations.js +78 -78
- package/lib/rules/no-invalid-regexp.js +53 -53
- package/lib/rules/no-irregular-whitespace.js +135 -135
- package/lib/rules/no-iterator.js +28 -28
- package/lib/rules/no-label-var.js +64 -64
- package/lib/rules/no-labels.js +44 -44
- package/lib/rules/no-lone-blocks.js +106 -27
- package/lib/rules/no-lonely-if.js +30 -30
- package/lib/rules/no-loop-func.js +58 -58
- package/lib/rules/no-mixed-requires.js +165 -165
- package/lib/rules/no-mixed-spaces-and-tabs.js +74 -74
- package/lib/rules/no-multi-spaces.js +119 -119
- package/lib/rules/no-multi-str.js +43 -43
- package/lib/rules/no-multiple-empty-lines.js +98 -98
- package/lib/rules/no-native-reassign.js +62 -62
- package/lib/rules/no-negated-in-lhs.js +25 -25
- package/lib/rules/no-nested-ternary.js +24 -24
- package/lib/rules/no-new-func.js +25 -25
- package/lib/rules/no-new-object.js +25 -25
- package/lib/rules/no-new-require.js +25 -25
- package/lib/rules/no-new-wrappers.js +26 -26
- package/lib/rules/no-new.js +27 -27
- package/lib/rules/no-obj-calls.js +28 -28
- package/lib/rules/no-octal-escape.js +39 -39
- package/lib/rules/no-octal.js +25 -25
- package/lib/rules/no-param-reassign.js +87 -87
- package/lib/rules/no-path-concat.js +39 -39
- package/lib/rules/no-plusplus.js +24 -24
- package/lib/rules/no-process-env.js +30 -30
- package/lib/rules/no-process-exit.js +33 -33
- package/lib/rules/no-proto.js +28 -28
- package/lib/rules/no-redeclare.js +68 -68
- package/lib/rules/no-regex-spaces.js +35 -35
- package/lib/rules/no-reserved-keys.js +56 -56
- package/lib/rules/no-restricted-modules.js +85 -85
- package/lib/rules/no-return-assign.js +53 -24
- package/lib/rules/no-script-url.js +34 -34
- package/lib/rules/no-self-compare.js +29 -29
- package/lib/rules/no-sequences.js +94 -94
- package/lib/rules/no-shadow-restricted-names.js +51 -51
- package/lib/rules/no-shadow.js +181 -136
- package/lib/rules/no-space-before-semi.js +98 -98
- package/lib/rules/no-spaced-func.js +37 -37
- package/lib/rules/no-sparse-arrays.js +33 -33
- package/lib/rules/no-sync.js +30 -30
- package/lib/rules/no-ternary.js +24 -24
- package/lib/rules/no-this-before-super.js +144 -0
- package/lib/rules/no-throw-literal.js +33 -33
- package/lib/rules/no-trailing-spaces.js +74 -63
- package/lib/rules/no-undef-init.js +28 -28
- package/lib/rules/no-undef.js +92 -92
- package/lib/rules/no-undefined.js +27 -27
- package/lib/rules/no-underscore-dangle.js +73 -73
- package/lib/rules/no-unexpected-multiline.js +58 -0
- package/lib/rules/no-unneeded-ternary.js +48 -48
- package/lib/rules/no-unreachable.js +98 -98
- package/lib/rules/no-unused-expressions.js +76 -76
- package/lib/rules/no-unused-vars.js +252 -250
- package/lib/rules/no-use-before-define.js +105 -105
- package/lib/rules/no-var.js +26 -26
- package/lib/rules/no-void.js +28 -28
- package/lib/rules/no-warning-comments.js +102 -102
- package/lib/rules/no-with.js +22 -22
- package/lib/rules/no-wrap-func.js +65 -65
- package/lib/rules/object-curly-spacing.js +231 -206
- package/lib/rules/object-shorthand.js +74 -73
- package/lib/rules/one-var.js +311 -304
- package/lib/rules/operator-assignment.js +118 -118
- package/lib/rules/operator-linebreak.js +114 -114
- package/lib/rules/padded-blocks.js +98 -98
- package/lib/rules/prefer-const.js +91 -0
- package/lib/rules/quote-props.js +72 -72
- package/lib/rules/quotes.js +92 -92
- package/lib/rules/radix.js +41 -41
- package/lib/rules/semi-spacing.js +167 -167
- package/lib/rules/semi.js +136 -136
- package/lib/rules/sort-vars.js +49 -49
- package/lib/rules/space-after-function-name.js +49 -49
- package/lib/rules/space-after-keywords.js +82 -82
- package/lib/rules/space-before-blocks.js +91 -91
- package/lib/rules/space-before-function-paren.js +139 -139
- package/lib/rules/space-before-function-parentheses.js +139 -139
- package/lib/rules/space-in-brackets.js +305 -305
- package/lib/rules/space-in-parens.js +281 -281
- package/lib/rules/space-infix-ops.js +106 -106
- package/lib/rules/space-return-throw-case.js +38 -38
- package/lib/rules/space-unary-ops.js +124 -133
- package/lib/rules/spaced-comment.js +143 -0
- package/lib/rules/spaced-line-comment.js +89 -89
- package/lib/rules/strict.js +242 -242
- package/lib/rules/use-isnan.js +26 -26
- package/lib/rules/valid-jsdoc.js +215 -215
- package/lib/rules/valid-typeof.js +42 -42
- package/lib/rules/vars-on-top.js +115 -115
- package/lib/rules/wrap-iife.js +48 -48
- package/lib/rules/wrap-regex.js +38 -38
- package/lib/rules/yoda.js +242 -225
- package/lib/rules.js +88 -88
- package/lib/timing.js +109 -109
- package/lib/token-store.js +201 -201
- package/lib/util/traverse.js +105 -105
- package/lib/util.js +125 -85
- package/package.json +6 -6
- package/CHANGELOG.md +0 -1638
package/lib/rule-context.js
CHANGED
@@ -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
|
+
];
|