|                                                      |  | /** * @fileoverview Rule to flag assignment of the exception parameter * @author Stephen Murray <spmurrayzzz> */
"use strict";
const astUtils = require("./utils/ast-utils");
//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------
/** @type {import('../shared/types').Rule} */module.exports = {    meta: {        type: "problem",
        docs: {            description: "Disallow reassigning exceptions in `catch` clauses",            recommended: true,            url: "https://eslint.org/docs/latest/rules/no-ex-assign"        },
        schema: [],
        messages: {            unexpected: "Do not assign to the exception parameter."        }    },
    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: "unexpected" });            });        }
        return {            CatchClause(node) {                sourceCode.getDeclaredVariables(node).forEach(checkVariable);            }        };
    }};
 |