eslint-plugin-sonarjs
Version:
SonarJS rules for ESLint
68 lines (67 loc) • 2.99 kB
JavaScript
/*
* SonarQube JavaScript Plugin
* Copyright (C) 2011-2025 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the Sonar Source-Available License Version 1, as published by SonarSource SA.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the Sonar Source-Available License for more details.
*
* You should have received a copy of the Sonar Source-Available License
* along with this program; if not, see https://sonarsource.com/license/ssal/
*/
// https://sonarsource.github.io/rspec/#/rspec/S4619/javascript
Object.defineProperty(exports, "__esModule", { value: true });
exports.rule = void 0;
const index_js_1 = require("../helpers/index.js");
const meta_js_1 = require("./meta.js");
exports.rule = {
meta: (0, index_js_1.generateMeta)(meta_js_1.meta, {
hasSuggestions: true,
messages: {
inMisuse: 'Use "indexOf" or "includes" (available from ES2016) instead.',
suggestIndexOf: 'Replace with "indexOf" method',
suggestIncludes: 'Replace with "includes" method',
},
}),
create(context) {
const services = context.sourceCode.parserServices;
function prototypeProperty(expr) {
if (expr.type !== 'Literal' || typeof expr.value !== 'string') {
return false;
}
return ['indexOf', 'lastIndexOf', 'forEach', 'map', 'filter', 'every', 'some'].includes(expr.value);
}
if ((0, index_js_1.isRequiredParserServices)(services)) {
return {
"BinaryExpression[operator='in']": (node) => {
const { left, right } = node;
if ((0, index_js_1.isArray)(right, services) && !prototypeProperty(left) && !(0, index_js_1.isNumber)(left, services)) {
const leftText = context.sourceCode.getText(left);
const rightText = context.sourceCode.getText(right);
context.report({
messageId: 'inMisuse',
node,
suggest: [
{
messageId: 'suggestIndexOf',
fix: fixer => fixer.replaceText(node, `${rightText}.indexOf(${leftText}) > -1`),
},
{
messageId: 'suggestIncludes',
fix: fixer => fixer.replaceText(node, `${rightText}.includes(${leftText})`),
},
],
});
}
},
};
}
return {};
},
};
;