Software: Apache. PHP/8.1.30 uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root) Safe-mode: OFF (not secure) /home/picotech/domains/rentals.picotech.app/public_html/node_modules/eslint/lib/rules/ drwxr-xr-x |
Viewing file: Select action/file-type: /** * @fileoverview Rule to disallow use of the new operator with global non-constructor functions * @author Sosuke Suzuki */ "use strict"; //------------------------------------------------------------------------------ // Helpers //------------------------------------------------------------------------------ const nonConstructorGlobalFunctionNames = ["Symbol", "BigInt"]; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ /** @type {import('../shared/types').Rule} */ module.exports = { meta: { type: "problem", docs: { description: "Disallow `new` operators with global non-constructor functions", recommended: true, url: "https://eslint.org/docs/latest/rules/no-new-native-nonconstructor" }, schema: [], messages: { noNewNonconstructor: "`{{name}}` cannot be called as a constructor." } }, create(context) { const sourceCode = context.sourceCode; return { "Program:exit"(node) { const globalScope = sourceCode.getScope(node); for (const nonConstructorName of nonConstructorGlobalFunctionNames) { const variable = globalScope.set.get(nonConstructorName); if (variable && variable.defs.length === 0) { variable.references.forEach(ref => { const idNode = ref.identifier; const parent = idNode.parent; if (parent && parent.type === "NewExpression" && parent.callee === idNode) { context.report({ node: idNode, messageId: "noNewNonconstructor", data: { name: nonConstructorName } }); } }); } } } }; } }; |
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0051 ]-- |