| /** | |
|  * @fileoverview A rule to disallow modifying variables that are declared using `const` | |
|  * @author Toru Nagashima | |
|  */ | |
| 
 | |
| "use strict"; | |
| 
 | |
| const astUtils = require("./utils/ast-utils"); | |
| 
 | |
| //------------------------------------------------------------------------------ | |
| // Rule Definition | |
| //------------------------------------------------------------------------------ | |
|  | |
| /** @type {import('../shared/types').Rule} */ | |
| module.exports = { | |
|     meta: { | |
|         type: "problem", | |
| 
 | |
|         docs: { | |
|             description: "Disallow reassigning `const` variables", | |
|             recommended: true, | |
|             url: "https://eslint.org/docs/latest/rules/no-const-assign" | |
|         }, | |
| 
 | |
|         schema: [], | |
| 
 | |
|         messages: { | |
|             const: "'{{name}}' is constant." | |
|         } | |
|     }, | |
| 
 | |
|     create(context) { | |
| 
 | |
|         const sourceCode = context.sourceCode; | |
| 
 | |
|         /** | |
|          * Finds and reports references that are non initializer and writable. | |
|          * @param {Variable} variable A variable to check. | |
|          * @returns {void} | |
|          */ | |
|         function checkVariable(variable) { | |
|             astUtils.getModifyingReferences(variable.references).forEach(reference => { | |
|                 context.report({ node: reference.identifier, messageId: "const", data: { name: reference.identifier.name } }); | |
|             }); | |
|         } | |
| 
 | |
|         return { | |
|             VariableDeclaration(node) { | |
|                 if (node.kind === "const") { | |
|                     sourceCode.getDeclaredVariables(node).forEach(checkVariable); | |
|                 } | |
|             } | |
|         }; | |
| 
 | |
|     } | |
| };
 |