-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfunctional_tutorial.kbdx
249 lines (216 loc) · 8.74 KB
/
functional_tutorial.kbdx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
# vim: syntax=ini
# ^ sets syntax highlighting rules for vim
#
# kbdx provides 4 implicit layers which can be inherited from
# 1. "source": a layer where each key is mapped to itself. This is useful for
# the starting layer.
# 2. "fallthrough": a layer equivalent to ALL underscores, so all keypresses go
# through to the next layer.
# 3. "block": a layer equivalent to ALL "XX"'s, so all keypresses do NOT go
# through to the next layer.
# 4. "default": this is assigned to "fallthrough" if configuration.fallthrough
# = true, and "block" otherwise. If a layer omits its parent, it will inherit
# from this layer.
#
# regardless of what you put in configuration.fallthrough, the transpiled kbd file will always have fallthrough set to true.
# later on in the document, you will see why this is useful
[configuration]
input = "/dev/input/by-id/usb-Logitech_USB_Receiver-if02-event-kbd"
output-name = "Logitech KMonad Output"
output-pre-command = "/run/current-system/sw/bin/sleep 1 && /run/current-system/sw/bin/setxkbmap -option compose:ralt"
cmp-seq = 'rctrl'
cmp-seq-delay = 5
fallthrough = true
allow-cmd = true
# indicate which layer you want to be in when KMonad launches
starting-layer = base
# behavior: if you want every layer to include mappings from one of the 4
# implicit layers (instead of `default`). I can't think of a real usecase for
# changing the default parent away from "default", but this setting is here if
# you want it.
# default-parent = default
# any heading that contains a "keys" item is a layer
# otherwise it is used purely for organization
[base]
# [base.keys] defines the different keymappings for the layer.
# you could also mark this section with [[keys]].
# this syntax is just used here to show that it's allowed.
[base.keys]
# use the "<layer name>:<button name>" syntax to reference buttons defined under layers.
# unlike in stock KBD (KMonad's config format), you can reference aliases that appear later in the document.
# NOTE: you can only omit the @ for aliases in _simple_ [[keys]] bindings, meaning that the r-value is not a Lisp expression
lmet = leader:enter
# here's a counter-example: to interpolate aliases into Lisp expressions, the @ is required.
backslash = (tap-hold 50 @leader:enter XX)
# this is a layer that contains all of the keys for entering the persistent
# layers. it does not define an "enter" button because it is only intended for
# use with inheritance.
[enter-layers]
# implicit "default" parent
# parent = default
[[keys]]
r = run:enter
s = scroll:enter
v = volume:enter
# you can put global aliases in the "aliases" table if you do not need a whole layer
[aliases]
window-switcher = (cmd-button "rofi -noplugins -modi window -show window -lines 5 --normal-window")
# every "instance" of "aliases" will be merged into one
[aliases]
discord = (cmd-button "wmctrl -a discord || /usr/bin/Discord")
[leader]
# we start with "block" because we do not want keys to fallthrough to the next layer
#
# kmonadx allows for multiple inheritance with the { <layer name>, ... }
# syntax, allowing you to effectively compose layers from other layers.
# inheritance works sequentially, with layers later in the "parent" list
# overriding keys defined earlier.
#
# inheritance works as you might expect; X's and _'s inherited from the "block"
# and "fallthrough" layers do /not/ override explicit bindings. however, X's
# and _'s that are _explicitly_ defined (and not just inherited) DO carry over,
# overriding keys from previous parents.
#
# in this example, the "leader" layer inherits "block", starting with all X's.
# then, the keys defined in "enter-layers" override the X's from "block".
# after that, any key defined in [[keys]] (alternatively, [leader.keys]) will
# override THOSE.
parent = { block, enter-layers }
# layers can choose which buttons they want to expose to other layers.
# buttons defined under [[public]] can be accessed using the aforementioned
# "<layer name>:<button name>" syntax, while [[private]] buttons can only be
# accessed within the layer.
[[private]]
leader_next = (around-next (layer-toggle leader))
[[public]]
enter = (tap-hold-next-release 250 @leader_next lmet)
[[keys]]
h = homerow-mods:enter
q = window-switcher
# here, `discord` is a button defined in a global [aliases] block, so we can
# reference it without specifying a layer. note that if there were another `discord`
# button defined internally within this layer, this binding would resolve to
# that button instead.
d = discord
# to reference regular keys, use single quotes
lmet = 'LeftMeta'
# these keys are inherited from "enter-layers"
# r = run:enter
# s = scroll:enter
# v = volume:enter
# these keys are inherited from "block"
# a = X
# b = X
# c = X
# ...
[homerow-mods]
[[private]]
# kbdx supports double quoted strings and numbers as constant rvalues.
# these can then be interpolated in buttons.
lctrl-hold-delay = 125
# in this button, the `$lctrl-hold-delay` constant is used in place of the number
lctrl-or-escape = (tap-hold-next-release $lctrl-hold-delay esc lctl)
exit = (layer-switch base)
[[public]]
enter = (layer-switch homerow-mods)
[[keys]]
# as mentioned earlier, we don't need to prefix with an @ for simple rvalue
# assignments. also notice that because the specified buttons come from the
# current layer, we don't need to use the `layer:button` syntax.
caps = lctrl-or-escape
lmet = exit
[run]
[[public]]
runner = (cmd-button "~/.config/kmonad/runner/runner.sh")
# notice that we already defined an "enter" under the leader layer.
# because buttons defined under layers are namespaced, the 2 do not collide.
# however, there WILL still be collision if you define 2 buttons with the same
# name WITHIN a layer or within the global [aliases] table.
#
# tap macro syntactic sugar works just like in kbd
enter = #(@runner (layer-add run))
[[private]]
exit = #((layer-rem run) (cmd-button "killall st"))
[[keys]]
lmet = exit
[aliases]
agenda = (cmd-button "kitty ~/.local/bin/taskwarrior-tui")
[aliases]
org-capture = (cmd-button "~/.local/bin/org-capture")
[scroll]
# inherit the keys for entering other layers
# note that this is equivalent to "parent = { default, enter-layers }"
# all layers implicitly inherit from "default", even when something else is
# specified.
parent = enter-layers
[[public]]
enter = (layer-add scroll)
[[private]]
scroll_sh = "~/.config/kmonad/scroll/scroll.sh"
speed_sh = "~/.config/kmonad/scroll/scroll_speed.sh"
speed-up-speed = 50
speed-down-speed = 200
exit = (layer-rem scroll)
# constants can be interpolated within double quoted strings as well
left = (cmd-button "$scroll_sh h -" "$scroll_sh h 0")
up = (cmd-button "$scroll_sh v -" "$scroll_sh v 0")
down = (cmd-button "$scroll_sh v +" "$scroll_sh v 0")
right = (cmd-button "$scroll_sh h +" "$scroll_sh h 0")
speed-up = (cmd-button "$speed_sh $speed-up-speed" "$speed_sh 0")
speed-down = (cmd-button "$speed_sh $speed-down-speed" "$speed_sh 0")
[[keys]]
h = left
j = down
k = up
l = right
caps = speed-down
lsft = speed-up
tab = scroll.arrow-keys:enter
lmet = exit
s = exit
# keys inherited from from enter-layers
# r = run:enter
# v = volume:enter
# if kbdx does not recognize the subtable name, it is interpreted as a NESTED
# LAYER. nested layers can be referenced using "<parent layer>.<child layer>",
# and must be FULLY QUALIFIED regardless of the context. it is a warning to use
# a nested layer from outside of the "parent" (hierarchical) layer, but it is
# allowed. this means that even if you are in the context of the scroll layer,
# you need to reference the arrow-keys layer as scroll.arrow-keys. as you may
# have guessed, this could also be defined as [[arrow-keys]]. however, it can
# be nicer to define it at the base level to avoid an extra set of square
# brackets.
[scroll.arrow-keys]
[[public]]
enter = (layer-add scroll.arrow-keys)
[[private]]
exit = (layer-rem scroll.arrow-keys)
[[keys]]
lmet = exit
# to explicitly refer to the KEY, put it in single quotes. even if there were
# buttons defined with the same name, as long as you reference them with single
# quotes there will not be a conflict.
h = 'left'
j = 'down'
k = 'up'
l = 'right'
[volume]
parent = enter-layers
[[public]]
enter = #(@scroll:enter (cmd-button "echo 1 > /tmp/volume_script_osd_file") (layer-add volume))
[[private]]
exit = (layer-rem volume)
up = (cmd-button "~/.config/kmonad/volume/volume.sh +" "~/.config/kmonad/volume/volume.sh 0")
down = (cmd-button "~/.config/kmonad/volume/volume.sh -" "~/.config/kmonad/volume/volume.sh 0")
osd-toggle = (cmd-button "~/.config/kmonad/volume/toggle_osd.sh")
mute = (cmd-button "qdbus org.kde.kglobalaccel /component/kmix invokeShortcut mute")
# to use literal dollar signs in double quoted strings, escape the dollar using
# a single backslash
log-key = (cmd-button "echo \"Log button pressed!\" > \$ENV_VAR_LOG_FILE")
[[keys]]
lmet = exit
q = osd-toggle
k = up
j = down
m = mute
l = log-key