git-project-manager/internal/cache/fuzz.go

62 lines
1.7 KiB
Go
Raw Normal View History

2024-01-15 21:02:15 +00:00
package cache
2023-12-08 21:52:26 +00:00
import (
"strings"
"github.com/lithammer/fuzzysearch/fuzzy"
2024-10-01 18:29:14 +00:00
"golang.org/x/exp/slices"
2024-12-19 19:55:49 +00:00
"gitea.libretechconsulting.com/rmcguire/git-project-manager/internal/remotes/projects"
2023-12-08 21:52:26 +00:00
)
// Performs a fuzzy find on the input string, returning the closest
// matched based on its Levenshtein distance, along with an integer
// indicating number of matches found
func (c *Cache) FuzzyFindAlias(name string) []*ProjectAlias {
ranks := fuzzy.RankFindFold(name, c.AliasStrings(""))
2023-12-08 21:52:26 +00:00
if ranks.Len() == 1 {
c.log.Debug("Fuzzy found alias result",
c.log.Args(
"searchTerm", ranks[0].Source,
"foundAlias", ranks[0].Target,
"levenshteinDistance", ranks[0].Distance,
))
} else if ranks.Len() > 1 {
found := make([]string, ranks.Len())
for i, r := range ranks {
found[i] = r.Target
}
2023-12-10 04:45:30 +00:00
c.log.Debug("Fuzzy found multiple aliases, try being more specific",
2023-12-09 04:13:17 +00:00
c.log.Args("foundAliases", strings.Join(found, ", ")))
2023-12-08 21:52:26 +00:00
}
2024-10-01 18:29:14 +00:00
aliases := make([]*ProjectAlias, 0, ranks.Len())
2023-12-08 21:52:26 +00:00
if ranks.Len() > 0 {
2024-10-01 18:29:14 +00:00
for _, r := range ranks {
alias := c.GetAliasByName(r.Target)
if alias != nil {
aliases = append(aliases, alias)
}
2023-12-08 21:52:26 +00:00
}
}
2024-10-01 18:29:14 +00:00
return slices.Clip(aliases)
2023-12-08 21:52:26 +00:00
}
// Returns all matching projects by fuzzy find term
// Matches NameWithNamespace and Aliases
2024-01-15 20:39:35 +00:00
func (c *Cache) FuzzyFindProjects(search string) []*projects.Project {
projects := make([]*projects.Project, 0, len(c.Projects))
for _, p := range c.Projects {
if fuzzy.MatchFold(search, p.NameWithNamespace) {
projects = append(projects, p)
continue
}
for _, a := range c.GetProjectAliases(p) {
if fuzzy.MatchFold(search, a.Alias) {
projects = append(projects, p)
continue
}
}
}
return projects
}