This is a personal fork of sxhkd, an X keyboard shortcut daemon, created to add a feature for my own personal needs, and to learn/showcase working on a project with an existing codebase.
- Add inline source documentation (partial)
- Add and test support for enabling and disabling groups of hotkeys via signal.
- Add complete test suite of existing functionality
sxhkd is a lightweight open source keyboard shortcut daemon that I use on my personal computer. My goal is to make a desired modification with as few changes as possible to the original codebase, and in a manner that is consistent with and integrated into the original design philosophy. I am making these changes using a test-driven approach, to ensure that I maintain all existing functionality, and to guide my design.
sxhkd is an X daemon that reacts to input events by executing commands.
Its configuration file is a series of bindings that define the associations between the input events and the commands.
The format of the configuration file supports a simple notation for mapping multiple shortcuts to multiple commands in parallel.
XF86Audio{Prev,Next}
mpc -q {prev,next}
@XF86LaunchA
scrot -s -e 'image_viewer $f'
super + shift + equal
sxiv -rt "$HOME/image"
XF86LaunchB
xdotool selectwindow | xsel -bi
super + {h,j,k,l}
bspc node -f {west,south,north,east}
super + alt + {0-9}
mpc -q seek {0-9}0%
super + {alt,ctrl,alt + ctrl} + XF86Eject
sudo systemctl {suspend,reboot,poweroff}
super + {_,shift + }{h,j,k,l}
bspc node -{f,s} {west,south,north,east}
{_,shift + ,super + }XF86MonBrightness{Down,Up}
bright {-1,-10,min,+1,+10,max}
super + o ; {e,w,m}
{gvim,firefox,thunderbird}
super + alt + control + {h,j,k,l} ; {0-9}
bspc node @{west,south,north,east} -r 0.{0-9}
super + alt + p
bspc config focus_follows_pointer {true,false}
# Smart resize, will grow or shrink depending on location.
# Will always grow for floating nodes.
super + ctrl + alt + {Left,Down,Up,Right}
n=10; \
{ d1=left; d2=right; dx=-$n; dy=0; \
, d1=bottom; d2=top; dx=0; dy=$n; \
, d1=top; d2=bottom; dx=0; dy=-$n; \
, d1=right; d2=left; dx=$n; dy=0; \
} \
bspc node --resize $d1 $dx $dy || bspc node --resize $d2 $dx $dy
For further information, check the man
pages.