/** * @fileoverview Rule to disallow use of void operator. * @author Mike Sidorov */ 'use strict'; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ /** @type {import('../types').Rule.RuleModule} */ module.exports = { meta: { type: 'suggestion', defaultOptions: [ { allowAsStatement: false, }, ], docs: { description: 'Disallow `void` operators', recommended: false, frozen: true, url: 'https://eslint.org/docs/latest/rules/no-void', }, messages: { noVoid: "Expected 'undefined' and instead saw 'void'.", }, schema: [ { type: 'object', properties: { allowAsStatement: { type: 'boolean', }, }, additionalProperties: false, }, ], }, create(context) { const [{ allowAsStatement }] = context.options; //-------------------------------------------------------------------------- // Public //-------------------------------------------------------------------------- return { 'UnaryExpression[operator="void"]'(node) { if ( allowAsStatement && node.parent && node.parent.type === 'ExpressionStatement' ) { return; } context.report({ node, messageId: 'noVoid', }); }, }; }, };