30 lines
907 B
Go
30 lines
907 B
Go
|
// Package sanitized_anchor_name provides a func to create sanitized anchor names.
|
||
|
//
|
||
|
// Its logic can be reused by multiple packages to create interoperable anchor names
|
||
|
// and links to those anchors.
|
||
|
//
|
||
|
// At this time, it does not try to ensure that generated anchor names
|
||
|
// are unique, that responsibility falls on the caller.
|
||
|
package sanitized_anchor_name // import "github.com/shurcooL/sanitized_anchor_name"
|
||
|
|
||
|
import "unicode"
|
||
|
|
||
|
// Create returns a sanitized anchor name for the given text.
|
||
|
func Create(text string) string {
|
||
|
var anchorName []rune
|
||
|
var futureDash = false
|
||
|
for _, r := range []rune(text) {
|
||
|
switch {
|
||
|
case unicode.IsLetter(r) || unicode.IsNumber(r):
|
||
|
if futureDash && len(anchorName) > 0 {
|
||
|
anchorName = append(anchorName, '-')
|
||
|
}
|
||
|
futureDash = false
|
||
|
anchorName = append(anchorName, unicode.ToLower(r))
|
||
|
default:
|
||
|
futureDash = true
|
||
|
}
|
||
|
}
|
||
|
return string(anchorName)
|
||
|
}
|