From c53b4eb9ba5f14fa5281222cd2ceed26b4a5c5d5 Mon Sep 17 00:00:00 2001 From: weiren Date: Wed, 18 Dec 2024 17:44:33 +0800 Subject: [PATCH] refactor: add utils.getSourceCode(), utils.getScope(), utils.getparserServices(), utils.getFilename() --- lib/rules/fixer-return.js | 7 +++---- lib/rules/meta-property-ordering.js | 5 +++-- lib/rules/no-deprecated-context-methods.js | 2 +- lib/rules/no-deprecated-report-api.js | 2 +- lib/rules/no-identical-tests.js | 2 +- lib/rules/no-meta-schema-default.js | 2 +- lib/rules/no-missing-message-ids.js | 4 ++-- lib/rules/no-missing-placeholders.js | 4 ++-- lib/rules/no-only-tests.js | 3 +-- lib/rules/no-property-in-node.js | 4 +++- lib/rules/no-unused-message-ids.js | 6 +++--- lib/rules/no-unused-placeholders.js | 4 ++-- lib/rules/no-useless-token-range.js | 2 +- lib/rules/prefer-message-ids.js | 4 ++-- lib/rules/prefer-object-rule.js | 2 +- lib/rules/prefer-output-null.js | 2 +- lib/rules/prefer-placeholders.js | 2 +- lib/rules/prefer-replace-text.js | 2 +- lib/rules/report-message-format.js | 6 +++--- lib/rules/require-meta-default-options.js | 2 +- lib/rules/require-meta-docs-description.js | 6 +++--- lib/rules/require-meta-docs-recommended.js | 2 +- lib/rules/require-meta-docs-url.js | 8 ++++---- lib/rules/require-meta-fixable.js | 6 +++--- lib/rules/require-meta-has-suggestions.js | 8 ++++---- lib/rules/require-meta-schema-description.js | 2 +- lib/rules/require-meta-schema.js | 2 +- lib/rules/require-meta-type.js | 6 +++--- lib/rules/test-case-property-ordering.js | 2 +- lib/rules/test-case-shorthand-strings.js | 2 +- lib/utils.js | 21 ++++++++++++++++++++ package.json | 2 +- 32 files changed, 78 insertions(+), 56 deletions(-) diff --git a/lib/rules/fixer-return.js b/lib/rules/fixer-return.js index 0ea7c857..11e7d57f 100644 --- a/lib/rules/fixer-return.js +++ b/lib/rules/fixer-return.js @@ -76,12 +76,11 @@ module.exports = { * @returns {boolean} */ function isFix(node) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: use context.sourceCode when dropping eslint < v9 if (node.type === 'ArrayExpression' && node.elements.length === 0) { // An empty array is not a fix. return false; } - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < 9.0.0 + const scope = utils.getScope(context); const staticValue = getStaticValue(node, scope); if (!staticValue) { // If we can't find a static value, assume it's a real fix value. @@ -99,7 +98,7 @@ module.exports = { return { Program(ast) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); contextIdentifiers = utils.getContextIdentifiers( sourceCode.scopeManager, ast, @@ -149,7 +148,7 @@ module.exports = { // Ensure the current (arrow) fixer function returned a fix. 'ArrowFunctionExpression:exit'(node) { if (funcInfo.shouldCheck) { - const sourceCode = context.sourceCode || context.getSourceCode(); + const sourceCode = utils.getSourceCode(context); const loc = sourceCode.getTokenBefore(node.body).loc; // Show violation on arrow (=>). if (node.expression) { // When the return is implied (no curly braces around the body), we have to check the single body node directly. diff --git a/lib/rules/meta-property-ordering.js b/lib/rules/meta-property-ordering.js index 04142237..27e29218 100644 --- a/lib/rules/meta-property-ordering.js +++ b/lib/rules/meta-property-ordering.js @@ -4,7 +4,8 @@ 'use strict'; -const { getKeyName, getRuleInfo } = require('../utils'); +const utils = require('../utils'); +const { getKeyName, getRuleInfo } = utils; const defaultOrder = [ 'type', @@ -48,7 +49,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = getRuleInfo(sourceCode); if (!ruleInfo) { return {}; diff --git a/lib/rules/no-deprecated-context-methods.js b/lib/rules/no-deprecated-context-methods.js index e72580ca..c4f6134b 100644 --- a/lib/rules/no-deprecated-context-methods.js +++ b/lib/rules/no-deprecated-context-methods.js @@ -54,7 +54,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); // ---------------------------------------------------------------------- // Public diff --git a/lib/rules/no-deprecated-report-api.js b/lib/rules/no-deprecated-report-api.js index 266cb71d..eb0c07c2 100644 --- a/lib/rules/no-deprecated-report-api.js +++ b/lib/rules/no-deprecated-report-api.js @@ -30,7 +30,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); let contextIdentifiers; // ---------------------------------------------------------------------- diff --git a/lib/rules/no-identical-tests.js b/lib/rules/no-identical-tests.js index c0744fad..c7c5867f 100644 --- a/lib/rules/no-identical-tests.js +++ b/lib/rules/no-identical-tests.js @@ -32,7 +32,7 @@ module.exports = { // ---------------------------------------------------------------------- // Public // ---------------------------------------------------------------------- - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); // ---------------------------------------------------------------------- // Helpers diff --git a/lib/rules/no-meta-schema-default.js b/lib/rules/no-meta-schema-default.js index 171d55e6..ccba978a 100644 --- a/lib/rules/no-meta-schema-default.js +++ b/lib/rules/no-meta-schema-default.js @@ -25,7 +25,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { diff --git a/lib/rules/no-missing-message-ids.js b/lib/rules/no-missing-message-ids.js index 1066b855..0bc2d9ed 100644 --- a/lib/rules/no-missing-message-ids.js +++ b/lib/rules/no-missing-message-ids.js @@ -26,7 +26,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { @@ -48,7 +48,7 @@ module.exports = { }, CallExpression(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < 9.0.0 + const scope = utils.getScope(context); // Check for messageId properties used in known calls to context.report(); if ( node.callee.type === 'MemberExpression' && diff --git a/lib/rules/no-missing-placeholders.js b/lib/rules/no-missing-placeholders.js index 364c340f..996e8004 100644 --- a/lib/rules/no-missing-placeholders.js +++ b/lib/rules/no-missing-placeholders.js @@ -31,7 +31,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; let contextIdentifiers; @@ -48,7 +48,7 @@ module.exports = { contextIdentifiers = utils.getContextIdentifiers(scopeManager, ast); }, CallExpression(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < 9.0.0 + const scope = utils.getScope(context); if ( node.callee.type === 'MemberExpression' && contextIdentifiers.has(node.callee.object) && diff --git a/lib/rules/no-only-tests.js b/lib/rules/no-only-tests.js index 816fedd1..3aa267d2 100644 --- a/lib/rules/no-only-tests.js +++ b/lib/rules/no-only-tests.js @@ -51,8 +51,7 @@ module.exports = { { messageId: 'removeOnly', *fix(fixer) { - const sourceCode = - context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const tokenBefore = sourceCode.getTokenBefore(onlyProperty); diff --git a/lib/rules/no-property-in-node.js b/lib/rules/no-property-in-node.js index ace20884..f21e0060 100644 --- a/lib/rules/no-property-in-node.js +++ b/lib/rules/no-property-in-node.js @@ -1,5 +1,7 @@ 'use strict'; +const utils = require('../utils'); + const defaultTypedNodeSourceFileTesters = [ /@types[/\\]estree[/\\]index\.d\.ts/, /@typescript-eslint[/\\]types[/\\]dist[/\\]generated[/\\]ast-spec\.d\.ts/, @@ -88,7 +90,7 @@ module.exports = { 'BinaryExpression[operator=in]'(node) { // TODO: Switch this to ESLintUtils.getParserServices with typescript-eslint@>=6 // https://github.com/eslint-community/eslint-plugin-eslint-plugin/issues/269 - const services = (context.sourceCode || context).parserServices; + const services = utils.getparserServices(context); if (!services.program) { throw new Error( 'You have used a rule which requires parserServices to be generated. You must therefore provide a value for the "parserOptions.project" property for @typescript-eslint/parser.', diff --git a/lib/rules/no-unused-message-ids.js b/lib/rules/no-unused-message-ids.js index 978fad10..69036140 100644 --- a/lib/rules/no-unused-message-ids.js +++ b/lib/rules/no-unused-message-ids.js @@ -24,7 +24,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { @@ -47,7 +47,7 @@ module.exports = { contextIdentifiers = utils.getContextIdentifiers(scopeManager, ast); }, - 'Program:exit'(ast) { + 'Program:exit'() { if (hasSeenUnknownMessageId || !hasSeenViolationReport) { /* Bail out when the rule is likely to have false positives. @@ -57,7 +57,7 @@ module.exports = { return; } - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < 9.0.0 + const scope = utils.getScope(context); const messageIdNodesUnused = messageIdNodes.filter( (node) => !messageIdsUsed.has(utils.getKeyName(node, scope)), diff --git a/lib/rules/no-unused-placeholders.js b/lib/rules/no-unused-placeholders.js index ca95c952..d7169c9a 100644 --- a/lib/rules/no-unused-placeholders.js +++ b/lib/rules/no-unused-placeholders.js @@ -31,7 +31,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; let contextIdentifiers; @@ -47,7 +47,7 @@ module.exports = { contextIdentifiers = utils.getContextIdentifiers(scopeManager, ast); }, CallExpression(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < 9.0.0 + const scope = utils.getScope(context); if ( node.callee.type === 'MemberExpression' && contextIdentifiers.has(node.callee.object) && diff --git a/lib/rules/no-useless-token-range.js b/lib/rules/no-useless-token-range.js index 998c0059..6c6d6214 100644 --- a/lib/rules/no-useless-token-range.js +++ b/lib/rules/no-useless-token-range.js @@ -30,7 +30,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); // ---------------------------------------------------------------------- // Helpers diff --git a/lib/rules/prefer-message-ids.js b/lib/rules/prefer-message-ids.js index 1d932748..cdf66642 100644 --- a/lib/rules/prefer-message-ids.js +++ b/lib/rules/prefer-message-ids.js @@ -29,7 +29,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; @@ -43,7 +43,7 @@ module.exports = { return { Program(ast) { - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + const scope = utils.getScope(context); contextIdentifiers = utils.getContextIdentifiers( sourceCode.scopeManager, ast, diff --git a/lib/rules/prefer-object-rule.js b/lib/rules/prefer-object-rule.js index 4a9351bf..1b0e98f1 100644 --- a/lib/rules/prefer-object-rule.js +++ b/lib/rules/prefer-object-rule.js @@ -32,7 +32,7 @@ module.exports = { // Public // ---------------------------------------------------------------------- - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; diff --git a/lib/rules/prefer-output-null.js b/lib/rules/prefer-output-null.js index d9be111b..4d9e90e5 100644 --- a/lib/rules/prefer-output-null.js +++ b/lib/rules/prefer-output-null.js @@ -35,7 +35,7 @@ module.exports = { // Public // ---------------------------------------------------------------------- - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); return { Program(ast) { diff --git a/lib/rules/prefer-placeholders.js b/lib/rules/prefer-placeholders.js index a1555945..f5c88fc1 100644 --- a/lib/rules/prefer-placeholders.js +++ b/lib/rules/prefer-placeholders.js @@ -33,7 +33,7 @@ module.exports = { create(context) { let contextIdentifiers; - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; // ---------------------------------------------------------------------- diff --git a/lib/rules/prefer-replace-text.js b/lib/rules/prefer-replace-text.js index 100c618c..173cc509 100644 --- a/lib/rules/prefer-replace-text.js +++ b/lib/rules/prefer-replace-text.js @@ -30,7 +30,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); let funcInfo = { upper: null, codePath: null, diff --git a/lib/rules/report-message-format.js b/lib/rules/report-message-format.js index d6d308f5..4fce24b8 100644 --- a/lib/rules/report-message-format.js +++ b/lib/rules/report-message-format.js @@ -63,7 +63,7 @@ module.exports = { } } - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; @@ -75,7 +75,7 @@ module.exports = { return { Program(ast) { - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + const scope = utils.getScope(context); contextIdentifiers = utils.getContextIdentifiers( sourceCode.scopeManager, ast, @@ -103,7 +103,7 @@ module.exports = { .forEach((it) => processMessageNode(it, scope)); }, CallExpression(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + const scope = utils.getScope(context); if ( node.callee.type === 'MemberExpression' && contextIdentifiers.has(node.callee.object) && diff --git a/lib/rules/require-meta-default-options.js b/lib/rules/require-meta-default-options.js index e1166b08..9ac37575 100644 --- a/lib/rules/require-meta-default-options.js +++ b/lib/rules/require-meta-default-options.js @@ -26,7 +26,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { diff --git a/lib/rules/require-meta-docs-description.js b/lib/rules/require-meta-docs-description.js index 0ff4ac38..b3cf5272 100644 --- a/lib/rules/require-meta-docs-description.js +++ b/lib/rules/require-meta-docs-description.js @@ -46,15 +46,15 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; } return { - Program(ast) { - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + Program() { + const scope = utils.getScope(context); const { scopeManager } = sourceCode; const { diff --git a/lib/rules/require-meta-docs-recommended.js b/lib/rules/require-meta-docs-recommended.js index b4ae768b..67851ffc 100644 --- a/lib/rules/require-meta-docs-recommended.js +++ b/lib/rules/require-meta-docs-recommended.js @@ -57,7 +57,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; diff --git a/lib/rules/require-meta-docs-url.js b/lib/rules/require-meta-docs-url.js index 90650626..cb3e35d3 100644 --- a/lib/rules/require-meta-docs-url.js +++ b/lib/rules/require-meta-docs-url.js @@ -55,7 +55,7 @@ module.exports = { */ create(context) { const options = context.options[0] || {}; - const filename = context.filename || context.getFilename(); // TODO: just use context.filename when dropping eslint < v9 + const filename = utils.getFilename(context); const ruleName = filename === '' ? undefined @@ -77,15 +77,15 @@ module.exports = { ); } - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; } return { - Program(ast) { - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + Program() { + const scope = utils.getScope(context); const { scopeManager } = sourceCode; const { diff --git a/lib/rules/require-meta-fixable.js b/lib/rules/require-meta-fixable.js index 76ab6032..e69ca4fc 100644 --- a/lib/rules/require-meta-fixable.js +++ b/lib/rules/require-meta-fixable.js @@ -50,7 +50,7 @@ module.exports = { const catchNoFixerButFixableProperty = context.options[0] && context.options[0].catchNoFixerButFixableProperty; - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); let contextIdentifiers; @@ -79,8 +79,8 @@ module.exports = { usesFixFunctions = true; } }, - 'Program:exit'(ast) { - const scope = sourceCode.getScope?.(ast) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + 'Program:exit'() { + const scope = utils.getScope(context); const metaFixableProp = ruleInfo && utils diff --git a/lib/rules/require-meta-has-suggestions.js b/lib/rules/require-meta-has-suggestions.js index 1759eecf..c8f75b3f 100644 --- a/lib/rules/require-meta-has-suggestions.js +++ b/lib/rules/require-meta-has-suggestions.js @@ -29,7 +29,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { @@ -44,7 +44,7 @@ module.exports = { * @returns {boolean} whether this property should be considered to contain suggestions */ function doesPropertyContainSuggestions(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + const scope = utils.getScope(context); const staticValue = getStaticValue(node.value, scope); if ( !staticValue || @@ -95,8 +95,8 @@ module.exports = { ruleReportsSuggestions = true; } }, - 'Program:exit'(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + 'Program:exit'() { + const scope = utils.getScope(context); const metaNode = ruleInfo && ruleInfo.meta; const hasSuggestionsProperty = utils .evaluateObjectProperties(metaNode, scopeManager) diff --git a/lib/rules/require-meta-schema-description.js b/lib/rules/require-meta-schema-description.js index 4606a489..842d576f 100644 --- a/lib/rules/require-meta-schema-description.js +++ b/lib/rules/require-meta-schema-description.js @@ -25,7 +25,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { diff --git a/lib/rules/require-meta-schema.js b/lib/rules/require-meta-schema.js index f885aa4b..59cf4575 100644 --- a/lib/rules/require-meta-schema.js +++ b/lib/rules/require-meta-schema.js @@ -43,7 +43,7 @@ module.exports = { }, create(context) { - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const { scopeManager } = sourceCode; const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { diff --git a/lib/rules/require-meta-type.js b/lib/rules/require-meta-type.js index 24036071..a6aec027 100644 --- a/lib/rules/require-meta-type.js +++ b/lib/rules/require-meta-type.js @@ -38,15 +38,15 @@ module.exports = { // Public // ---------------------------------------------------------------------- - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); const ruleInfo = utils.getRuleInfo(sourceCode); if (!ruleInfo) { return {}; } return { - Program(node) { - const scope = sourceCode.getScope?.(node) || context.getScope(); // TODO: just use sourceCode.getScope() when we drop support for ESLint < v9.0.0 + Program() { + const scope = utils.getScope(context); const { scopeManager } = sourceCode; const metaNode = ruleInfo.meta; diff --git a/lib/rules/test-case-property-ordering.js b/lib/rules/test-case-property-ordering.js index 6bf7a4a0..f6b4dd2f 100644 --- a/lib/rules/test-case-property-ordering.js +++ b/lib/rules/test-case-property-ordering.js @@ -55,7 +55,7 @@ module.exports = { // Public // ---------------------------------------------------------------------- const order = context.options[0] || defaultOrder; - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); return { Program(ast) { diff --git a/lib/rules/test-case-shorthand-strings.js b/lib/rules/test-case-shorthand-strings.js index 68e813e3..0cf22333 100644 --- a/lib/rules/test-case-shorthand-strings.js +++ b/lib/rules/test-case-shorthand-strings.js @@ -39,7 +39,7 @@ module.exports = { create(context) { const shorthandOption = context.options[0] || 'as-needed'; - const sourceCode = context.sourceCode || context.getSourceCode(); // TODO: just use context.sourceCode when dropping eslint < v9 + const sourceCode = utils.getSourceCode(context); // ---------------------------------------------------------------------- // Helpers diff --git a/lib/utils.js b/lib/utils.js index b049eacb..bc15d2c0 100644 --- a/lib/utils.js +++ b/lib/utils.js @@ -1003,4 +1003,25 @@ module.exports = { return variable?.defs[0]?.type === 'Parameter'; }, + + getSourceCode(context) { + // TODO: remove contet.getSourceCode() when dropping eslint < v9 + return context.sourceCode || context.getSourceCode(); + }, + + getScope(context) { + // TODO: remove contet.getScope() when dropping eslint < v9 + const sourceCode = context.sourceCode || context.getSourceCode(); + return sourceCode.getScope?.(sourceCode.ast) || context.getScope(); + }, + + getparserServices(context) { + // TODO: remove context.parserServices when dropping eslint < v9 + return (context.sourceCode || context).parserServices; + }, + + getFilename(context) { + // TODO: just use context.filename when dropping eslint < v9 + return context.filename || context.getFilename(); + }, }; diff --git a/package.json b/package.json index c29b6e39..5f259b41 100644 --- a/package.json +++ b/package.json @@ -44,7 +44,7 @@ "estraverse": "^5.3.0" }, "nyc": { - "branches": 90, + "branches": 95, "functions": 99, "lines": 99, "statements": 99