2019-05-16 08:41:16 +02:00
|
|
|
package util
|
|
|
|
|
|
|
|
import (
|
2019-06-13 11:26:01 -07:00
|
|
|
"strings"
|
2019-05-16 08:41:16 +02:00
|
|
|
"unicode"
|
|
|
|
)
|
|
|
|
|
2019-06-13 11:26:01 -07:00
|
|
|
// isSeparator reports whether the rune could mark a word boundary.
|
|
|
|
func isSeparator(r rune) bool {
|
|
|
|
// ASCII alphanumerics and underscore are not separators
|
|
|
|
if r <= 0x7F {
|
|
|
|
switch {
|
|
|
|
case '0' <= r && r <= '9':
|
|
|
|
return false
|
|
|
|
case 'a' <= r && r <= 'z':
|
|
|
|
return false
|
|
|
|
case 'A' <= r && r <= 'Z':
|
|
|
|
return false
|
|
|
|
case r == '_', r == '\'':
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
// Letters and digits are not separators
|
|
|
|
if unicode.IsLetter(r) || unicode.IsDigit(r) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
// Otherwise, all we can do for now is treat spaces as separators.
|
|
|
|
return unicode.IsSpace(r)
|
|
|
|
}
|
|
|
|
|
2019-05-16 08:41:16 +02:00
|
|
|
func UcFirst(str string) string {
|
|
|
|
for i, v := range str {
|
|
|
|
return string(unicode.ToUpper(v)) + str[i+1:]
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
2019-06-13 11:26:01 -07:00
|
|
|
|
|
|
|
func Title(s string) string {
|
|
|
|
prev := ' '
|
|
|
|
return strings.Map(
|
|
|
|
func(r rune) rune {
|
|
|
|
if isSeparator(prev) {
|
|
|
|
prev = r
|
|
|
|
return unicode.ToTitle(r)
|
|
|
|
}
|
|
|
|
prev = r
|
|
|
|
return r
|
|
|
|
},
|
|
|
|
s)
|
|
|
|
}
|