node/tools/node_modules/eslint/lib/rules/no-implicit-globals.js
Michaël Zasso 7a52c51e81 tools: update ESLint to 4.15.0
PR-URL: https://github.com/nodejs/node/pull/17820
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
2018-01-11 09:50:42 +01:00

57 lines
1.8 KiB
JavaScript

/**
* @fileoverview Rule to check for implicit global variables and functions.
* @author Joshua Peek
*/
"use strict";
//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------
module.exports = {
meta: {
docs: {
description: "disallow variable and `function` declarations in the global scope",
category: "Best Practices",
recommended: false,
url: "https://eslint.org/docs/rules/no-implicit-globals"
},
schema: []
},
create(context) {
return {
Program() {
const scope = context.getScope();
scope.variables.forEach(variable => {
if (variable.writeable) {
return;
}
variable.defs.forEach(def => {
if (def.type === "FunctionName" || (def.type === "Variable" && def.parent.kind === "var")) {
context.report({ node: def.node, message: "Implicit global variable, assign as global property instead." });
}
});
});
scope.implicit.variables.forEach(variable => {
const scopeVariable = scope.set.get(variable.name);
if (scopeVariable && scopeVariable.writeable) {
return;
}
variable.defs.forEach(def => {
context.report({ node: def.node, message: "Implicit global variable, assign as global property instead." });
});
});
}
};
}
};