/** * @fileoverview Disallow string concatenation when using __dirname and __filename * @author Nicholas C. Zakas * @deprecated in ESLint v7.0.0 */ 'use strict'; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ /** @type {import('../types').Rule.RuleModule} */ module.exports = { meta: { deprecated: { message: 'Node.js rules were moved out of ESLint core.', url: 'https://eslint.org/docs/latest/use/migrating-to-7.0.0#deprecate-node-rules', deprecatedSince: '7.0.0', availableUntil: null, replacedBy: [ { message: 'eslint-plugin-n now maintains deprecated Node.js-related rules.', plugin: { name: 'eslint-plugin-n', url: 'https://github.com/eslint-community/eslint-plugin-n', }, rule: { name: 'no-path-concat', url: 'https://github.com/eslint-community/eslint-plugin-n/tree/master/docs/rules/no-path-concat.md', }, }, ], }, type: 'suggestion', docs: { description: 'Disallow string concatenation with `__dirname` and `__filename`', recommended: false, url: 'https://eslint.org/docs/latest/rules/no-path-concat', }, schema: [], messages: { usePathFunctions: 'Use path.join() or path.resolve() instead of + to create paths.', }, }, create(context) { const MATCHER = /^__(?:dir|file)name$/u; //-------------------------------------------------------------------------- // Public //-------------------------------------------------------------------------- return { BinaryExpression(node) { const left = node.left, right = node.right; if ( node.operator === '+' && ((left.type === 'Identifier' && MATCHER.test(left.name)) || (right.type === 'Identifier' && MATCHER.test(right.name))) ) { context.report({ node, messageId: 'usePathFunctions', }); } }, }; }, };