From 9632263ba644fbeda183e9f92c83cfc32c76c242 Mon Sep 17 00:00:00 2001 From: Calvin Date: Sat, 8 Feb 2014 18:18:12 -0500 Subject: initial commit --- hotkey.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 hotkey.c diff --git a/hotkey.c b/hotkey.c new file mode 100644 index 0000000..7978baf --- /dev/null +++ b/hotkey.c @@ -0,0 +1,52 @@ +#include +#include +#include +#include +#include +#include +#include + +#define len(X) (sizeof X / sizeof X[0]) + +typedef struct { + char *command; + unsigned int mod; + KeySym key; +} Key; + +static const Key hotkeys[] = { + //"Command MOD Key + { "svte &", Mod1Mask, XK_g }, + { "svte -e mocp &", ShiftMask|ControlMask, XK_y } +}; + +int main() { + Display* dpy = XOpenDisplay(0); + Window root = DefaultRootWindow(dpy); + unsigned int i = 0; + + for(i = 0; i < len(hotkeys); i++) { + XGrabKey(dpy, XKeysymToKeycode(dpy,hotkeys[i].key), hotkeys[i].mod, root, False, GrabModeAsync, GrabModeAsync); + } + + XSelectInput(dpy, root, KeyPressMask ); + while(true) { + XEvent ev; + XNextEvent(dpy, &ev); + + if(ev.type == KeyPress) { + //ripped out of dwm + XKeyEvent *kev = &ev.xkey; + KeySym keysym = XKeycodeToKeysym(dpy, (KeyCode)kev->keycode, 0); + for(i = 0; i < len(hotkeys); i++) { + if(keysym == hotkeys[i].key && hotkeys[i].mod == kev->state) { + printf("executing '%s'\n", hotkeys[i].command); + system(hotkeys[i].command); + } + } + } + } + + XCloseDisplay(dpy); + return 0; +} -- cgit v1.2.3