Blame view
node_modules/eslint/lib/rules/no-dupe-args.js
2.13 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 |
/** * @fileoverview Rule to flag duplicate arguments * @author Jamund Ferguson */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ module.exports = { meta: { docs: { description: "disallow duplicate arguments in `function` definitions", category: "Possible Errors", recommended: true }, schema: [] }, create(context) { //-------------------------------------------------------------------------- // Helpers //-------------------------------------------------------------------------- /** * Checks whether or not a given definition is a parameter's. * @param {escope.DefEntry} def - A definition to check. * @returns {boolean} `true` if the definition is a parameter's. */ function isParameter(def) { return def.type === "Parameter"; } /** * Determines if a given node has duplicate parameters. * @param {ASTNode} node The node to check. * @returns {void} * @private */ function checkParams(node) { const variables = context.getDeclaredVariables(node); for (let i = 0; i < variables.length; ++i) { const variable = variables[i]; // Checks and reports duplications. const defs = variable.defs.filter(isParameter); if (defs.length >= 2) { context.report({ node, message: "Duplicate param '{{name}}'.", data: { name: variable.name } }); } } } //-------------------------------------------------------------------------- // Public API //-------------------------------------------------------------------------- return { FunctionDeclaration: checkParams, FunctionExpression: checkParams }; } }; |