Compare commits

..

No commits in common. "master" and "v0.1.1" have entirely different histories.

5 changed files with 22 additions and 109 deletions

View File

@ -1,10 +1,9 @@
sudo: false
language: go
go:
- 1.7.x
- 1.8.x
- 1.9.x
- 1.10.x
- 1.11.x
- 1.12.x
- 1.13.x
- 1.14.x
- 1.15.x
- master

View File

@ -1,6 +1,6 @@
# strcase
[![Godoc Reference](https://godoc.org/github.com/iancoleman/strcase?status.svg)](http://godoc.org/github.com/iancoleman/strcase)
[![Build Status](https://travis-ci.com/iancoleman/strcase.svg)](https://travis-ci.com/iancoleman/strcase)
[![Build Status](https://travis-ci.org/iancoleman/strcase.svg)](https://travis-ci.org/iancoleman/strcase)
[![Coverage](http://gocover.io/_badge/github.com/iancoleman/strcase?0)](http://gocover.io/github.com/iancoleman/strcase)
[![Go Report Card](https://goreportcard.com/badge/github.com/iancoleman/strcase)](https://goreportcard.com/report/github.com/iancoleman/strcase)
@ -31,29 +31,3 @@ s := "AnyKind of_string"
```bash
go get -u github.com/iancoleman/strcase
```
## Custom Acronyms for ToCamel && ToLowerCamel
Often times text can contain specific acronyms which you need to be handled a certain way.
Out of the box `strcase` treats the string "ID" as "Id" or "id" but there is no way to cater
for every case in the wild.
To configure your custom acronym globally you can use the following before running any conversion
```go
import (
"github.com/iancoleman/strcase"
)
func init() {
// results in "Api" using ToCamel("API")
// results in "api" using ToLowerCamel("API")
strcase.ConfigureAcronym("API", "api")
// results in "PostgreSQL" using ToCamel("PostgreSQL")
// results in "postgreSQL" using ToLowerCamel("PostgreSQL")
strcase.ConfigureAcronym("PostgreSQL", "PostgreSQL")
}
```

View File

@ -3,8 +3,3 @@ package strcase
var uppercaseAcronym = map[string]string{
"ID": "id",
}
// ConfigureAcronym allows you to add additional words which will be considered acronyms
func ConfigureAcronym(key, val string) {
uppercaseAcronym[key] = val
}

View File

@ -85,78 +85,6 @@ func TestToLowerCamel(t *testing.T) {
toLowerCamel(t)
}
func TestCustomAcronymsToCamel(t *testing.T) {
tests := []struct {
name string
acronymKey string
acronymValue string
expected string
}{
{
name: "API Custom Acronym",
acronymKey: "API",
acronymValue: "api",
expected: "Api",
},
{
name: "ABCDACME Custom Acroynm",
acronymKey: "ABCDACME",
acronymValue: "AbcdAcme",
expected: "AbcdAcme",
},
{
name: "PostgreSQL Custom Acronym",
acronymKey: "PostgreSQL",
acronymValue: "PostgreSQL",
expected: "PostgreSQL",
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
ConfigureAcronym(test.acronymKey, test.acronymValue)
if result := ToCamel(test.acronymKey); result != test.expected {
t.Errorf("expected custom acronym result %s, got %s", test.expected, result)
}
})
}
}
func TestCustomAcronymsToLowerCamel(t *testing.T) {
tests := []struct {
name string
acronymKey string
acronymValue string
expected string
}{
{
name: "API Custom Acronym",
acronymKey: "API",
acronymValue: "api",
expected: "api",
},
{
name: "ABCDACME Custom Acroynm",
acronymKey: "ABCDACME",
acronymValue: "AbcdAcme",
expected: "abcdAcme",
},
{
name: "PostgreSQL Custom Acronym",
acronymKey: "PostgreSQL",
acronymValue: "PostgreSQL",
expected: "postgreSQL",
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
ConfigureAcronym(test.acronymKey, test.acronymValue)
if result := ToLowerCamel(test.acronymKey); result != test.expected {
t.Errorf("expected custom acronym result %s, got %s", test.expected, result)
}
})
}
}
func BenchmarkToLowerCamel(b *testing.B) {
benchmarkCamelTest(b, toLowerCamel)
}

View File

@ -64,10 +64,27 @@ func ToDelimited(s string, delimiter uint8) string {
// or delimited.snake.case
// (in this case `delimiter = '.'; screaming = false`)
func ToScreamingDelimited(s string, delimiter uint8, ignore uint8, screaming bool) string {
s = strings.TrimSpace(s)
n := strings.Builder{}
n.Grow(len(s) + 2) // nominal 2 bytes of extra space for inserted delimiters
start := true
spaces := 0
for i, v := range []byte(s) {
if v == ' ' {
spaces++
continue
} else if start {
start = false
spaces = 0
} else {
for ; spaces > 0; spaces-- {
if ignore == ' ' {
n.WriteByte(' ')
} else {
n.WriteByte(delimiter)
}
}
}
vIsCap := v >= 'A' && v <= 'Z'
vIsLow := v >= 'a' && v <= 'z'
if vIsLow && screaming {