From 7f7d024f11631b1e244fdb88a25b5dd7a493eaaf Mon Sep 17 00:00:00 2001 From: Oleksandr Redko Date: Tue, 3 Dec 2024 18:08:21 +0200 Subject: [PATCH] unused-param,unused-receiver: fix panic message (#1156) --- rule/unused_param.go | 17 ++++++++--------- rule/unused_receiver.go | 16 ++++++++-------- 2 files changed, 16 insertions(+), 17 deletions(-) diff --git a/rule/unused_param.go b/rule/unused_param.go index a8514ac2d..08945da43 100644 --- a/rule/unused_param.go +++ b/rule/unused_param.go @@ -21,28 +21,27 @@ type UnusedParamRule struct { func (r *UnusedParamRule) configure(args lint.Arguments) { // while by default args is an array, i think it's good to provide structures inside it by default, not arrays or primitives // it's more compatible to JSON nature of configurations - var allowedRegexStr string + var allowRegexStr string if len(args) == 0 { - allowedRegexStr = "^_$" + allowRegexStr = "^_$" r.failureMsg = "parameter '%s' seems to be unused, consider removing or renaming it as _" } else { // Arguments = [{}] options := args[0].(map[string]any) - // Arguments = [{allowedRegex="^_"}] + // Arguments = [{allowRegex="^_"}] - if allowedRegexParam, ok := options["allowRegex"]; ok { - allowedRegexStr, ok = allowedRegexParam.(string) + if allowRegexParam, ok := options["allowRegex"]; ok { + allowRegexStr, ok = allowRegexParam.(string) if !ok { - panic(fmt.Errorf("error configuring %s rule: allowedRegex is not string but [%T]", r.Name(), allowedRegexParam)) + panic(fmt.Errorf("error configuring %s rule: allowRegex is not string but [%T]", r.Name(), allowRegexParam)) } } } var err error - r.allowRegex, err = regexp.Compile(allowedRegexStr) + r.allowRegex, err = regexp.Compile(allowRegexStr) if err != nil { - panic(fmt.Errorf("error configuring %s rule: allowedRegex is not valid regex [%s]: %v", r.Name(), allowedRegexStr, err)) + panic(fmt.Errorf("error configuring %s rule: allowRegex is not valid regex [%s]: %v", r.Name(), allowRegexStr, err)) } - if r.failureMsg == "" { r.failureMsg = "parameter '%s' seems to be unused, consider removing or renaming it to match " + r.allowRegex.String() } diff --git a/rule/unused_receiver.go b/rule/unused_receiver.go index f1866cf90..c88c0e39f 100644 --- a/rule/unused_receiver.go +++ b/rule/unused_receiver.go @@ -21,26 +21,26 @@ type UnusedReceiverRule struct { func (r *UnusedReceiverRule) configure(args lint.Arguments) { // while by default args is an array, i think it's good to provide structures inside it by default, not arrays or primitives // it's more compatible to JSON nature of configurations - var allowedRegexStr string + var allowRegexStr string if len(args) == 0 { - allowedRegexStr = "^_$" + allowRegexStr = "^_$" r.failureMsg = "method receiver '%s' is not referenced in method's body, consider removing or renaming it as _" } else { // Arguments = [{}] options := args[0].(map[string]any) - // Arguments = [{allowedRegex="^_"}] + // Arguments = [{allowRegex="^_"}] - if allowedRegexParam, ok := options["allowRegex"]; ok { - allowedRegexStr, ok = allowedRegexParam.(string) + if allowRegexParam, ok := options["allowRegex"]; ok { + allowRegexStr, ok = allowRegexParam.(string) if !ok { - panic(fmt.Errorf("error configuring [unused-receiver] rule: allowedRegex is not string but [%T]", allowedRegexParam)) + panic(fmt.Errorf("error configuring [unused-receiver] rule: allowRegex is not string but [%T]", allowRegexParam)) } } } var err error - r.allowRegex, err = regexp.Compile(allowedRegexStr) + r.allowRegex, err = regexp.Compile(allowRegexStr) if err != nil { - panic(fmt.Errorf("error configuring [unused-receiver] rule: allowedRegex is not valid regex [%s]: %v", allowedRegexStr, err)) + panic(fmt.Errorf("error configuring [unused-receiver] rule: allowRegex is not valid regex [%s]: %v", allowRegexStr, err)) } if r.failureMsg == "" { r.failureMsg = "method receiver '%s' is not referenced in method's body, consider removing or renaming it to match " + r.allowRegex.String()