eslint 8.3.0 → 8.6.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/README.md +6 -16
- package/conf/globals.js +144 -0
- package/lib/cli.js +1 -1
- package/lib/config/default-config.js +11 -2
- package/lib/config/flat-config-array.js +2 -2
- package/lib/config/flat-config-helpers.js +67 -0
- package/lib/config/flat-config-schema.js +13 -8
- package/lib/config/rule-validator.js +28 -27
- package/lib/eslint/eslint.js +11 -3
- package/lib/linter/apply-disable-directives.js +20 -16
- package/lib/linter/linter.js +463 -49
- package/lib/options.js +6 -6
- package/lib/rule-tester/rule-tester.js +14 -0
- package/lib/rules/accessor-pairs.js +1 -0
- package/lib/rules/array-bracket-newline.js +1 -0
- package/lib/rules/array-bracket-spacing.js +1 -0
- package/lib/rules/array-callback-return.js +1 -0
- package/lib/rules/array-element-newline.js +1 -0
- package/lib/rules/arrow-body-style.js +1 -0
- package/lib/rules/arrow-parens.js +1 -0
- package/lib/rules/arrow-spacing.js +1 -0
- package/lib/rules/block-scoped-var.js +1 -0
- package/lib/rules/block-spacing.js +1 -0
- package/lib/rules/brace-style.js +1 -0
- package/lib/rules/callback-return.js +1 -0
- package/lib/rules/camelcase.js +1 -0
- package/lib/rules/capitalized-comments.js +1 -0
- package/lib/rules/class-methods-use-this.js +1 -0
- package/lib/rules/comma-dangle.js +1 -0
- package/lib/rules/comma-spacing.js +1 -0
- package/lib/rules/comma-style.js +1 -0
- package/lib/rules/complexity.js +1 -0
- package/lib/rules/computed-property-spacing.js +1 -0
- package/lib/rules/consistent-return.js +1 -0
- package/lib/rules/consistent-this.js +1 -0
- package/lib/rules/constructor-super.js +1 -0
- package/lib/rules/curly.js +1 -0
- package/lib/rules/default-case-last.js +1 -0
- package/lib/rules/default-case.js +1 -0
- package/lib/rules/default-param-last.js +1 -0
- package/lib/rules/dot-location.js +1 -0
- package/lib/rules/dot-notation.js +1 -0
- package/lib/rules/eol-last.js +1 -0
- package/lib/rules/eqeqeq.js +1 -0
- package/lib/rules/for-direction.js +1 -0
- package/lib/rules/func-call-spacing.js +1 -0
- package/lib/rules/func-name-matching.js +1 -0
- package/lib/rules/func-names.js +1 -0
- package/lib/rules/func-style.js +1 -0
- package/lib/rules/function-call-argument-newline.js +1 -0
- package/lib/rules/function-paren-newline.js +1 -0
- package/lib/rules/generator-star-spacing.js +1 -0
- package/lib/rules/getter-return.js +1 -0
- package/lib/rules/global-require.js +1 -0
- package/lib/rules/grouped-accessor-pairs.js +1 -0
- package/lib/rules/guard-for-in.js +1 -0
- package/lib/rules/handle-callback-err.js +1 -0
- package/lib/rules/id-blacklist.js +1 -0
- package/lib/rules/id-denylist.js +1 -0
- package/lib/rules/id-length.js +1 -0
- package/lib/rules/id-match.js +35 -0
- package/lib/rules/implicit-arrow-linebreak.js +1 -0
- package/lib/rules/indent-legacy.js +1 -0
- package/lib/rules/indent.js +1 -0
- package/lib/rules/index.js +1 -0
- package/lib/rules/init-declarations.js +1 -0
- package/lib/rules/jsx-quotes.js +1 -0
- package/lib/rules/key-spacing.js +1 -0
- package/lib/rules/keyword-spacing.js +1 -0
- package/lib/rules/line-comment-position.js +1 -0
- package/lib/rules/linebreak-style.js +1 -0
- package/lib/rules/lines-around-comment.js +1 -0
- package/lib/rules/lines-around-directive.js +1 -0
- package/lib/rules/lines-between-class-members.js +1 -0
- package/lib/rules/max-classes-per-file.js +1 -0
- package/lib/rules/max-depth.js +1 -0
- package/lib/rules/max-len.js +1 -0
- package/lib/rules/max-lines-per-function.js +1 -0
- package/lib/rules/max-lines.js +1 -0
- package/lib/rules/max-nested-callbacks.js +1 -0
- package/lib/rules/max-params.js +1 -0
- package/lib/rules/max-statements-per-line.js +1 -0
- package/lib/rules/max-statements.js +1 -0
- package/lib/rules/multiline-comment-style.js +1 -0
- package/lib/rules/multiline-ternary.js +1 -0
- package/lib/rules/new-cap.js +1 -0
- package/lib/rules/new-parens.js +1 -0
- package/lib/rules/newline-after-var.js +1 -0
- package/lib/rules/newline-before-return.js +1 -0
- package/lib/rules/newline-per-chained-call.js +1 -0
- package/lib/rules/no-alert.js +1 -0
- package/lib/rules/no-array-constructor.js +1 -0
- package/lib/rules/no-async-promise-executor.js +1 -0
- package/lib/rules/no-await-in-loop.js +1 -0
- package/lib/rules/no-bitwise.js +1 -0
- package/lib/rules/no-buffer-constructor.js +1 -0
- package/lib/rules/no-caller.js +1 -0
- package/lib/rules/no-case-declarations.js +1 -0
- package/lib/rules/no-catch-shadow.js +1 -0
- package/lib/rules/no-class-assign.js +1 -0
- package/lib/rules/no-compare-neg-zero.js +1 -0
- package/lib/rules/no-cond-assign.js +1 -0
- package/lib/rules/no-confusing-arrow.js +1 -0
- package/lib/rules/no-console.js +1 -0
- package/lib/rules/no-const-assign.js +1 -0
- package/lib/rules/no-constant-condition.js +4 -1
- package/lib/rules/no-constructor-return.js +1 -0
- package/lib/rules/no-continue.js +1 -0
- package/lib/rules/no-control-regex.js +1 -0
- package/lib/rules/no-debugger.js +1 -0
- package/lib/rules/no-delete-var.js +1 -0
- package/lib/rules/no-div-regex.js +1 -0
- package/lib/rules/no-dupe-args.js +1 -0
- package/lib/rules/no-dupe-class-members.js +1 -0
- package/lib/rules/no-dupe-else-if.js +1 -0
- package/lib/rules/no-dupe-keys.js +1 -0
- package/lib/rules/no-duplicate-case.js +1 -0
- package/lib/rules/no-duplicate-imports.js +1 -0
- package/lib/rules/no-else-return.js +1 -0
- package/lib/rules/no-empty-character-class.js +1 -0
- package/lib/rules/no-empty-function.js +1 -0
- package/lib/rules/no-empty-pattern.js +1 -0
- package/lib/rules/no-empty.js +1 -0
- package/lib/rules/no-eq-null.js +1 -0
- package/lib/rules/no-eval.js +1 -0
- package/lib/rules/no-ex-assign.js +1 -0
- package/lib/rules/no-extend-native.js +1 -0
- package/lib/rules/no-extra-bind.js +1 -0
- package/lib/rules/no-extra-boolean-cast.js +1 -0
- package/lib/rules/no-extra-label.js +1 -0
- package/lib/rules/no-extra-parens.js +1 -0
- package/lib/rules/no-extra-semi.js +1 -0
- package/lib/rules/no-fallthrough.js +1 -0
- package/lib/rules/no-floating-decimal.js +1 -0
- package/lib/rules/no-func-assign.js +1 -0
- package/lib/rules/no-global-assign.js +1 -0
- package/lib/rules/no-implicit-coercion.js +1 -0
- package/lib/rules/no-implicit-globals.js +1 -0
- package/lib/rules/no-implied-eval.js +1 -0
- package/lib/rules/no-import-assign.js +1 -0
- package/lib/rules/no-inline-comments.js +1 -0
- package/lib/rules/no-inner-declarations.js +1 -0
- package/lib/rules/no-invalid-regexp.js +1 -0
- package/lib/rules/no-invalid-this.js +1 -0
- package/lib/rules/no-irregular-whitespace.js +1 -0
- package/lib/rules/no-iterator.js +1 -0
- package/lib/rules/no-label-var.js +1 -0
- package/lib/rules/no-labels.js +1 -0
- package/lib/rules/no-lone-blocks.js +1 -0
- package/lib/rules/no-lonely-if.js +1 -0
- package/lib/rules/no-loop-func.js +1 -0
- package/lib/rules/no-loss-of-precision.js +1 -0
- package/lib/rules/no-magic-numbers.js +1 -0
- package/lib/rules/no-misleading-character-class.js +1 -0
- package/lib/rules/no-mixed-operators.js +1 -0
- package/lib/rules/no-mixed-requires.js +1 -0
- package/lib/rules/no-mixed-spaces-and-tabs.js +1 -0
- package/lib/rules/no-multi-assign.js +1 -0
- package/lib/rules/no-multi-spaces.js +1 -0
- package/lib/rules/no-multi-str.js +1 -0
- package/lib/rules/no-multiple-empty-lines.js +1 -0
- package/lib/rules/no-native-reassign.js +1 -0
- package/lib/rules/no-negated-condition.js +1 -0
- package/lib/rules/no-negated-in-lhs.js +1 -0
- package/lib/rules/no-nested-ternary.js +1 -0
- package/lib/rules/no-new-func.js +1 -0
- package/lib/rules/no-new-object.js +1 -0
- package/lib/rules/no-new-require.js +1 -0
- package/lib/rules/no-new-symbol.js +1 -0
- package/lib/rules/no-new-wrappers.js +1 -0
- package/lib/rules/no-new.js +1 -0
- package/lib/rules/no-nonoctal-decimal-escape.js +1 -0
- package/lib/rules/no-obj-calls.js +1 -0
- package/lib/rules/no-octal-escape.js +1 -0
- package/lib/rules/no-octal.js +1 -0
- package/lib/rules/no-param-reassign.js +1 -0
- package/lib/rules/no-path-concat.js +1 -0
- package/lib/rules/no-plusplus.js +1 -0
- package/lib/rules/no-process-env.js +1 -0
- package/lib/rules/no-process-exit.js +1 -0
- package/lib/rules/no-promise-executor-return.js +1 -0
- package/lib/rules/no-proto.js +1 -0
- package/lib/rules/no-prototype-builtins.js +1 -0
- package/lib/rules/no-redeclare.js +1 -0
- package/lib/rules/no-regex-spaces.js +1 -0
- package/lib/rules/no-restricted-exports.js +1 -0
- package/lib/rules/no-restricted-globals.js +1 -0
- package/lib/rules/no-restricted-imports.js +1 -0
- package/lib/rules/no-restricted-modules.js +1 -0
- package/lib/rules/no-restricted-properties.js +1 -0
- package/lib/rules/no-restricted-syntax.js +1 -0
- package/lib/rules/no-return-assign.js +1 -0
- package/lib/rules/no-return-await.js +1 -0
- package/lib/rules/no-script-url.js +1 -0
- package/lib/rules/no-self-assign.js +2 -1
- package/lib/rules/no-self-compare.js +1 -0
- package/lib/rules/no-sequences.js +1 -0
- package/lib/rules/no-setter-return.js +1 -0
- package/lib/rules/no-shadow-restricted-names.js +1 -0
- package/lib/rules/no-shadow.js +1 -0
- package/lib/rules/no-spaced-func.js +1 -0
- package/lib/rules/no-sparse-arrays.js +1 -0
- package/lib/rules/no-sync.js +1 -0
- package/lib/rules/no-tabs.js +1 -0
- package/lib/rules/no-template-curly-in-string.js +1 -0
- package/lib/rules/no-ternary.js +1 -0
- package/lib/rules/no-this-before-super.js +1 -0
- package/lib/rules/no-throw-literal.js +1 -0
- package/lib/rules/no-trailing-spaces.js +1 -0
- package/lib/rules/no-undef-init.js +1 -0
- package/lib/rules/no-undef.js +1 -0
- package/lib/rules/no-undefined.js +1 -0
- package/lib/rules/no-underscore-dangle.js +1 -0
- package/lib/rules/no-unexpected-multiline.js +1 -0
- package/lib/rules/no-unmodified-loop-condition.js +1 -0
- package/lib/rules/no-unneeded-ternary.js +1 -0
- package/lib/rules/no-unreachable-loop.js +1 -0
- package/lib/rules/no-unreachable.js +1 -0
- package/lib/rules/no-unsafe-finally.js +1 -0
- package/lib/rules/no-unsafe-negation.js +1 -0
- package/lib/rules/no-unsafe-optional-chaining.js +1 -0
- package/lib/rules/no-unused-expressions.js +1 -0
- package/lib/rules/no-unused-labels.js +1 -0
- package/lib/rules/no-unused-private-class-members.js +1 -0
- package/lib/rules/no-unused-vars.js +1 -0
- package/lib/rules/no-use-before-define.js +1 -0
- package/lib/rules/no-useless-backreference.js +1 -0
- package/lib/rules/no-useless-call.js +1 -0
- package/lib/rules/no-useless-catch.js +1 -0
- package/lib/rules/no-useless-computed-key.js +1 -0
- package/lib/rules/no-useless-concat.js +1 -0
- package/lib/rules/no-useless-constructor.js +1 -0
- package/lib/rules/no-useless-escape.js +1 -0
- package/lib/rules/no-useless-rename.js +1 -0
- package/lib/rules/no-useless-return.js +1 -0
- package/lib/rules/no-var.js +1 -0
- package/lib/rules/no-void.js +1 -0
- package/lib/rules/no-warning-comments.js +1 -0
- package/lib/rules/no-whitespace-before-property.js +1 -0
- package/lib/rules/no-with.js +1 -0
- package/lib/rules/nonblock-statement-body-position.js +1 -0
- package/lib/rules/object-curly-newline.js +1 -0
- package/lib/rules/object-curly-spacing.js +1 -0
- package/lib/rules/object-property-newline.js +1 -0
- package/lib/rules/object-shorthand.js +1 -0
- package/lib/rules/one-var-declaration-per-line.js +1 -0
- package/lib/rules/one-var.js +1 -0
- package/lib/rules/operator-assignment.js +1 -0
- package/lib/rules/operator-linebreak.js +1 -0
- package/lib/rules/padded-blocks.js +1 -0
- package/lib/rules/padding-line-between-statements.js +1 -0
- package/lib/rules/prefer-arrow-callback.js +1 -0
- package/lib/rules/prefer-const.js +1 -0
- package/lib/rules/prefer-destructuring.js +1 -0
- package/lib/rules/prefer-exponentiation-operator.js +1 -0
- package/lib/rules/prefer-named-capture-group.js +1 -0
- package/lib/rules/prefer-numeric-literals.js +1 -0
- package/lib/rules/prefer-object-has-own.js +112 -0
- package/lib/rules/prefer-object-spread.js +1 -0
- package/lib/rules/prefer-promise-reject-errors.js +1 -0
- package/lib/rules/prefer-reflect.js +1 -0
- package/lib/rules/prefer-regex-literals.js +218 -1
- package/lib/rules/prefer-rest-params.js +1 -0
- package/lib/rules/prefer-spread.js +1 -0
- package/lib/rules/prefer-template.js +2 -1
- package/lib/rules/quote-props.js +1 -0
- package/lib/rules/quotes.js +1 -0
- package/lib/rules/radix.js +1 -0
- package/lib/rules/require-atomic-updates.js +1 -0
- package/lib/rules/require-await.js +1 -0
- package/lib/rules/require-jsdoc.js +1 -0
- package/lib/rules/require-unicode-regexp.js +1 -0
- package/lib/rules/require-yield.js +1 -0
- package/lib/rules/rest-spread-spacing.js +1 -0
- package/lib/rules/semi-spacing.js +1 -0
- package/lib/rules/semi-style.js +1 -0
- package/lib/rules/semi.js +1 -0
- package/lib/rules/sort-imports.js +1 -0
- package/lib/rules/sort-keys.js +1 -0
- package/lib/rules/sort-vars.js +1 -0
- package/lib/rules/space-before-blocks.js +1 -0
- package/lib/rules/space-before-function-paren.js +1 -0
- package/lib/rules/space-in-parens.js +1 -0
- package/lib/rules/space-infix-ops.js +1 -0
- package/lib/rules/space-unary-ops.js +1 -0
- package/lib/rules/spaced-comment.js +1 -0
- package/lib/rules/strict.js +1 -0
- package/lib/rules/switch-colon-spacing.js +1 -0
- package/lib/rules/symbol-description.js +1 -0
- package/lib/rules/template-curly-spacing.js +1 -0
- package/lib/rules/template-tag-spacing.js +1 -0
- package/lib/rules/unicode-bom.js +1 -0
- package/lib/rules/use-isnan.js +1 -0
- package/lib/rules/valid-jsdoc.js +1 -0
- package/lib/rules/valid-typeof.js +1 -0
- package/lib/rules/vars-on-top.js +1 -0
- package/lib/rules/wrap-iife.js +1 -0
- package/lib/rules/wrap-regex.js +1 -0
- package/lib/rules/yield-star-spacing.js +1 -0
- package/lib/rules/yoda.js +1 -0
- package/lib/shared/types.js +10 -0
- package/package.json +7 -6
package/lib/rules/no-tabs.js
CHANGED
package/lib/rules/no-ternary.js
CHANGED
package/lib/rules/no-undef.js
CHANGED
@@ -156,6 +156,7 @@ function updateModifiedFlag(conditions, modifiers) {
|
|
156
156
|
// Rule Definition
|
157
157
|
//------------------------------------------------------------------------------
|
158
158
|
|
159
|
+
/** @type {import('../shared/types').Rule} */
|
159
160
|
module.exports = {
|
160
161
|
meta: {
|
161
162
|
type: "problem",
|
@@ -23,6 +23,7 @@ const OR_PRECEDENCE = astUtils.getPrecedence({ type: "LogicalExpression", operat
|
|
23
23
|
// Rule Definition
|
24
24
|
//------------------------------------------------------------------------------
|
25
25
|
|
26
|
+
/** @type {import('../shared/types').Rule} */
|
26
27
|
module.exports = {
|
27
28
|
meta: {
|
28
29
|
type: "suggestion",
|
@@ -18,6 +18,7 @@ const SENTINEL_NODE_TYPE_CONTINUE = /^(?:Program|(?:Function|Class)(?:Declaratio
|
|
18
18
|
// Rule Definition
|
19
19
|
//------------------------------------------------------------------------------
|
20
20
|
|
21
|
+
/** @type {import('../shared/types').Rule} */
|
21
22
|
module.exports = {
|
22
23
|
meta: {
|
23
24
|
type: "problem",
|
@@ -218,6 +218,7 @@ function isEvaluatedDuringInitialization(reference) {
|
|
218
218
|
// Rule Definition
|
219
219
|
//------------------------------------------------------------------------------
|
220
220
|
|
221
|
+
/** @type {import('../shared/types').Rule} */
|
221
222
|
module.exports = {
|
222
223
|
meta: {
|
223
224
|
type: "problem",
|
@@ -49,6 +49,7 @@ function isValidThisArg(expectedThis, thisArg, sourceCode) {
|
|
49
49
|
// Rule Definition
|
50
50
|
//------------------------------------------------------------------------------
|
51
51
|
|
52
|
+
/** @type {import('../shared/types').Rule} */
|
52
53
|
module.exports = {
|
53
54
|
meta: {
|
54
55
|
type: "suggestion",
|
@@ -132,6 +132,7 @@ function isRedundantSuperCall(body, ctorParams) {
|
|
132
132
|
// Rule Definition
|
133
133
|
//------------------------------------------------------------------------------
|
134
134
|
|
135
|
+
/** @type {import('../shared/types').Rule} */
|
135
136
|
module.exports = {
|
136
137
|
meta: {
|
137
138
|
type: "suggestion",
|
package/lib/rules/no-var.js
CHANGED
@@ -179,6 +179,7 @@ function hasNameDisallowedForLetDeclarations(variable) {
|
|
179
179
|
// Rule Definition
|
180
180
|
//------------------------------------------------------------------------------
|
181
181
|
|
182
|
+
/** @type {import('../shared/types').Rule} */
|
182
183
|
module.exports = {
|
183
184
|
meta: {
|
184
185
|
type: "suggestion",
|
package/lib/rules/no-void.js
CHANGED
package/lib/rules/no-with.js
CHANGED
@@ -144,6 +144,7 @@ function areLineBreaksRequired(node, options, first, last) {
|
|
144
144
|
// Rule Definition
|
145
145
|
//------------------------------------------------------------------------------
|
146
146
|
|
147
|
+
/** @type {import('../shared/types').Rule} */
|
147
148
|
module.exports = {
|
148
149
|
meta: {
|
149
150
|
type: "layout",
|
@@ -22,6 +22,7 @@ const astUtils = require("./utils/ast-utils");
|
|
22
22
|
//------------------------------------------------------------------------------
|
23
23
|
// Rule Definition
|
24
24
|
//------------------------------------------------------------------------------
|
25
|
+
/** @type {import('../shared/types').Rule} */
|
25
26
|
module.exports = {
|
26
27
|
meta: {
|
27
28
|
type: "suggestion",
|
package/lib/rules/one-var.js
CHANGED
@@ -145,6 +145,7 @@ function hasDuplicateParams(paramsList) {
|
|
145
145
|
// Rule Definition
|
146
146
|
//------------------------------------------------------------------------------
|
147
147
|
|
148
|
+
/** @type {import('../shared/types').Rule} */
|
148
149
|
module.exports = {
|
149
150
|
meta: {
|
150
151
|
type: "suggestion",
|
@@ -326,6 +326,7 @@ function findUp(node, type, shouldStop) {
|
|
326
326
|
// Rule Definition
|
327
327
|
//------------------------------------------------------------------------------
|
328
328
|
|
329
|
+
/** @type {import('../shared/types').Rule} */
|
329
330
|
module.exports = {
|
330
331
|
meta: {
|
331
332
|
type: "suggestion",
|
@@ -20,6 +20,7 @@ const PRECEDENCE_OF_ASSIGNMENT_EXPR = astUtils.getPrecedence({ type: "Assignment
|
|
20
20
|
// Rule Definition
|
21
21
|
//------------------------------------------------------------------------------
|
22
22
|
|
23
|
+
/** @type {import('../shared/types').Rule} */
|
23
24
|
module.exports = {
|
24
25
|
meta: {
|
25
26
|
type: "suggestion",
|
@@ -84,6 +84,7 @@ function parenthesizeIfShould(text, shouldParenthesize) {
|
|
84
84
|
// Rule Definition
|
85
85
|
//------------------------------------------------------------------------------
|
86
86
|
|
87
|
+
/** @type {import('../shared/types').Rule} */
|
87
88
|
module.exports = {
|
88
89
|
meta: {
|
89
90
|
type: "suggestion",
|
@@ -0,0 +1,112 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview Prefers Object.hasOwn() instead of Object.prototype.hasOwnProperty.call()
|
3
|
+
* @author Nitin Kumar
|
4
|
+
* @author Gautam Arora
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
//------------------------------------------------------------------------------
|
10
|
+
// Requirements
|
11
|
+
//------------------------------------------------------------------------------
|
12
|
+
|
13
|
+
const astUtils = require("./utils/ast-utils");
|
14
|
+
|
15
|
+
//------------------------------------------------------------------------------
|
16
|
+
// Helpers
|
17
|
+
//------------------------------------------------------------------------------
|
18
|
+
|
19
|
+
/**
|
20
|
+
* Checks if the given node is considered to be an access to a property of `Object.prototype`.
|
21
|
+
* @param {ASTNode} node `MemberExpression` node to evaluate.
|
22
|
+
* @returns {boolean} `true` if `node.object` is `Object`, `Object.prototype`, or `{}` (empty 'ObjectExpression' node).
|
23
|
+
*/
|
24
|
+
function hasLeftHandObject(node) {
|
25
|
+
|
26
|
+
/*
|
27
|
+
* ({}).hasOwnProperty.call(obj, prop) - `true`
|
28
|
+
* ({ foo }.hasOwnProperty.call(obj, prop)) - `false`, object literal should be empty
|
29
|
+
*/
|
30
|
+
if (node.object.type === "ObjectExpression" && node.object.properties.length === 0) {
|
31
|
+
return true;
|
32
|
+
}
|
33
|
+
|
34
|
+
const objectNodeToCheck = node.object.type === "MemberExpression" && astUtils.getStaticPropertyName(node.object) === "prototype" ? node.object.object : node.object;
|
35
|
+
|
36
|
+
if (objectNodeToCheck.type === "Identifier" && objectNodeToCheck.name === "Object") {
|
37
|
+
return true;
|
38
|
+
}
|
39
|
+
|
40
|
+
return false;
|
41
|
+
}
|
42
|
+
|
43
|
+
//------------------------------------------------------------------------------
|
44
|
+
// Rule Definition
|
45
|
+
//------------------------------------------------------------------------------
|
46
|
+
|
47
|
+
/** @type {import('../shared/types').Rule} */
|
48
|
+
module.exports = {
|
49
|
+
meta: {
|
50
|
+
type: "suggestion",
|
51
|
+
docs: {
|
52
|
+
description:
|
53
|
+
"disallow use of `Object.prototype.hasOwnProperty.call()` and prefer use of `Object.hasOwn()`",
|
54
|
+
recommended: false,
|
55
|
+
url: "https://eslint.org/docs/rules/prefer-object-has-own"
|
56
|
+
},
|
57
|
+
schema: [],
|
58
|
+
messages: {
|
59
|
+
useHasOwn: "Use 'Object.hasOwn()' instead of 'Object.prototype.hasOwnProperty.call()'."
|
60
|
+
},
|
61
|
+
fixable: "code"
|
62
|
+
},
|
63
|
+
create(context) {
|
64
|
+
return {
|
65
|
+
CallExpression(node) {
|
66
|
+
if (!(node.callee.type === "MemberExpression" && node.callee.object.type === "MemberExpression")) {
|
67
|
+
return;
|
68
|
+
}
|
69
|
+
|
70
|
+
const calleePropertyName = astUtils.getStaticPropertyName(node.callee);
|
71
|
+
const objectPropertyName = astUtils.getStaticPropertyName(node.callee.object);
|
72
|
+
const isObject = hasLeftHandObject(node.callee.object);
|
73
|
+
|
74
|
+
// check `Object` scope
|
75
|
+
const scope = context.getScope();
|
76
|
+
const variable = astUtils.getVariableByName(scope, "Object");
|
77
|
+
|
78
|
+
if (
|
79
|
+
calleePropertyName === "call" &&
|
80
|
+
objectPropertyName === "hasOwnProperty" &&
|
81
|
+
isObject &&
|
82
|
+
variable && variable.scope.type === "global"
|
83
|
+
) {
|
84
|
+
context.report({
|
85
|
+
node,
|
86
|
+
messageId: "useHasOwn",
|
87
|
+
fix(fixer) {
|
88
|
+
const sourceCode = context.getSourceCode();
|
89
|
+
|
90
|
+
if (sourceCode.getCommentsInside(node.callee).length > 0) {
|
91
|
+
return null;
|
92
|
+
}
|
93
|
+
|
94
|
+
const tokenJustBeforeNode = sourceCode.getTokenBefore(node.callee, { includeComments: true });
|
95
|
+
|
96
|
+
// for https://github.com/eslint/eslint/pull/15346#issuecomment-991417335
|
97
|
+
if (
|
98
|
+
tokenJustBeforeNode &&
|
99
|
+
tokenJustBeforeNode.range[1] === node.callee.range[0] &&
|
100
|
+
!astUtils.canTokensBeAdjacent(tokenJustBeforeNode, "Object.hasOwn")
|
101
|
+
) {
|
102
|
+
return fixer.replaceText(node.callee, " Object.hasOwn");
|
103
|
+
}
|
104
|
+
|
105
|
+
return fixer.replaceText(node.callee, "Object.hasOwn");
|
106
|
+
}
|
107
|
+
});
|
108
|
+
}
|
109
|
+
}
|
110
|
+
};
|
111
|
+
}
|
112
|
+
};
|