Blame view
node_modules/eslint/lib/rules/no-undefined.js
1.99 KB
f7563de62
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
/** * @fileoverview Rule to flag references to the undefined variable. * @author Michael Ficarra */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ module.exports = { meta: { docs: { description: "disallow the use of `undefined` as an identifier", category: "Variables", recommended: false }, schema: [] }, create(context) { /** * Report an invalid "undefined" identifier node. * @param {ASTNode} node The node to report. * @returns {void} */ function report(node) { context.report({ node, message: "Unexpected use of undefined." }); } /** * Checks the given scope for references to `undefined` and reports * all references found. * @param {escope.Scope} scope The scope to check. * @returns {void} */ function checkScope(scope) { const undefinedVar = scope.set.get("undefined"); if (!undefinedVar) { return; } const references = undefinedVar.references; const defs = undefinedVar.defs; // Report non-initializing references (those are covered in defs below) references .filter(ref => !ref.init) .forEach(ref => report(ref.identifier)); defs.forEach(def => report(def.name)); } return { "Program:exit"() { const globalScope = context.getScope(); const stack = [globalScope]; while (stack.length) { const scope = stack.pop(); stack.push.apply(stack, scope.childScopes); checkScope(scope); } } }; } }; |