mouse clicks on root window are now configurable
This commit is contained in:
parent
939d9eb149
commit
05e102a49a
18
awesomerc
18
awesomerc
|
@ -147,7 +147,23 @@ mouse
|
||||||
{
|
{
|
||||||
button = "5"
|
button = "5"
|
||||||
command = "view_tag_previous"
|
command = "view_tag_previous"
|
||||||
}
|
}
|
||||||
|
root
|
||||||
|
{
|
||||||
|
button = "3"
|
||||||
|
command = "spawn"
|
||||||
|
arg = "exec urxvt"
|
||||||
|
}
|
||||||
|
root
|
||||||
|
{
|
||||||
|
button = "4"
|
||||||
|
command = "view_tag_next"
|
||||||
|
}
|
||||||
|
root
|
||||||
|
{
|
||||||
|
button = "5"
|
||||||
|
command = "view_tag_previous"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
keys
|
keys
|
||||||
|
|
9
client.c
9
client.c
|
@ -189,7 +189,8 @@ focus(Client *c, Bool selscreen, awesome_config *awesomeconf)
|
||||||
window_grabbuttons(awesomeconf->tags[i].client_sel->display,
|
window_grabbuttons(awesomeconf->tags[i].client_sel->display,
|
||||||
awesomeconf->tags[i].client_sel->phys_screen,
|
awesomeconf->tags[i].client_sel->phys_screen,
|
||||||
awesomeconf->tags[i].client_sel->win,
|
awesomeconf->tags[i].client_sel->win,
|
||||||
False, True, awesomeconf->modkey, awesomeconf->numlockmask);
|
False, True, awesomeconf->buttons.root, awesomeconf->buttons.nroot,
|
||||||
|
awesomeconf->modkey, awesomeconf->numlockmask);
|
||||||
XSetWindowBorder(awesomeconf->tags[i].client_sel->display,
|
XSetWindowBorder(awesomeconf->tags[i].client_sel->display,
|
||||||
awesomeconf->tags[i].client_sel->win,
|
awesomeconf->tags[i].client_sel->win,
|
||||||
awesomeconf->colors_normal[ColBorder].pixel);
|
awesomeconf->colors_normal[ColBorder].pixel);
|
||||||
|
@ -200,7 +201,8 @@ focus(Client *c, Bool selscreen, awesome_config *awesomeconf)
|
||||||
{
|
{
|
||||||
XSetWindowBorder(awesomeconf->display, c->win, awesomeconf->colors_selected[ColBorder].pixel);
|
XSetWindowBorder(awesomeconf->display, c->win, awesomeconf->colors_selected[ColBorder].pixel);
|
||||||
window_grabbuttons(c->display, c->phys_screen, c->win,
|
window_grabbuttons(c->display, c->phys_screen, c->win,
|
||||||
True, True, awesomeconf->modkey, awesomeconf->numlockmask);
|
True, True, awesomeconf->buttons.root, awesomeconf->buttons.nroot,
|
||||||
|
awesomeconf->modkey, awesomeconf->numlockmask);
|
||||||
}
|
}
|
||||||
if(!selscreen)
|
if(!selscreen)
|
||||||
return;
|
return;
|
||||||
|
@ -324,7 +326,8 @@ client_manage(Window w, XWindowAttributes *wa, awesome_config *awesomeconf)
|
||||||
|
|
||||||
/* grab buttons */
|
/* grab buttons */
|
||||||
window_grabbuttons(c->display, c->phys_screen, c->win,
|
window_grabbuttons(c->display, c->phys_screen, c->win,
|
||||||
False, True, awesomeconf->modkey, awesomeconf->numlockmask);
|
False, True, awesomeconf->buttons.root, awesomeconf->buttons.nroot,
|
||||||
|
awesomeconf->modkey, awesomeconf->numlockmask);
|
||||||
|
|
||||||
/* update window title */
|
/* update window title */
|
||||||
updatetitle(c);
|
updatetitle(c);
|
||||||
|
|
18
config.c
18
config.c
|
@ -115,7 +115,7 @@ static const KeyMod KeyModList[] =
|
||||||
{"Mod3", Mod3Mask},
|
{"Mod3", Mod3Mask},
|
||||||
{"Mod4", Mod4Mask},
|
{"Mod4", Mod4Mask},
|
||||||
{"Mod5", Mod5Mask},
|
{"Mod5", Mod5Mask},
|
||||||
{NULL, 0}
|
{NULL, NoSymbol}
|
||||||
};
|
};
|
||||||
|
|
||||||
/** List of button name and corresponding X11 mask codes */
|
/** List of button name and corresponding X11 mask codes */
|
||||||
|
@ -152,7 +152,7 @@ key_mask_lookup(const char *keyname)
|
||||||
if(!a_strcmp(keyname, KeyModList[i].name))
|
if(!a_strcmp(keyname, KeyModList[i].name))
|
||||||
return KeyModList[i].keysym;
|
return KeyModList[i].keysym;
|
||||||
|
|
||||||
return 0;
|
return NoSymbol;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Lookup for a mouse button from its name
|
/** Lookup for a mouse button from its name
|
||||||
|
@ -281,6 +281,7 @@ parse_config(const char *confpatharg, awesome_config *awesomeconf)
|
||||||
CFG_SEC((char *) "tag", mouse_tag_opts, CFGF_MULTI),
|
CFG_SEC((char *) "tag", mouse_tag_opts, CFGF_MULTI),
|
||||||
CFG_SEC((char *) "layout", mouse_generic_opts, CFGF_MULTI),
|
CFG_SEC((char *) "layout", mouse_generic_opts, CFGF_MULTI),
|
||||||
CFG_SEC((char *) "title", mouse_generic_opts, CFGF_MULTI),
|
CFG_SEC((char *) "title", mouse_generic_opts, CFGF_MULTI),
|
||||||
|
CFG_SEC((char *) "root", mouse_generic_opts, CFGF_MULTI),
|
||||||
CFG_END()
|
CFG_END()
|
||||||
};
|
};
|
||||||
static cfg_opt_t opts[] =
|
static cfg_opt_t opts[] =
|
||||||
|
@ -485,6 +486,19 @@ parse_config(const char *confpatharg, awesome_config *awesomeconf)
|
||||||
awesomeconf->buttons.title[i].arg = a_strdup(cfg_getstr(cfgsectmp, "arg"));
|
awesomeconf->buttons.title[i].arg = a_strdup(cfg_getstr(cfgsectmp, "arg"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Mouse: root window click bindings */
|
||||||
|
awesomeconf->buttons.nroot = cfg_size(cfg_mouse, "root");
|
||||||
|
awesomeconf->buttons.root = p_new(Button, awesomeconf->buttons.nroot);
|
||||||
|
for(i = 0; i < awesomeconf->buttons.nroot; i++)
|
||||||
|
{
|
||||||
|
cfgsectmp = cfg_getnsec(cfg_mouse, "root", i);
|
||||||
|
for(j = 0; j < cfg_size(cfgsectmp, "modkey"); j++)
|
||||||
|
awesomeconf->buttons.root[i].mod |= key_mask_lookup(cfg_getnstr(cfgsectmp, "modkey", j));
|
||||||
|
awesomeconf->buttons.root[i].button = mouse_button_lookup(cfg_getstr(cfgsectmp, "button"));
|
||||||
|
awesomeconf->buttons.root[i].func = name_func_lookup(cfg_getstr(cfgsectmp, "command"), UicbList);
|
||||||
|
awesomeconf->buttons.root[i].arg = a_strdup(cfg_getstr(cfgsectmp, "arg"));
|
||||||
|
}
|
||||||
|
|
||||||
/* Keys */
|
/* Keys */
|
||||||
awesomeconf->numlockmask = get_numlockmask(awesomeconf->display);
|
awesomeconf->numlockmask = get_numlockmask(awesomeconf->display);
|
||||||
awesomeconf->nkeys = cfg_size(cfg_keys, "key");
|
awesomeconf->nkeys = cfg_size(cfg_keys, "key");
|
||||||
|
|
2
config.h
2
config.h
|
@ -179,6 +179,8 @@ struct awesome_config
|
||||||
int ntitle;
|
int ntitle;
|
||||||
Button *layout;
|
Button *layout;
|
||||||
int nlayout;
|
int nlayout;
|
||||||
|
Button *root;
|
||||||
|
int nroot;
|
||||||
} buttons;
|
} buttons;
|
||||||
/** Number of keys binding in *keys */
|
/** Number of keys binding in *keys */
|
||||||
int nkeys;
|
int nkeys;
|
||||||
|
|
15
event.c
15
event.c
|
@ -212,7 +212,8 @@ handle_event_buttonpress(XEvent * e, awesome_config *awesomeconf)
|
||||||
{
|
{
|
||||||
restack(&awesomeconf[c->screen]);
|
restack(&awesomeconf[c->screen]);
|
||||||
window_grabbuttons(c->display, c->phys_screen, c->win,
|
window_grabbuttons(c->display, c->phys_screen, c->win,
|
||||||
True, True, awesomeconf->modkey, awesomeconf->numlockmask);
|
True, True, awesomeconf->buttons.root, awesomeconf->buttons.nroot,
|
||||||
|
awesomeconf->modkey, awesomeconf->numlockmask);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(ev->button == Button1)
|
else if(ev->button == Button1)
|
||||||
|
@ -255,11 +256,10 @@ handle_event_buttonpress(XEvent * e, awesome_config *awesomeconf)
|
||||||
&& XQueryPointer(e->xany.display, ev->window, &wdummy, &wdummy, &x, &y, &i, &i, &udummy))
|
&& XQueryPointer(e->xany.display, ev->window, &wdummy, &wdummy, &x, &y, &i, &i, &udummy))
|
||||||
{
|
{
|
||||||
screen = get_screen_bycoord(e->xany.display, x, y);
|
screen = get_screen_bycoord(e->xany.display, x, y);
|
||||||
if(ev->button == Button4)
|
handle_mouse_button_press(&awesomeconf[screen],
|
||||||
uicb_tag_viewnext(&awesomeconf[screen], NULL);
|
ev->button, ev->state, awesomeconf->numlockmask,
|
||||||
else if(ev->button == Button5)
|
awesomeconf->buttons.root, awesomeconf->buttons.nroot, NULL);
|
||||||
uicb_tag_viewprev(&awesomeconf[screen], NULL);
|
return;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -369,7 +369,8 @@ handle_event_enternotify(XEvent * e, awesome_config *awesomeconf)
|
||||||
|| get_current_layout(awesomeconf[c->screen].tags,
|
|| get_current_layout(awesomeconf[c->screen].tags,
|
||||||
awesomeconf[c->screen].ntags)->arrange == layout_floating)
|
awesomeconf[c->screen].ntags)->arrange == layout_floating)
|
||||||
window_grabbuttons(c->display, c->phys_screen, c->win,
|
window_grabbuttons(c->display, c->phys_screen, c->win,
|
||||||
True, False, awesomeconf->modkey, awesomeconf->numlockmask);
|
True, False, awesomeconf->buttons.root, awesomeconf->buttons.nroot,
|
||||||
|
awesomeconf->modkey, awesomeconf->numlockmask);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
for(screen = 0; screen < ScreenCount(e->xany.display); screen++)
|
for(screen = 0; screen < ScreenCount(e->xany.display); screen++)
|
||||||
|
|
39
window.c
39
window.c
|
@ -92,8 +92,12 @@ window_configure(Display *disp, Window win, int x, int y, int w, int h, int bord
|
||||||
* \param numlockmask Numlock mask
|
* \param numlockmask Numlock mask
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
window_grabbuttons(Display *disp, int screen, Window win, Bool focused, Bool raised, KeySym modkey, unsigned int numlockmask)
|
window_grabbuttons(Display *disp, int screen, Window win, Bool focused, Bool raised,
|
||||||
|
Button *buttons_root, int nbuttons_root,
|
||||||
|
KeySym modkey, unsigned int numlockmask)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
XUngrabButton(disp, AnyButton, AnyModifier, win);
|
XUngrabButton(disp, AnyButton, AnyModifier, win);
|
||||||
|
|
||||||
if(focused)
|
if(focused)
|
||||||
|
@ -154,24 +158,21 @@ window_grabbuttons(Display *disp, int screen, Window win, Bool focused, Bool rai
|
||||||
XGrabButton(disp, AnyButton, AnyModifier, win, False, BUTTONMASK,
|
XGrabButton(disp, AnyButton, AnyModifier, win, False, BUTTONMASK,
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
GrabModeAsync, GrabModeSync, None, None);
|
||||||
|
|
||||||
XGrabButton(disp, Button4, NoSymbol, RootWindow(disp, screen), False, BUTTONMASK,
|
for(i = 0; i < nbuttons_root; i++)
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
{
|
||||||
XGrabButton(disp, Button4, LockMask, RootWindow(disp, screen), False, BUTTONMASK,
|
XGrabButton(disp, buttons_root[i].button, buttons_root[i].mod,
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
RootWindow(disp, screen), False, BUTTONMASK,
|
||||||
XGrabButton(disp, Button4, numlockmask, RootWindow(disp, screen), False, BUTTONMASK,
|
GrabModeAsync, GrabModeSync, None, None);
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
XGrabButton(disp, buttons_root[i].button, buttons_root[i].mod | LockMask,
|
||||||
XGrabButton(disp, Button4, numlockmask | LockMask, RootWindow(disp, screen), False, BUTTONMASK,
|
RootWindow(disp, screen), False, BUTTONMASK,
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
GrabModeAsync, GrabModeSync, None, None);
|
||||||
|
XGrabButton(disp, buttons_root[i].button, buttons_root[i].mod | numlockmask,
|
||||||
XGrabButton(disp, Button5, NoSymbol, RootWindow(disp, screen), False, BUTTONMASK,
|
RootWindow(disp, screen), False, BUTTONMASK,
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
GrabModeAsync, GrabModeSync, None, None);
|
||||||
XGrabButton(disp, Button5, LockMask, RootWindow(disp, screen), False, BUTTONMASK,
|
XGrabButton(disp, buttons_root[i].button, buttons_root[i].mod | numlockmask | LockMask,
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
RootWindow(disp, screen), False, BUTTONMASK,
|
||||||
XGrabButton(disp, Button5, numlockmask, RootWindow(disp, screen), False, BUTTONMASK,
|
GrabModeAsync, GrabModeSync, None, None);
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
}
|
||||||
XGrabButton(disp, Button5, numlockmask | LockMask, RootWindow(disp, screen), False, BUTTONMASK,
|
|
||||||
GrabModeAsync, GrabModeSync, None, None);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
3
window.h
3
window.h
|
@ -23,6 +23,7 @@
|
||||||
#define AWESOME_WINDOW_H
|
#define AWESOME_WINDOW_H
|
||||||
|
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
/** Mask shorthands, used in event.c and window.c */
|
/** Mask shorthands, used in event.c and window.c */
|
||||||
#define BUTTONMASK (ButtonPressMask | ButtonReleaseMask)
|
#define BUTTONMASK (ButtonPressMask | ButtonReleaseMask)
|
||||||
|
@ -30,7 +31,7 @@
|
||||||
int window_setstate(Display *, Window, long);
|
int window_setstate(Display *, Window, long);
|
||||||
long window_getstate(Display *, Window);
|
long window_getstate(Display *, Window);
|
||||||
Status window_configure(Display *, Window, int, int, int, int, int);
|
Status window_configure(Display *, Window, int, int, int, int, int);
|
||||||
void window_grabbuttons(Display *, int, Window, Bool, Bool, KeySym, unsigned int);
|
void window_grabbuttons(Display *, int, Window, Bool, Bool, Button *, int, KeySym, unsigned int);
|
||||||
void window_setshape(Display *, int, Window);
|
void window_setshape(Display *, int, Window);
|
||||||
void window_settrans(Display *, Window, double);
|
void window_settrans(Display *, Window, double);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue