From ccffdcb18f57c9319cb4e9ec110cf7d370404d28 Mon Sep 17 00:00:00 2001 From: "Hans Bergren (0xCLARITY)" Date: Thu, 23 May 2024 10:01:10 -0700 Subject: [PATCH] Exclude abi.encodeX calls from func-named-parameters --- lib/rules/naming/func-named-parameters.js | 28 ++++++++++++++++++----- 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/lib/rules/naming/func-named-parameters.js b/lib/rules/naming/func-named-parameters.js index 170ea4ba..2836d654 100644 --- a/lib/rules/naming/func-named-parameters.js +++ b/lib/rules/naming/func-named-parameters.js @@ -36,6 +36,10 @@ const meta = { description: 'Function call with four NAMED parameters', code: 'functionName({ sender: _senderAddress, amount: 1e18, token: _tokenAddress, receiver: _receiverAddress })', }, + { + description: 'abi.encodeX call with four UNNAMED parameters', + code: 'abi.encodePacked(_senderAddress, 1e18, _tokenAddress, _receiverAddress )', + }, ], bad: [ { @@ -67,12 +71,24 @@ class FunctionNamedParametersChecker extends BaseChecker { const qtyNamed = node.names.length const qtyArgs = node.arguments.length - if (qtyArgs !== 0) { - if (qtyNamed === 0 && qtyArgs > this.maxUnnamedArguments) { - this.error( - node, - `Named parameters missing. MIN unnamed argumenst is ${this.maxUnnamedArguments}` - ) + if (!this.isAbiCall(node)) { + if (qtyArgs !== 0) { + if (qtyNamed === 0 && qtyArgs > this.maxUnnamedArguments) { + this.error( + node, + `Named parameters missing. MIN unnamed argumenst is ${this.maxUnnamedArguments}` + ) + } + } + } + } + + isAbiCall(node) { + if (node.expression.type == 'MemberAccess') { + if (node.expression.expression.type == 'Identifier') { + if (node.expression.expression.name == 'abi') { + return true + } } } }