From b3e7a5386f996177e4808f11acb2aa93a0f660df Mon Sep 17 00:00:00 2001 From: Frederic BIDON Date: Wed, 27 Dec 2023 08:55:11 +0100 Subject: [PATCH] fix(mangling): fixed name mangling when special chars are substituted This PR fixes name mangling methods (ToJSONName, ToCommandName, etc) for cases when a special character is expanded, like so: "get$ref" should be jasonified as "getDollarRef". The issue was that the extra space added was not trimmed before name reconstruction, so in the example above, we get "getDollar Ref" instead. * contributes go-swagger/go-swagger#2821 Signed-off-by: Frederic BIDON --- util.go | 8 ++++---- util_test.go | 14 ++++++++++++++ 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/util.go b/util.go index c5322d1..0413f74 100644 --- a/util.go +++ b/util.go @@ -174,7 +174,7 @@ func (s byInitialism) Less(i, j int) bool { // Removes leading whitespaces func trim(str string) string { - return strings.Trim(str, " ") + return strings.TrimSpace(str) } // Shortcut to strings.ToUpper() @@ -231,7 +231,7 @@ func ToHumanNameLower(name string) string { if !w.IsInitialism() { out = append(out, lower(w.GetOriginal())) } else { - out = append(out, w.GetOriginal()) + out = append(out, trim(w.GetOriginal())) } } @@ -244,7 +244,7 @@ func ToHumanNameTitle(name string) string { out := make([]string, 0, len(in)) for _, w := range in { - original := w.GetOriginal() + original := trim(w.GetOriginal()) if !w.IsInitialism() { out = append(out, Camelize(original)) } else { @@ -264,7 +264,7 @@ func ToJSONName(name string) string { out = append(out, lower(w)) continue } - out = append(out, Camelize(w)) + out = append(out, Camelize(trim(w))) } return strings.Join(out, "") } diff --git a/util_test.go b/util_test.go index f002a38..ccc15bc 100644 --- a/util_test.go +++ b/util_test.go @@ -111,6 +111,7 @@ func TestToGoName(t *testing.T) { {"日本語findThingById", "X日本語findThingByID"}, {"findTHINGSbyID", "FindTHINGSbyID"}, {"x-isAnOptionalHeader0", "XIsAnOptionalHeader0"}, + {"get$ref", "GetDollarRef"}, } for _, k := range commonInitialisms.sorted() { @@ -242,6 +243,7 @@ func TestToFileName(t *testing.T) { {"ELB.HTTPLoadBalancer", "elb_http_load_balancer"}, {"elbHTTPLoadBalancer", "elb_http_load_balancer"}, {"ELBHTTPLoadBalancer", "elb_http_load_balancer"}, + {"get$Ref", "get_dollar_ref"}, } for _, k := range commonInitialisms.sorted() { samples = append(samples, @@ -261,6 +263,8 @@ func TestToCommandName(t *testing.T) { {"SampleText", "sample-text"}, {"FindThingByID", "find-thing-by-id"}, {"elbHTTPLoadBalancer", "elb-http-load-balancer"}, + {"get$ref", "get-dollar-ref"}, + {"get!ref", "get-bang-ref"}, } for _, k := range commonInitialisms.sorted() { @@ -298,6 +302,8 @@ func TestToJSONName(t *testing.T) { {"SampleText", "sampleText"}, {"FindThingByID", "findThingById"}, {"elbHTTPLoadBalancer", "elbHttpLoadBalancer"}, + {"get$ref", "getDollarRef"}, + {"get!ref", "getBangRef"}, } for _, k := range commonInitialisms.sorted() { @@ -426,6 +432,8 @@ func TestCamelize(t *testing.T) { {"elbHTTPLoadBalancer", "Elbhttploadbalancer"}, {"ELBHTTPLoadBalancer", "Elbhttploadbalancer"}, {"12ab", "12ab"}, + {"get$Ref", "Get$ref"}, + {"get!Ref", "Get!ref"}, } for _, sample := range samples { @@ -447,6 +455,8 @@ func TestToHumanNameTitle(t *testing.T) { {"ELB.HTTPLoadBalancer", "ELB HTTP Load Balancer"}, {"elbHTTPLoadBalancer", "elb HTTP Load Balancer"}, {"ELBHTTPLoadBalancer", "ELB HTTP Load Balancer"}, + {"get$ref", "Get Dollar Ref"}, + {"get!ref", "Get Bang Ref"}, } for _, sample := range samples { @@ -471,6 +481,8 @@ func TestToVarName(t *testing.T) { {"Id", "id"}, {"HTTP", "http"}, {"A", "a"}, + {"get$ref", "getDollarRef"}, + {"get!ref", "getBangRef"}, } for _, sample := range samples { @@ -504,6 +516,8 @@ func TestToGoNameUnicode(t *testing.T) { {"abc", "Abc"}, {"éabc", "Éabc"}, {":éabc", "Éabc"}, + {"get$ref", "GetDollarRef"}, + {"get!ref", "GetBangRef"}, // TODO: non unicode char }