guile-swayer/modules/kbd.scm

162 lines
5 KiB
Scheme
Raw Normal View History

2024-06-15 09:57:11 +02:00
(define-module (modules kbd)
#:use-module (ice-9 hash-table)
#:export (kbd-init
define-keysym
define-modsym
keysym-translations
modsym-translations
keysym-clean
kbd))
2024-06-18 18:05:39 +02:00
;; Hashmap that's used to translate key symbols
;; Use define-keysym to add and translations
2024-06-15 09:57:11 +02:00
(define keysym-translations (make-hash-table))
2024-06-18 18:05:39 +02:00
;; Hashmap that's used to translate modifier symbols
;; Use define-modsym to add and translations
2024-06-15 09:57:11 +02:00
(define modsym-translations (make-hash-table))
(define (replace-char str old-char new-char)
2024-06-18 18:05:39 +02:00
"Replace all occurances of a character (old-char) with the
charcter (new-char)."
2024-06-15 09:57:11 +02:00
(string-map
(lambda (ch)
(if (char=? ch old-char)
new-char
ch))
str))
(define (keysym-clean key)
2024-06-18 18:05:39 +02:00
"Clean the keysym, it replaces all underscores (_) with dashes (-)
and lowercase all characters. This is done to make it easier to translate
symbols, for example: Spc and SPC should both be translated to the same
symbol. Note: symbols shouldn't include letter like a or b."
2024-06-15 09:57:11 +02:00
(if (<= (string-length (string-trim-both key)) 1)
key
(string-trim-both
(string-downcase
(replace-char key #\_ #\-)))))
(define (define-keysym key translation)
2024-06-18 18:05:39 +02:00
"Define a mapping from a symbol to a sway compatible symbol in keys
Parameters:
- key: the key to look for in the keybinding.
- translation: the symbol to convert the key to.
Example:
(define-keysym \"SPC\" \"space\")
With the above definition, kbd will translate the keys below.
\"s-spc\" => \"s-space\"
\"s-Spc\" => \"s-space\"
\"s-SPC\" => \"s-space\"
For more information why case is ignored, refer or modify keysym-clean."
2024-06-15 09:57:11 +02:00
(hash-set! keysym-translations (keysym-clean key) translation))
(define (define-modsym key translation)
2024-06-18 18:05:39 +02:00
"Define a mapping from a symbol to a sway compatible symbol in modifier keys
Parameters:
- key: the key to look for in the keybinding.
- translation: the symbol to convert the key to.
2024-06-15 09:57:11 +02:00
2024-06-18 18:05:39 +02:00
Example:
(define-modsym \"s-\" \"mod4+\")
With the above definition, kbd will translate the keys below.
\"s-spc\" => \"mod4+space\"
Note: unlike define-keysym, keysym-clean is not used."
(hash-set! modsym-translations key translation))
2024-06-15 09:57:11 +02:00
(define* (replace-modifiers key #:optional (translation ""))
2024-06-18 18:05:39 +02:00
"Replace modifier keys in the given key with translations
defined in modsym-translations."
2024-06-15 09:57:11 +02:00
(cond
((< (string-length key) 2) (list translation key))
((hash-get-handle modsym-translations (substring key 0 2))
(replace-modifiers
(substring key 2)
(string-append
translation
(cdr (hash-get-handle modsym-translations (substring key 0 2))))))
(else (list translation key))))
(define* (replace-key-symbols key)
2024-06-18 18:05:39 +02:00
"Replace keys in the given key with translations
defined in keysym-translations."
2024-06-16 06:44:40 +02:00
(let* ((lkey (keysym-clean key))
2024-06-15 09:57:11 +02:00
(translation (hash-get-handle keysym-translations lkey)))
(if (pair? translation)
(cdr translation)
2024-06-16 06:44:40 +02:00
key)))
2024-06-15 09:57:11 +02:00
(define (sway-key key)
2024-06-18 18:05:39 +02:00
"Replace the provided key/chord with translations defined in both
modsym-translations and keysym-translations."
2024-06-15 09:57:11 +02:00
(let* ((modifier (replace-modifiers key))
(rkey (replace-key-symbols (list-ref modifier 1))))
(string-append (list-ref modifier 0)
(if (number? rkey)
(number->string rkey)
rkey))))
(define (kbd seq)
2024-06-18 18:05:39 +02:00
"Return sway compatible keybinding symbols from emacs like key sequence."
2024-06-15 09:57:11 +02:00
(string-join
(map sway-key
(string-split seq #\Space)) " "))
(define (kbd-init)
2024-06-18 18:05:39 +02:00
"Definie initial translations"
2024-06-15 09:57:11 +02:00
;; key modifiers
(define-modsym "C-" "Control+")
(define-modsym "S-" "Shift+")
(define-modsym "s-" "mod4+")
(define-modsym "M-" "Alt+")
(define-modsym "C-" "Control+")
;; key symbols
(define-keysym "RET" "Return")
(define-keysym "ESC" "Escape")
(define-keysym "TAB" "Tab")
(define-keysym "DEL" "BackSpace")
(define-keysym "SPC" "space")
(define-keysym "!" "exclam")
(define-keysym "\"" "quotedbl")
(define-keysym "$" "dollar")
(define-keysym "£" "sterling")
(define-keysym "%" "percent")
(define-keysym "&" "ampersand")
(define-keysym "'" "apostrophe")
(define-keysym "`" "grave")
(define-keysym "&" "ampersand")
(define-keysym "(" "parenleft")
(define-keysym ")" "parenright")
(define-keysym "*" "asterisk")
(define-keysym "+" "plus")
(define-keysym "," "comma")
(define-keysym "-" "minus")
(define-keysym "." "period")
(define-keysym "/" "slash")
(define-keysym ":" "colon")
(define-keysym ";" "semicolon")
(define-keysym "<" "less")
(define-keysym "=" "equal")
(define-keysym ">" "greater")
(define-keysym "?" "question")
(define-keysym "@" "at")
(define-keysym "[" "bracketleft")
(define-keysym "\\" "backslash")
(define-keysym "]" "bracketright")
(define-keysym "^" "asciicircum")
(define-keysym "_" "underscore")
(define-keysym "#" "numbersign")
(define-keysym "{" "braceleft")
(define-keysym "|" "bar")
(define-keysym "}" "braceright")
(define-keysym "~" "asciitilde")
(define-keysym "<" "quoteleft")
(define-keysym ">" "quoteright"))