eslint 5.6.0 → 5.9.0
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/CHANGELOG.md +65 -0
- package/bin/eslint.js +0 -1
- package/lib/cli-engine.js +128 -31
- package/lib/cli.js +6 -1
- package/lib/linter.js +9 -0
- package/lib/options.js +5 -0
- package/lib/rules/accessor-pairs.js +4 -0
- package/lib/rules/array-bracket-newline.js +5 -0
- package/lib/rules/array-bracket-spacing.js +5 -0
- package/lib/rules/array-callback-return.js +2 -0
- package/lib/rules/array-element-newline.js +4 -0
- package/lib/rules/arrow-body-style.js +2 -0
- package/lib/rules/arrow-parens.js +2 -0
- package/lib/rules/arrow-spacing.js +2 -0
- package/lib/rules/block-scoped-var.js +2 -0
- package/lib/rules/block-spacing.js +2 -0
- package/lib/rules/brace-style.js +2 -0
- package/lib/rules/callback-return.js +2 -0
- package/lib/rules/camelcase.js +38 -8
- package/lib/rules/capitalized-comments.js +4 -0
- package/lib/rules/class-methods-use-this.js +3 -0
- package/lib/rules/comma-dangle.js +4 -0
- package/lib/rules/comma-spacing.js +2 -0
- package/lib/rules/comma-style.js +5 -0
- package/lib/rules/complexity.js +2 -0
- package/lib/rules/computed-property-spacing.js +2 -0
- package/lib/rules/consistent-return.js +2 -0
- package/lib/rules/consistent-this.js +2 -0
- package/lib/rules/constructor-super.js +2 -0
- package/lib/rules/curly.js +2 -0
- package/lib/rules/default-case.js +2 -0
- package/lib/rules/dot-location.js +2 -0
- package/lib/rules/dot-notation.js +2 -0
- package/lib/rules/eol-last.js +5 -0
- package/lib/rules/eqeqeq.js +2 -0
- package/lib/rules/for-direction.js +4 -0
- package/lib/rules/func-call-spacing.js +4 -0
- package/lib/rules/func-name-matching.js +3 -0
- package/lib/rules/func-names.js +3 -0
- package/lib/rules/func-style.js +3 -0
- package/lib/rules/function-paren-newline.js +5 -0
- package/lib/rules/generator-star-spacing.js +3 -0
- package/lib/rules/getter-return.js +5 -0
- package/lib/rules/global-require.js +2 -0
- package/lib/rules/guard-for-in.js +2 -0
- package/lib/rules/handle-callback-err.js +2 -0
- package/lib/rules/id-blacklist.js +2 -0
- package/lib/rules/id-length.js +2 -0
- package/lib/rules/id-match.js +101 -27
- package/lib/rules/implicit-arrow-linebreak.js +4 -0
- package/lib/rules/indent-legacy.js +4 -1
- package/lib/rules/indent.js +2 -0
- package/lib/rules/init-declarations.js +2 -0
- package/lib/rules/jsx-quotes.js +2 -0
- package/lib/rules/key-spacing.js +4 -3
- package/lib/rules/keyword-spacing.js +2 -0
- package/lib/rules/line-comment-position.js +2 -0
- package/lib/rules/linebreak-style.js +2 -0
- package/lib/rules/lines-around-comment.js +2 -0
- package/lib/rules/lines-around-directive.js +6 -2
- package/lib/rules/lines-between-class-members.js +2 -0
- package/lib/rules/max-classes-per-file.js +4 -0
- package/lib/rules/max-depth.js +2 -0
- package/lib/rules/max-len.js +2 -0
- package/lib/rules/max-lines-per-function.js +2 -0
- package/lib/rules/max-lines.js +2 -0
- package/lib/rules/max-nested-callbacks.js +2 -0
- package/lib/rules/max-params.js +2 -0
- package/lib/rules/max-statements-per-line.js +2 -0
- package/lib/rules/max-statements.js +2 -0
- package/lib/rules/multiline-comment-style.js +3 -0
- package/lib/rules/multiline-ternary.js +3 -0
- package/lib/rules/new-cap.js +2 -0
- package/lib/rules/new-parens.js +2 -1
- package/lib/rules/newline-after-var.js +5 -2
- package/lib/rules/newline-before-return.js +5 -2
- package/lib/rules/newline-per-chained-call.js +4 -0
- package/lib/rules/no-alert.js +2 -0
- package/lib/rules/no-array-constructor.js +2 -0
- package/lib/rules/no-async-promise-executor.js +3 -0
- package/lib/rules/no-await-in-loop.js +4 -0
- package/lib/rules/no-bitwise.js +2 -0
- package/lib/rules/no-buffer-constructor.js +4 -0
- package/lib/rules/no-caller.js +2 -0
- package/lib/rules/no-case-declarations.js +2 -0
- package/lib/rules/no-catch-shadow.js +6 -3
- package/lib/rules/no-class-assign.js +2 -0
- package/lib/rules/no-compare-neg-zero.js +4 -0
- package/lib/rules/no-cond-assign.js +2 -0
- package/lib/rules/no-confusing-arrow.js +2 -0
- package/lib/rules/no-console.js +2 -0
- package/lib/rules/no-const-assign.js +2 -0
- package/lib/rules/no-constant-condition.js +2 -0
- package/lib/rules/no-continue.js +2 -0
- package/lib/rules/no-control-regex.js +4 -2
- package/lib/rules/no-debugger.js +4 -0
- package/lib/rules/no-delete-var.js +2 -0
- package/lib/rules/no-div-regex.js +2 -0
- package/lib/rules/no-dupe-args.js +2 -0
- package/lib/rules/no-dupe-class-members.js +2 -0
- package/lib/rules/no-dupe-keys.js +2 -0
- package/lib/rules/no-duplicate-case.js +2 -0
- package/lib/rules/no-duplicate-imports.js +2 -0
- package/lib/rules/no-else-return.js +2 -0
- package/lib/rules/no-empty-character-class.js +2 -0
- package/lib/rules/no-empty-function.js +2 -0
- package/lib/rules/no-empty-pattern.js +2 -0
- package/lib/rules/no-empty.js +2 -0
- package/lib/rules/no-eq-null.js +2 -0
- package/lib/rules/no-eval.js +2 -0
- package/lib/rules/no-ex-assign.js +2 -0
- package/lib/rules/no-extend-native.js +2 -0
- package/lib/rules/no-extra-bind.js +24 -1
- package/lib/rules/no-extra-boolean-cast.js +2 -1
- package/lib/rules/no-extra-label.js +2 -1
- package/lib/rules/no-extra-parens.js +5 -6
- package/lib/rules/no-extra-semi.js +2 -0
- package/lib/rules/no-fallthrough.js +2 -0
- package/lib/rules/no-floating-decimal.js +2 -1
- package/lib/rules/no-func-assign.js +2 -0
- package/lib/rules/no-global-assign.js +2 -0
- package/lib/rules/no-implicit-coercion.js +3 -0
- package/lib/rules/no-implicit-globals.js +2 -0
- package/lib/rules/no-implied-eval.js +2 -0
- package/lib/rules/no-inline-comments.js +2 -0
- package/lib/rules/no-inner-declarations.js +2 -0
- package/lib/rules/no-invalid-regexp.js +2 -0
- package/lib/rules/no-invalid-this.js +2 -0
- package/lib/rules/no-irregular-whitespace.js +6 -8
- package/lib/rules/no-iterator.js +2 -0
- package/lib/rules/no-label-var.js +2 -0
- package/lib/rules/no-labels.js +2 -0
- package/lib/rules/no-lone-blocks.js +2 -0
- package/lib/rules/no-lonely-if.js +2 -1
- package/lib/rules/no-loop-func.js +2 -0
- package/lib/rules/no-magic-numbers.js +3 -0
- package/lib/rules/no-misleading-character-class.js +4 -0
- package/lib/rules/no-mixed-operators.js +3 -0
- package/lib/rules/no-mixed-requires.js +2 -0
- package/lib/rules/no-mixed-spaces-and-tabs.js +2 -0
- package/lib/rules/no-multi-assign.js +3 -0
- package/lib/rules/no-multi-spaces.js +2 -0
- package/lib/rules/no-multi-str.js +2 -0
- package/lib/rules/no-multiple-empty-lines.js +2 -0
- package/lib/rules/no-native-reassign.js +4 -1
- package/lib/rules/no-negated-condition.js +2 -0
- package/lib/rules/no-negated-in-lhs.js +5 -2
- package/lib/rules/no-nested-ternary.js +2 -0
- package/lib/rules/no-new-func.js +2 -0
- package/lib/rules/no-new-object.js +2 -0
- package/lib/rules/no-new-require.js +2 -0
- package/lib/rules/no-new-symbol.js +2 -0
- package/lib/rules/no-new-wrappers.js +2 -0
- package/lib/rules/no-new.js +2 -0
- package/lib/rules/no-obj-calls.js +2 -0
- package/lib/rules/no-octal-escape.js +2 -0
- package/lib/rules/no-octal.js +2 -0
- package/lib/rules/no-param-reassign.js +2 -0
- package/lib/rules/no-path-concat.js +2 -0
- package/lib/rules/no-plusplus.js +2 -0
- package/lib/rules/no-process-env.js +2 -0
- package/lib/rules/no-process-exit.js +2 -0
- package/lib/rules/no-proto.js +2 -0
- package/lib/rules/no-prototype-builtins.js +2 -0
- package/lib/rules/no-redeclare.js +2 -0
- package/lib/rules/no-regex-spaces.js +2 -1
- package/lib/rules/no-restricted-globals.js +2 -0
- package/lib/rules/no-restricted-imports.js +40 -22
- package/lib/rules/no-restricted-modules.js +2 -0
- package/lib/rules/no-restricted-properties.js +2 -0
- package/lib/rules/no-restricted-syntax.js +2 -0
- package/lib/rules/no-return-assign.js +2 -0
- package/lib/rules/no-return-await.js +4 -0
- package/lib/rules/no-script-url.js +2 -0
- package/lib/rules/no-self-assign.js +2 -0
- package/lib/rules/no-self-compare.js +2 -0
- package/lib/rules/no-sequences.js +2 -0
- package/lib/rules/no-shadow-restricted-names.js +2 -0
- package/lib/rules/no-shadow.js +2 -0
- package/lib/rules/no-spaced-func.js +4 -1
- package/lib/rules/no-sparse-arrays.js +2 -0
- package/lib/rules/no-sync.js +2 -0
- package/lib/rules/no-tabs.js +25 -6
- package/lib/rules/no-template-curly-in-string.js +2 -0
- package/lib/rules/no-ternary.js +2 -0
- package/lib/rules/no-this-before-super.js +2 -0
- package/lib/rules/no-throw-literal.js +2 -0
- package/lib/rules/no-trailing-spaces.js +2 -0
- package/lib/rules/no-undef-init.js +2 -1
- package/lib/rules/no-undef.js +2 -0
- package/lib/rules/no-undefined.js +2 -0
- package/lib/rules/no-underscore-dangle.js +2 -0
- package/lib/rules/no-unexpected-multiline.js +2 -0
- package/lib/rules/no-unmodified-loop-condition.js +2 -0
- package/lib/rules/no-unneeded-ternary.js +2 -0
- package/lib/rules/no-unreachable.js +2 -1
- package/lib/rules/no-unsafe-finally.js +2 -0
- package/lib/rules/no-unsafe-negation.js +3 -0
- package/lib/rules/no-unused-expressions.js +2 -0
- package/lib/rules/no-unused-labels.js +2 -1
- package/lib/rules/no-unused-vars.js +37 -13
- package/lib/rules/no-use-before-define.js +2 -0
- package/lib/rules/no-useless-call.js +2 -0
- package/lib/rules/no-useless-computed-key.js +2 -1
- package/lib/rules/no-useless-concat.js +2 -0
- package/lib/rules/no-useless-constructor.js +2 -0
- package/lib/rules/no-useless-escape.js +2 -0
- package/lib/rules/no-useless-rename.js +4 -0
- package/lib/rules/no-useless-return.js +3 -0
- package/lib/rules/no-var.js +2 -0
- package/lib/rules/no-void.js +2 -0
- package/lib/rules/no-warning-comments.js +2 -0
- package/lib/rules/no-whitespace-before-property.js +2 -0
- package/lib/rules/no-with.js +2 -0
- package/lib/rules/nonblock-statement-body-position.js +4 -0
- package/lib/rules/object-curly-newline.js +4 -0
- package/lib/rules/object-curly-spacing.js +2 -0
- package/lib/rules/object-property-newline.js +3 -2
- package/lib/rules/object-shorthand.js +2 -0
- package/lib/rules/one-var-declaration-per-line.js +2 -0
- package/lib/rules/one-var.js +13 -1
- package/lib/rules/operator-assignment.js +2 -0
- package/lib/rules/operator-linebreak.js +2 -0
- package/lib/rules/padded-blocks.js +2 -0
- package/lib/rules/padding-line-between-statements.js +7 -0
- package/lib/rules/prefer-arrow-callback.js +2 -0
- package/lib/rules/prefer-const.js +116 -11
- package/lib/rules/prefer-destructuring.js +3 -0
- package/lib/rules/prefer-numeric-literals.js +2 -1
- package/lib/rules/prefer-object-spread.js +4 -0
- package/lib/rules/prefer-promise-reject-errors.js +4 -0
- package/lib/rules/prefer-reflect.js +4 -1
- package/lib/rules/prefer-rest-params.js +2 -0
- package/lib/rules/prefer-spread.js +2 -1
- package/lib/rules/prefer-template.js +2 -1
- package/lib/rules/quote-props.js +2 -0
- package/lib/rules/quotes.js +2 -0
- package/lib/rules/radix.js +2 -0
- package/lib/rules/require-atomic-updates.js +91 -30
- package/lib/rules/require-await.js +3 -0
- package/lib/rules/require-jsdoc.js +2 -0
- package/lib/rules/require-unicode-regexp.js +4 -0
- package/lib/rules/require-yield.js +2 -0
- package/lib/rules/rest-spread-spacing.js +4 -0
- package/lib/rules/semi-spacing.js +2 -0
- package/lib/rules/semi-style.js +3 -0
- package/lib/rules/semi.js +2 -0
- package/lib/rules/sort-imports.js +2 -0
- package/lib/rules/sort-keys.js +3 -0
- package/lib/rules/sort-vars.js +2 -0
- package/lib/rules/space-before-blocks.js +46 -35
- package/lib/rules/space-before-function-paren.js +2 -0
- package/lib/rules/space-in-parens.js +2 -0
- package/lib/rules/space-infix-ops.js +18 -25
- package/lib/rules/space-unary-ops.js +2 -0
- package/lib/rules/spaced-comment.js +2 -0
- package/lib/rules/strict.js +2 -0
- package/lib/rules/switch-colon-spacing.js +4 -0
- package/lib/rules/symbol-description.js +2 -0
- package/lib/rules/template-curly-spacing.js +2 -0
- package/lib/rules/template-tag-spacing.js +2 -0
- package/lib/rules/unicode-bom.js +2 -0
- package/lib/rules/use-isnan.js +2 -0
- package/lib/rules/valid-jsdoc.js +2 -0
- package/lib/rules/valid-typeof.js +2 -0
- package/lib/rules/vars-on-top.js +2 -0
- package/lib/rules/wrap-iife.js +2 -0
- package/lib/rules/wrap-regex.js +3 -1
- package/lib/rules/yield-star-spacing.js +2 -0
- package/lib/rules/yoda.js +2 -0
- package/lib/testers/rule-tester.js +2 -2
- package/lib/util/source-code-fixer.js +1 -1
- package/package.json +12 -12
@@ -27,6 +27,8 @@ const LINE_BREAK = astUtils.createGlobalLinebreakMatcher();
|
|
27
27
|
|
28
28
|
module.exports = {
|
29
29
|
meta: {
|
30
|
+
type: "problem",
|
31
|
+
|
30
32
|
docs: {
|
31
33
|
description: "disallow irregular whitespace outside of strings and comments",
|
32
34
|
category: "Possible Errors",
|
@@ -81,9 +83,7 @@ module.exports = {
|
|
81
83
|
const locStart = node.loc.start;
|
82
84
|
const locEnd = node.loc.end;
|
83
85
|
|
84
|
-
errors = errors.filter(
|
85
|
-
const errorLoc = error[1];
|
86
|
-
|
86
|
+
errors = errors.filter(({ loc: errorLoc }) => {
|
87
87
|
if (errorLoc.line >= locStart.line && errorLoc.line <= locEnd.line) {
|
88
88
|
if (errorLoc.column >= locStart.column && (errorLoc.column <= locEnd.column || errorLoc.line < locEnd.line)) {
|
89
89
|
return false;
|
@@ -157,7 +157,7 @@ module.exports = {
|
|
157
157
|
column: match.index
|
158
158
|
};
|
159
159
|
|
160
|
-
errors.push(
|
160
|
+
errors.push({ node, message: "Irregular whitespace not allowed.", loc: location });
|
161
161
|
}
|
162
162
|
});
|
163
163
|
}
|
@@ -182,7 +182,7 @@ module.exports = {
|
|
182
182
|
column: sourceLines[lineIndex].length
|
183
183
|
};
|
184
184
|
|
185
|
-
errors.push(
|
185
|
+
errors.push({ node, message: "Irregular whitespace not allowed.", loc: location });
|
186
186
|
lastLineIndex = lineIndex;
|
187
187
|
}
|
188
188
|
}
|
@@ -224,9 +224,7 @@ module.exports = {
|
|
224
224
|
}
|
225
225
|
|
226
226
|
// If we have any errors remaining report on them
|
227
|
-
errors.forEach(error =>
|
228
|
-
context.report(...error);
|
229
|
-
});
|
227
|
+
errors.forEach(error => context.report(error));
|
230
228
|
};
|
231
229
|
} else {
|
232
230
|
nodes.Program = noop;
|
package/lib/rules/no-iterator.js
CHANGED
package/lib/rules/no-labels.js
CHANGED
@@ -10,6 +10,8 @@
|
|
10
10
|
|
11
11
|
module.exports = {
|
12
12
|
meta: {
|
13
|
+
type: "suggestion",
|
14
|
+
|
13
15
|
docs: {
|
14
16
|
description: "disallow `if` statements as the only statement in `else` blocks",
|
15
17
|
category: "Stylistic Issues",
|
@@ -18,7 +20,6 @@ module.exports = {
|
|
18
20
|
},
|
19
21
|
|
20
22
|
schema: [],
|
21
|
-
|
22
23
|
fixable: "code"
|
23
24
|
},
|
24
25
|
|
@@ -11,6 +11,8 @@
|
|
11
11
|
|
12
12
|
module.exports = {
|
13
13
|
meta: {
|
14
|
+
type: "suggestion",
|
15
|
+
|
14
16
|
docs: {
|
15
17
|
description: "disallow magic numbers",
|
16
18
|
category: "Best Practices",
|
@@ -40,6 +42,7 @@ module.exports = {
|
|
40
42
|
},
|
41
43
|
additionalProperties: false
|
42
44
|
}],
|
45
|
+
|
43
46
|
messages: {
|
44
47
|
useConst: "Number constants declarations must use 'const'.",
|
45
48
|
noMagic: "No magic number: {{raw}}."
|
@@ -101,13 +101,17 @@ const kinds = Object.keys(hasCharacterSequence);
|
|
101
101
|
|
102
102
|
module.exports = {
|
103
103
|
meta: {
|
104
|
+
type: "problem",
|
105
|
+
|
104
106
|
docs: {
|
105
107
|
description: "disallow characters which are made with multiple code points in character class syntax",
|
106
108
|
category: "Possible Errors",
|
107
109
|
recommended: false,
|
108
110
|
url: "https://eslint.org/docs/rules/no-misleading-character-class"
|
109
111
|
},
|
112
|
+
|
110
113
|
schema: [],
|
114
|
+
|
111
115
|
messages: {
|
112
116
|
surrogatePairWithoutUFlag: "Unexpected surrogate pair in character class. Use 'u' flag.",
|
113
117
|
combiningClass: "Unexpected combined character in character class.",
|
@@ -71,12 +71,15 @@ function includesBothInAGroup(groups, left, right) {
|
|
71
71
|
|
72
72
|
module.exports = {
|
73
73
|
meta: {
|
74
|
+
type: "suggestion",
|
75
|
+
|
74
76
|
docs: {
|
75
77
|
description: "disallow mixed binary operators",
|
76
78
|
category: "Stylistic Issues",
|
77
79
|
recommended: false,
|
78
80
|
url: "https://eslint.org/docs/rules/no-mixed-operators"
|
79
81
|
},
|
82
|
+
|
80
83
|
schema: [
|
81
84
|
{
|
82
85
|
type: "object",
|
@@ -12,12 +12,15 @@
|
|
12
12
|
|
13
13
|
module.exports = {
|
14
14
|
meta: {
|
15
|
+
type: "suggestion",
|
16
|
+
|
15
17
|
docs: {
|
16
18
|
description: "disallow use of chained assignment expressions",
|
17
19
|
category: "Stylistic Issues",
|
18
20
|
recommended: false,
|
19
21
|
url: "https://eslint.org/docs/rules/no-multi-assign"
|
20
22
|
},
|
23
|
+
|
21
24
|
schema: []
|
22
25
|
},
|
23
26
|
|
@@ -12,16 +12,19 @@
|
|
12
12
|
|
13
13
|
module.exports = {
|
14
14
|
meta: {
|
15
|
+
type: "suggestion",
|
16
|
+
|
15
17
|
docs: {
|
16
18
|
description: "disallow assignments to native objects or read-only global variables",
|
17
19
|
category: "Best Practices",
|
18
20
|
recommended: false,
|
19
|
-
replacedBy: ["no-global-assign"],
|
20
21
|
url: "https://eslint.org/docs/rules/no-native-reassign"
|
21
22
|
},
|
22
23
|
|
23
24
|
deprecated: true,
|
24
25
|
|
26
|
+
replacedBy: ["no-global-assign"],
|
27
|
+
|
25
28
|
schema: [
|
26
29
|
{
|
27
30
|
type: "object",
|
@@ -12,15 +12,18 @@
|
|
12
12
|
|
13
13
|
module.exports = {
|
14
14
|
meta: {
|
15
|
+
type: "problem",
|
16
|
+
|
15
17
|
docs: {
|
16
18
|
description: "disallow negating the left operand in `in` expressions",
|
17
19
|
category: "Possible Errors",
|
18
20
|
recommended: false,
|
19
|
-
replacedBy: ["no-unsafe-negation"],
|
20
21
|
url: "https://eslint.org/docs/rules/no-negated-in-lhs"
|
21
22
|
},
|
22
|
-
deprecated: true,
|
23
23
|
|
24
|
+
replacedBy: ["no-unsafe-negation"],
|
25
|
+
|
26
|
+
deprecated: true,
|
24
27
|
schema: []
|
25
28
|
},
|
26
29
|
|
package/lib/rules/no-new-func.js
CHANGED
package/lib/rules/no-new.js
CHANGED
package/lib/rules/no-octal.js
CHANGED
package/lib/rules/no-plusplus.js
CHANGED
package/lib/rules/no-proto.js
CHANGED
@@ -13,6 +13,8 @@ const astUtils = require("../util/ast-utils");
|
|
13
13
|
|
14
14
|
module.exports = {
|
15
15
|
meta: {
|
16
|
+
type: "suggestion",
|
17
|
+
|
16
18
|
docs: {
|
17
19
|
description: "disallow multiple spaces in regular expressions",
|
18
20
|
category: "Possible Errors",
|
@@ -21,7 +23,6 @@ module.exports = {
|
|
21
23
|
},
|
22
24
|
|
23
25
|
schema: [],
|
24
|
-
|
25
26
|
fixable: "code"
|
26
27
|
},
|
27
28
|
|
@@ -53,6 +53,8 @@ const arrayOfStringsOrObjects = {
|
|
53
53
|
|
54
54
|
module.exports = {
|
55
55
|
meta: {
|
56
|
+
type: "suggestion",
|
57
|
+
|
56
58
|
docs: {
|
57
59
|
description: "disallow specified modules when loaded by `import`",
|
58
60
|
category: "ECMAScript 6",
|
@@ -234,31 +236,47 @@ module.exports = {
|
|
234
236
|
return restrictedPatterns.length > 0 && restrictedPatternsMatcher.ignores(importSource);
|
235
237
|
}
|
236
238
|
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
239
|
+
/**
|
240
|
+
* Checks a node to see if any problems should be reported.
|
241
|
+
* @param {ASTNode} node The node to check.
|
242
|
+
* @returns {void}
|
243
|
+
* @private
|
244
|
+
*/
|
245
|
+
function checkNode(node) {
|
246
|
+
const importSource = node.source.value.trim();
|
247
|
+
const importNames = node.specifiers ? node.specifiers.reduce((set, specifier) => {
|
248
|
+
if (specifier.type === "ImportDefaultSpecifier") {
|
249
|
+
set.add("default");
|
250
|
+
} else if (specifier.type === "ImportNamespaceSpecifier") {
|
251
|
+
set.add("*");
|
252
|
+
} else if (specifier.imported) {
|
253
|
+
set.add(specifier.imported.name);
|
254
|
+
} else if (specifier.local) {
|
255
|
+
set.add(specifier.local.name);
|
253
256
|
}
|
257
|
+
return set;
|
258
|
+
}, new Set()) : new Set();
|
254
259
|
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
260
|
+
if (isRestrictedForEverythingImported(importSource, importNames)) {
|
261
|
+
reportPathForEverythingImported(importSource, node);
|
262
|
+
}
|
263
|
+
|
264
|
+
if (isRestrictedPath(importSource, importNames)) {
|
265
|
+
reportPath(node);
|
266
|
+
}
|
267
|
+
if (isRestrictedPattern(importSource)) {
|
268
|
+
reportPathForPatterns(node);
|
261
269
|
}
|
270
|
+
}
|
271
|
+
|
272
|
+
return {
|
273
|
+
ImportDeclaration: checkNode,
|
274
|
+
ExportNamedDeclaration(node) {
|
275
|
+
if (node.source) {
|
276
|
+
checkNode(node);
|
277
|
+
}
|
278
|
+
},
|
279
|
+
ExportAllDeclaration: checkNode
|
262
280
|
};
|
263
281
|
}
|
264
282
|
};
|
@@ -14,6 +14,8 @@ const message = "Redundant use of `await` on a return value.";
|
|
14
14
|
|
15
15
|
module.exports = {
|
16
16
|
meta: {
|
17
|
+
type: "suggestion",
|
18
|
+
|
17
19
|
docs: {
|
18
20
|
description: "disallow unnecessary `return await`",
|
19
21
|
category: "Best Practices",
|
@@ -22,7 +24,9 @@ module.exports = {
|
|
22
24
|
|
23
25
|
url: "https://eslint.org/docs/rules/no-return-await"
|
24
26
|
},
|
27
|
+
|
25
28
|
fixable: null,
|
29
|
+
|
26
30
|
schema: [
|
27
31
|
]
|
28
32
|
},
|