77 lines
2.1 KiB
JavaScript
77 lines
2.1 KiB
JavaScript
'use strict';
|
|
const {isOpeningParenToken, isClosingParenToken} = require('@eslint-community/eslint-utils');
|
|
const assertToken = require('./utils/assert-token.js');
|
|
|
|
const MESSAGE_ID_WITH_NAME = 'with-name';
|
|
const MESSAGE_ID_WITHOUT_NAME = 'without-name';
|
|
const messages = {
|
|
[MESSAGE_ID_WITH_NAME]: 'Remove unused catch binding `{{name}}`.',
|
|
[MESSAGE_ID_WITHOUT_NAME]: 'Remove unused catch binding.',
|
|
};
|
|
|
|
const selector = [
|
|
'CatchClause',
|
|
' > ',
|
|
'.param',
|
|
].join('');
|
|
|
|
/** @param {import('eslint').Rule.RuleContext} context */
|
|
const create = context => ({
|
|
[selector](node) {
|
|
const variables = context.getDeclaredVariables(node.parent);
|
|
|
|
if (variables.some(variable => variable.references.length > 0)) {
|
|
return;
|
|
}
|
|
|
|
const {type, name, parent} = node;
|
|
|
|
return {
|
|
node,
|
|
messageId: type === 'Identifier' ? MESSAGE_ID_WITH_NAME : MESSAGE_ID_WITHOUT_NAME,
|
|
data: {name},
|
|
* fix(fixer) {
|
|
const sourceCode = context.getSourceCode();
|
|
const tokenBefore = sourceCode.getTokenBefore(node);
|
|
assertToken(tokenBefore, {
|
|
test: isOpeningParenToken,
|
|
expected: '(',
|
|
ruleId: 'prefer-optional-catch-binding',
|
|
});
|
|
|
|
const tokenAfter = sourceCode.getTokenAfter(node);
|
|
assertToken(tokenAfter, {
|
|
test: isClosingParenToken,
|
|
expected: ')',
|
|
ruleId: 'prefer-optional-catch-binding',
|
|
});
|
|
|
|
yield fixer.remove(tokenBefore);
|
|
yield fixer.remove(node);
|
|
yield fixer.remove(tokenAfter);
|
|
|
|
const [, endOfClosingParenthesis] = tokenAfter.range;
|
|
const [startOfCatchClauseBody] = parent.body.range;
|
|
const text = sourceCode.text.slice(endOfClosingParenthesis, startOfCatchClauseBody);
|
|
const leadingSpacesLength = text.length - text.trimStart().length;
|
|
if (leadingSpacesLength !== 0) {
|
|
yield fixer.removeRange([endOfClosingParenthesis, endOfClosingParenthesis + leadingSpacesLength]);
|
|
}
|
|
},
|
|
};
|
|
},
|
|
});
|
|
|
|
/** @type {import('eslint').Rule.RuleModule} */
|
|
module.exports = {
|
|
create,
|
|
meta: {
|
|
type: 'suggestion',
|
|
docs: {
|
|
description: 'Prefer omitting the `catch` binding parameter.',
|
|
},
|
|
fixable: 'code',
|
|
messages,
|
|
},
|
|
};
|