navidrome/utils/index_group_parser.go

40 lines
1.2 KiB
Go

package utils
import (
"regexp"
"strings"
)
type IndexGroups map[string]string
// ParseIndexGroups
// The specification is a space-separated list of index entries. Normally, each entry is just a single character,
// but you may also specify multiple characters. For instance, the entry "The" will link to all files and
// folders starting with "The".
//
// You may also create an entry using a group of index characters in parentheses. For instance, the entry
// "A-E(ABCDE)" will display as "A-E" and link to all files and folders starting with either
// A, B, C, D or E. This may be useful for grouping less-frequently used characters (such and X, Y and Z), or
// for grouping accented characters (such as A, \u00C0 and \u00C1)
//
// Files and folders that are not covered by an index entry will be placed under the index entry "#".
func ParseIndexGroups(spec string) IndexGroups {
parsed := make(IndexGroups)
split := strings.Split(spec, " ")
re := regexp.MustCompile(`(.+)\((.+)\)`)
for _, g := range split {
sub := re.FindStringSubmatch(g)
if len(sub) > 0 {
i := 0
chars := strings.Split(sub[2], "")
for _, c := range chars {
parsed[c] = sub[1]
i++
}
} else {
parsed[g] = g
}
}
return parsed
}