summaryrefslogtreecommitdiff
path: root/commands/commands.go
diff options
context:
space:
mode:
authorinwit <inwit@sindominio.net>2022-01-31 17:32:19 +0100
committerRobin Jarry <robin@jarry.cc>2022-01-31 17:51:57 +0100
commite0b5f2e08cd766258bdfd5eb392690768d2f5964 (patch)
treeea0abbcc5fa9358f215b1951f9b23b05a2794a67 /commands/commands.go
parent27122ef8e885f6824afd395c0c0b7b4f19f71b21 (diff)
downloadaerc-e0b5f2e08cd766258bdfd5eb392690768d2f5964.zip
completions: add folder flexible search as an option
Provide an option to change the completion style when selecting a folder from completing with folders starting with the input string to completing with folders in which the input string is a substring present at any point in the folder name. References: https://lists.sr.ht/~sircmpwn/aerc/%3C20201129181020.186984-1-inwit%40sindominio.net%3E References: https://lists.sr.ht/~sircmpwn/aerc/%3C20210223202536.199355-1-clayton%40craftyguy.net%3E Signed-off-by: inwit <inwit@sindominio.net>
Diffstat (limited to 'commands/commands.go')
-rw-r--r--commands/commands.go15
1 files changed, 14 insertions, 1 deletions
diff --git a/commands/commands.go b/commands/commands.go
index 3777835..cb5b63b 100644
--- a/commands/commands.go
+++ b/commands/commands.go
@@ -121,7 +121,7 @@ func GetFolders(aerc *widgets.Aerc, args []string) []string {
return aerc.SelectedAccount().Directories().List()
}
for _, dir := range aerc.SelectedAccount().Directories().List() {
- if hasCaseSmartPrefix(dir, args[0]) {
+ if foundInString(dir, args[0], aerc.SelectedAccount().UiConfig().FuzzyFolderComplete) {
out = append(out, dir)
}
}
@@ -177,6 +177,14 @@ func GetLabels(aerc *widgets.Aerc, args []string) []string {
return out
}
+func foundInString(s, substring string, fuzzy bool) bool {
+ if fuzzy {
+ return caseInsensitiveContains(s, substring)
+ } else {
+ return hasCaseSmartPrefix(s, substring)
+ }
+}
+
// hasCaseSmartPrefix checks whether s starts with prefix, using a case
// sensitive match if and only if prefix contains upper case letters.
func hasCaseSmartPrefix(s, prefix string) bool {
@@ -186,6 +194,11 @@ func hasCaseSmartPrefix(s, prefix string) bool {
return strings.HasPrefix(strings.ToLower(s), strings.ToLower(prefix))
}
+func caseInsensitiveContains(s, substr string) bool {
+ s, substr = strings.ToUpper(s), strings.ToUpper(substr)
+ return strings.Contains(s, substr)
+}
+
func hasUpper(s string) bool {
for _, r := range s {
if unicode.IsUpper(r) {