Use strings.Builder in NameToSlug.
This commit is contained in:
parent
ac0dd6d2cb
commit
084f1bbeca
@ -261,7 +261,7 @@ func ConvertFriendlyUnit(num int) (int, string) {
|
|||||||
|
|
||||||
// TODO: Make slugs optional for certain languages across the entirety of Gosora?
|
// TODO: Make slugs optional for certain languages across the entirety of Gosora?
|
||||||
// TODO: Let plugins replace NameToSlug and the URL building logic with their own
|
// TODO: Let plugins replace NameToSlug and the URL building logic with their own
|
||||||
func NameToSlug(name string) (slug string) {
|
/*func NameToSlug(name string) (slug string) {
|
||||||
// TODO: Do we want this reliant on config file flags? This might complicate tests and oddball uses
|
// TODO: Do we want this reliant on config file flags? This might complicate tests and oddball uses
|
||||||
if !Config.BuildSlugs {
|
if !Config.BuildSlugs {
|
||||||
return ""
|
return ""
|
||||||
@ -283,6 +283,33 @@ func NameToSlug(name string) (slug string) {
|
|||||||
slug = "untitled"
|
slug = "untitled"
|
||||||
}
|
}
|
||||||
return slug
|
return slug
|
||||||
|
}*/
|
||||||
|
|
||||||
|
// TODO: Make slugs optional for certain languages across the entirety of Gosora?
|
||||||
|
// TODO: Let plugins replace NameToSlug and the URL building logic with their own
|
||||||
|
func NameToSlug(name string) (slug string) {
|
||||||
|
// TODO: Do we want this reliant on config file flags? This might complicate tests and oddball uses
|
||||||
|
if !Config.BuildSlugs {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
name = strings.TrimSpace(name)
|
||||||
|
name = strings.Replace(name, " ", " ", -1)
|
||||||
|
|
||||||
|
var sb strings.Builder
|
||||||
|
for _, char := range name {
|
||||||
|
if unicode.IsLower(char) || unicode.IsNumber(char) {
|
||||||
|
sb.WriteRune(char)
|
||||||
|
} else if unicode.IsUpper(char) {
|
||||||
|
sb.WriteRune(unicode.ToLower(char))
|
||||||
|
} else if unicode.IsSpace(char) {
|
||||||
|
sb.WriteByte('-')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if sb.Len() == 0 {
|
||||||
|
return "untitled"
|
||||||
|
}
|
||||||
|
return sb.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Write a test for this
|
// TODO: Write a test for this
|
||||||
|
Loading…
Reference in New Issue
Block a user