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