aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobin Jarry <robin@jarry.cc>2023-09-16 00:15:42 +0200
committerRobin Jarry <robin@jarry.cc>2023-09-19 16:49:59 +0200
commitd4e49c79a69c399702c3c781920c8eae5b9e22ba (patch)
tree74af2ee50e0b2b6c5ef6d25131d2236162944b3d
parent34c718d72b357b6a64f4273ef72b4415ad721fd2 (diff)
downloadaerc-d4e49c79a69c399702c3c781920c8eae5b9e22ba.tar.gz
aerc-d4e49c79a69c399702c3c781920c8eae5b9e22ba.zip
binds: improve display of key sequences
Do not replace all spaces by <space>, it makes the bindings completely unreadable. Only replace trailing and leading spaces with <space> since these are the only one that actually matter. The others are implicit and it improves the readability level by over 9000. Signed-off-by: Robin Jarry <robin@jarry.cc> Tested-by: Inwit <inwit@sindominio.net>
-rw-r--r--config/binds.go24
-rw-r--r--widgets/aerc.go1
2 files changed, 20 insertions, 5 deletions
diff --git a/config/binds.go b/config/binds.go
index 78f68eb4..1e9727a5 100644
--- a/config/binds.go
+++ b/config/binds.go
@@ -393,11 +393,16 @@ func FormatKeyStrokes(keystrokes []KeyStroke) string {
if ks.Modifiers == stroke.Modifiers && ks.Key == stroke.Key && ks.Rune == stroke.Rune {
switch name {
case "cr", "c-m":
- name = "enter"
+ s = "<enter>"
case "c-i":
- name = "tab"
+ s = "<tab>"
+ case "space":
+ s = " "
+ case "semicolon":
+ s = ";"
+ default:
+ s = fmt.Sprintf("<%s>", name)
}
- s = fmt.Sprintf("<%s>", name)
break
}
}
@@ -407,9 +412,20 @@ func FormatKeyStrokes(keystrokes []KeyStroke) string {
sb.WriteString(s)
}
- return sb.String()
+ // replace leading & trailing spaces with explicit <space> keystrokes
+ buf := sb.String()
+ match := spaceTrimRe.FindStringSubmatch(buf)
+ if len(match) == 4 {
+ prefix := strings.ReplaceAll(match[1], " ", "<space>")
+ suffix := strings.ReplaceAll(match[3], " ", "<space>")
+ buf = prefix + match[2] + suffix
+ }
+
+ return buf
}
+var spaceTrimRe = regexp.MustCompile(`^(\s*)(.*?)(\s*)$`)
+
var keyNames = map[string]KeyStroke{
"space": {tcell.ModNone, tcell.KeyRune, ' '},
"semicolon": {tcell.ModNone, tcell.KeyRune, ';'},
diff --git a/widgets/aerc.go b/widgets/aerc.go
index faec403e..efa13194 100644
--- a/widgets/aerc.go
+++ b/widgets/aerc.go
@@ -209,7 +209,6 @@ func (aerc *Aerc) HumanReadableBindings() []string {
var result []string
binds := aerc.getBindings()
format := func(s string) string {
- s = strings.ReplaceAll(s, "<space>", " ")
return strings.ReplaceAll(s, "%", "%%")
}
fmtStr := "%10s %s"