123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
-
-
- "use strict";
-
-
-
-
-
- module.exports = {
- meta: {
- type: "suggestion",
-
- docs: {
- description: "disallow assignments to native objects or read-only global variables",
- category: "Best Practices",
- recommended: false,
- url: "https://eslint.org/docs/rules/no-native-reassign"
- },
-
- deprecated: true,
-
- replacedBy: ["no-global-assign"],
-
- schema: [
- {
- type: "object",
- properties: {
- exceptions: {
- type: "array",
- items: { type: "string" },
- uniqueItems: true
- }
- },
- additionalProperties: false
- }
- ]
- },
-
- create(context) {
- const config = context.options[0];
- const exceptions = (config && config.exceptions) || [];
-
-
-
- function checkReference(reference, index, references) {
- const identifier = reference.identifier;
-
- if (reference.init === false &&
- reference.isWrite() &&
-
-
-
- (index === 0 || references[index - 1].identifier !== identifier)
- ) {
- context.report({
- node: identifier,
- message: "Read-only global '{{name}}' should not be modified.",
- data: identifier
- });
- }
- }
-
-
-
- function checkVariable(variable) {
- if (variable.writeable === false && exceptions.indexOf(variable.name) === -1) {
- variable.references.forEach(checkReference);
- }
- }
-
- return {
- Program() {
- const globalScope = context.getScope();
-
- globalScope.variables.forEach(checkVariable);
- }
- };
- }
- };
|