mirror of
https://git.suckless.org/dwm
synced 2024-12-27 03:16:32 +00:00
integrated yiyus mouse.diff (though the bar click handling is slightly broken, I'm to tired to debug it now, yiyus could you please?)
This commit is contained in:
parent
e3838e8585
commit
5cd65f8cd8
2 changed files with 111 additions and 74 deletions
84
config.def.h
84
config.def.h
|
@ -39,10 +39,10 @@ static Layout layouts[] = {
|
||||||
/* key definitions */
|
/* key definitions */
|
||||||
#define MODKEY Mod1Mask
|
#define MODKEY Mod1Mask
|
||||||
#define TAGKEYS(KEY,TAG) \
|
#define TAGKEYS(KEY,TAG) \
|
||||||
{ MODKEY, KEY, view, TAG }, \
|
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ControlMask, KEY, toggleview, TAG }, \
|
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ShiftMask, KEY, tag, TAG }, \
|
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, TAG },
|
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
||||||
|
|
||||||
/* helper for spawning shell commands */
|
/* helper for spawning shell commands */
|
||||||
#define SHCMD(cmd) { .v = (char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
#define SHCMD(cmd) { .v = (char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
||||||
|
@ -51,27 +51,61 @@ static Key keys[] = {
|
||||||
/* modifier key function argument */
|
/* modifier key function argument */
|
||||||
{ MODKEY, XK_p, spawn, {.v = (char *[]){"dmenu_run", "-fn", FONT, "-nb", NORMBGCOLOR, "-nf", NORMFGCOLOR, "-sb", SELBGCOLOR, "-sf", SELFGCOLOR, NULL}} },
|
{ MODKEY, XK_p, spawn, {.v = (char *[]){"dmenu_run", "-fn", FONT, "-nb", NORMBGCOLOR, "-nf", NORMFGCOLOR, "-sb", SELBGCOLOR, "-sf", SELFGCOLOR, NULL}} },
|
||||||
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = (char *[]){"uxterm", NULL}} },
|
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = (char *[]){"uxterm", NULL}} },
|
||||||
{ MODKEY, XK_b, togglebar, {0}},
|
{ MODKEY, XK_b, togglebar, {0} },
|
||||||
{ MODKEY, XK_j, focusstack, {.i = +1 }},
|
{ MODKEY, XK_j, focusstack, {.i = +1 } },
|
||||||
{ MODKEY, XK_k, focusstack, {.i = -1 }},
|
{ MODKEY, XK_k, focusstack, {.i = -1 } },
|
||||||
{ MODKEY, XK_h, setmfact, {.f = -0.05}},
|
{ MODKEY, XK_h, setmfact, {.f = -0.05} },
|
||||||
{ MODKEY, XK_l, setmfact, {.f = +0.05}},
|
{ MODKEY, XK_l, setmfact, {.f = +0.05} },
|
||||||
{ MODKEY, XK_m, togglemax, {0}},
|
{ MODKEY, XK_m, togglemax, {0} },
|
||||||
{ MODKEY, XK_Return, zoom, {0}},
|
{ MODKEY, XK_Return, zoom, {0} },
|
||||||
{ MODKEY, XK_Tab, view, {0}},
|
{ MODKEY, XK_Tab, view, {0} },
|
||||||
{ MODKEY|ShiftMask, XK_c, killclient, {0}},
|
{ MODKEY|ShiftMask, XK_c, killclient, {0} },
|
||||||
{ MODKEY, XK_space, togglelayout, {0}},
|
{ MODKEY, XK_space, togglelayout, {0} },
|
||||||
{ MODKEY|ShiftMask, XK_space, togglefloating, {0}},
|
{ MODKEY|ShiftMask, XK_space, togglefloating, {0} },
|
||||||
{ MODKEY, XK_0, view, {.ui = ~0 } },
|
{ MODKEY, XK_0, view, {.ui = ~0 } },
|
||||||
{ MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
|
{ MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
|
||||||
TAGKEYS( XK_1, {.ui = 1 << 0} )
|
TAGKEYS( XK_1, 0)
|
||||||
TAGKEYS( XK_2, {.ui = 1 << 1} )
|
TAGKEYS( XK_2, 1)
|
||||||
TAGKEYS( XK_3, {.ui = 1 << 2} )
|
TAGKEYS( XK_3, 2)
|
||||||
TAGKEYS( XK_4, {.ui = 1 << 3} )
|
TAGKEYS( XK_4, 3)
|
||||||
TAGKEYS( XK_5, {.ui = 1 << 4} )
|
TAGKEYS( XK_5, 4)
|
||||||
TAGKEYS( XK_6, {.ui = 1 << 5} )
|
TAGKEYS( XK_6, 5)
|
||||||
TAGKEYS( XK_7, {.ui = 1 << 6} )
|
TAGKEYS( XK_7, 6)
|
||||||
TAGKEYS( XK_8, {.ui = 1 << 7} )
|
TAGKEYS( XK_8, 7)
|
||||||
TAGKEYS( XK_9, {.ui = 1 << 8} )
|
TAGKEYS( XK_9, 8)
|
||||||
{ MODKEY|ShiftMask, XK_q, quit, {0}},
|
{ MODKEY|ShiftMask, XK_q, quit, {0} },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* button definitions */
|
||||||
|
#define TAGBUTTONS(TAG) \
|
||||||
|
{ TAG, 0, Button1, view, {.ui = 1 << TAG} }, \
|
||||||
|
{ TAG, 0, Button3, toggleview, {.ui = 1 << TAG} }, \
|
||||||
|
{ TAG, MODKEY, Button1, tag, {.ui = 1 << TAG} }, \
|
||||||
|
{ TAG, MODKEY, Button3, toggletag, {.ui = 1 << TAG} },
|
||||||
|
|
||||||
|
/* click can be a tag number (starting at 0),
|
||||||
|
* ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
|
||||||
|
static Button buttons[] = {
|
||||||
|
/* click event mask button function argument */
|
||||||
|
{ ClkLtSymbol, 0, Button1, togglelayout, {0} },
|
||||||
|
{ ClkLtSymbol, 0, Button3, togglemax, {0} },
|
||||||
|
{ ClkWinTitle, 0, Button1, movemouse, {0} },
|
||||||
|
{ ClkWinTitle, 0, Button2, zoom, {0} },
|
||||||
|
{ ClkWinTitle, 0, Button3, resizemouse, {0} },
|
||||||
|
{ ClkWinTitle, 0, Button4, focusstack, {.i = +1 } },
|
||||||
|
{ ClkWinTitle, 0, Button5, focusstack, {.i = -1 } },
|
||||||
|
{ ClkClientWin, MODKEY, Button1, movemouse, {0} },
|
||||||
|
{ ClkClientWin, MODKEY, Button2, togglefloating, {0} },
|
||||||
|
{ ClkClientWin, MODKEY, Button3, resizemouse, {0} },
|
||||||
|
{ ClkRootWin, Button1Mask, Button3, spawn, {.v = (char *[]){"uxterm", NULL}} },
|
||||||
|
TAGBUTTONS(0)
|
||||||
|
TAGBUTTONS(1)
|
||||||
|
TAGBUTTONS(2)
|
||||||
|
TAGBUTTONS(3)
|
||||||
|
TAGBUTTONS(4)
|
||||||
|
TAGBUTTONS(5)
|
||||||
|
TAGBUTTONS(6)
|
||||||
|
TAGBUTTONS(7)
|
||||||
|
TAGBUTTONS(8)
|
||||||
|
};
|
||||||
|
|
||||||
|
|
101
dwm.c
101
dwm.c
|
@ -59,10 +59,28 @@ enum { CurNormal, CurResize, CurMove, CurLast }; /* cursor */
|
||||||
enum { ColBorder, ColFG, ColBG, ColLast }; /* color */
|
enum { ColBorder, ColFG, ColBG, ColLast }; /* color */
|
||||||
enum { NetSupported, NetWMName, NetLast }; /* EWMH atoms */
|
enum { NetSupported, NetWMName, NetLast }; /* EWMH atoms */
|
||||||
enum { WMProtocols, WMDelete, WMName, WMState, WMLast };/* default atoms */
|
enum { WMProtocols, WMDelete, WMName, WMState, WMLast };/* default atoms */
|
||||||
|
enum { ClkLtSymbol = -1, ClkStatusText = -2, ClkWinTitle = -3,
|
||||||
|
ClkClientWin = -4, ClkRootWin = -5, ClkLast = -6};/* clicks */
|
||||||
|
|
||||||
/* typedefs */
|
/* typedefs */
|
||||||
typedef unsigned int uint;
|
typedef unsigned int uint;
|
||||||
typedef unsigned long ulong;
|
typedef unsigned long ulong;
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
int i;
|
||||||
|
uint ui;
|
||||||
|
float f;
|
||||||
|
void *v;
|
||||||
|
} Arg;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint click;
|
||||||
|
uint mask;
|
||||||
|
uint button;
|
||||||
|
void (*func)(const Arg *arg);
|
||||||
|
const Arg arg;
|
||||||
|
} Button;
|
||||||
|
|
||||||
typedef struct Client Client;
|
typedef struct Client Client;
|
||||||
struct Client {
|
struct Client {
|
||||||
char name[256];
|
char name[256];
|
||||||
|
@ -92,13 +110,6 @@ typedef struct {
|
||||||
} font;
|
} font;
|
||||||
} DC; /* draw context */
|
} DC; /* draw context */
|
||||||
|
|
||||||
typedef union {
|
|
||||||
int i;
|
|
||||||
uint ui;
|
|
||||||
float f;
|
|
||||||
void *v;
|
|
||||||
} Arg;
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint mod;
|
uint mod;
|
||||||
KeySym keysym;
|
KeySym keysym;
|
||||||
|
@ -157,12 +168,12 @@ static void killclient(const Arg *arg);
|
||||||
static void manage(Window w, XWindowAttributes *wa);
|
static void manage(Window w, XWindowAttributes *wa);
|
||||||
static void mappingnotify(XEvent *e);
|
static void mappingnotify(XEvent *e);
|
||||||
static void maprequest(XEvent *e);
|
static void maprequest(XEvent *e);
|
||||||
static void movemouse(Client *c);
|
static void movemouse(const Arg *arg);
|
||||||
static Client *nexttiled(Client *c);
|
static Client *nexttiled(Client *c);
|
||||||
static void propertynotify(XEvent *e);
|
static void propertynotify(XEvent *e);
|
||||||
static void quit(const Arg *arg);
|
static void quit(const Arg *arg);
|
||||||
static void resize(Client *c, int x, int y, int w, int h, Bool sizehints);
|
static void resize(Client *c, int x, int y, int w, int h, Bool sizehints);
|
||||||
static void resizemouse(Client *c);
|
static void resizemouse(const Arg *arg);
|
||||||
static void restack(void);
|
static void restack(void);
|
||||||
static void run(void);
|
static void run(void);
|
||||||
static void scan(void);
|
static void scan(void);
|
||||||
|
@ -297,50 +308,31 @@ attachstack(Client *c) {
|
||||||
|
|
||||||
void
|
void
|
||||||
buttonpress(XEvent *e) {
|
buttonpress(XEvent *e) {
|
||||||
uint i, mask;
|
uint i, x, click;
|
||||||
int x;
|
|
||||||
Client *c;
|
Client *c;
|
||||||
XButtonPressedEvent *ev = &e->xbutton;
|
XButtonPressedEvent *ev = &e->xbutton;
|
||||||
|
|
||||||
|
click = ClkRootWin;
|
||||||
if(ev->window == barwin) {
|
if(ev->window == barwin) {
|
||||||
x = 0;
|
x = 0;
|
||||||
for(i = 0; i < LENGTH(tags); i++) {
|
for(i = 0; i < LENGTH(tags) && ev->x >= x; i++) {
|
||||||
x += TEXTW(tags[i]);
|
x += TEXTW(tags[i]);
|
||||||
if(ev->x < x) {
|
if(i < LENGTH(tags) || ev->x <= x)
|
||||||
mask = 1 << i;
|
click = i - 1;
|
||||||
if(ev->button == Button1) {
|
else if(ev->x < x + blw)
|
||||||
if(ev->state & MODKEY)
|
click = ClkLtSymbol;
|
||||||
tag((Arg*)&mask);
|
else if(ev->x > wx + ww - TEXTW(stext))
|
||||||
else
|
click = ClkStatusText;
|
||||||
view((Arg*)&mask);
|
else
|
||||||
}
|
click = ClkWinTitle;
|
||||||
else if(ev->button == Button3) {
|
|
||||||
if(ev->state & MODKEY)
|
|
||||||
toggletag((Arg*)&mask);
|
|
||||||
else
|
|
||||||
toggleview((Arg*)&mask);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(ev->x < x + blw) {
|
|
||||||
if(ev->button == Button1)
|
|
||||||
togglelayout(NULL);
|
|
||||||
else if(ev->button == Button3)
|
|
||||||
togglemax(NULL);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if((c = getclient(ev->window))) {
|
else if((c = getclient(ev->window)))
|
||||||
focus(c);
|
click = ClkClientWin;
|
||||||
if(CLEANMASK(ev->state) != MODKEY || (ismax && !c->isfixed))
|
|
||||||
return;
|
for(i = 0; i < LENGTH(buttons); i++)
|
||||||
if(ev->button == Button1)
|
if(click == buttons[i].click && buttons[i].func && buttons[i].button == ev->button && CLEANMASK(buttons[i].mask) == CLEANMASK(ev->state))
|
||||||
movemouse(c);
|
buttons[i].func(&buttons[i].arg);
|
||||||
else if(ev->button == Button2)
|
|
||||||
togglefloating(NULL);
|
|
||||||
else if(ev->button == Button3 && !c->isfixed)
|
|
||||||
resizemouse(c);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -971,12 +963,15 @@ maprequest(XEvent *e) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
movemouse(Client *c) {
|
movemouse(const Arg *arg) {
|
||||||
int x1, y1, ocx, ocy, di, nx, ny;
|
int x1, y1, ocx, ocy, di, nx, ny;
|
||||||
uint dui;
|
uint dui;
|
||||||
|
Client *c;
|
||||||
Window dummy;
|
Window dummy;
|
||||||
XEvent ev;
|
XEvent ev;
|
||||||
|
|
||||||
|
if(!(c = sel))
|
||||||
|
return;
|
||||||
restack();
|
restack();
|
||||||
ocx = nx = c->x;
|
ocx = nx = c->x;
|
||||||
ocy = ny = c->y;
|
ocy = ny = c->y;
|
||||||
|
@ -984,6 +979,11 @@ movemouse(Client *c) {
|
||||||
None, cursor[CurMove], CurrentTime) != GrabSuccess)
|
None, cursor[CurMove], CurrentTime) != GrabSuccess)
|
||||||
return;
|
return;
|
||||||
XQueryPointer(dpy, root, &dummy, &dummy, &x1, &y1, &di, &di, &dui);
|
XQueryPointer(dpy, root, &dummy, &dummy, &x1, &y1, &di, &di, &dui);
|
||||||
|
if(x1 < c->x || x1 > c->x + c->w || y1 < c->y || y1 > c->y + c->h) {
|
||||||
|
XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, 0, 0);
|
||||||
|
x1 = c->x + 1;
|
||||||
|
y1 = c->y + 1;
|
||||||
|
}
|
||||||
for(;;) {
|
for(;;) {
|
||||||
XMaskEvent(dpy, MOUSEMASK|ExposureMask|SubstructureRedirectMask, &ev);
|
XMaskEvent(dpy, MOUSEMASK|ExposureMask|SubstructureRedirectMask, &ev);
|
||||||
switch (ev.type) {
|
switch (ev.type) {
|
||||||
|
@ -1131,11 +1131,14 @@ resize(Client *c, int x, int y, int w, int h, Bool sizehints) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
resizemouse(Client *c) {
|
resizemouse(const Arg *arg) {
|
||||||
int ocx, ocy;
|
int ocx, ocy;
|
||||||
int nw, nh;
|
int nw, nh;
|
||||||
|
Client *c;
|
||||||
XEvent ev;
|
XEvent ev;
|
||||||
|
|
||||||
|
if(!(c = sel))
|
||||||
|
return;
|
||||||
restack();
|
restack();
|
||||||
ocx = c->x;
|
ocx = c->x;
|
||||||
ocy = c->y;
|
ocy = c->y;
|
||||||
|
@ -1377,7 +1380,7 @@ setup(void) {
|
||||||
PropModeReplace, (unsigned char *) netatom, NetLast);
|
PropModeReplace, (unsigned char *) netatom, NetLast);
|
||||||
|
|
||||||
/* select for events */
|
/* select for events */
|
||||||
wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask
|
wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|ButtonPressMask
|
||||||
|EnterWindowMask|LeaveWindowMask|StructureNotifyMask;
|
|EnterWindowMask|LeaveWindowMask|StructureNotifyMask;
|
||||||
XChangeWindowAttributes(dpy, root, CWEventMask|CWCursor, &wa);
|
XChangeWindowAttributes(dpy, root, CWEventMask|CWCursor, &wa);
|
||||||
XSelectInput(dpy, root, wa.event_mask);
|
XSelectInput(dpy, root, wa.event_mask);
|
||||||
|
@ -1643,7 +1646,7 @@ updatewmhints(Client *c) {
|
||||||
void
|
void
|
||||||
view(const Arg *arg) {
|
view(const Arg *arg) {
|
||||||
seltags ^= 1; /* toggle sel tagset */
|
seltags ^= 1; /* toggle sel tagset */
|
||||||
if(arg && (arg->ui & TAGMASK))
|
if(arg && (arg->ui & TAGMASK) && (arg->ui & TAGMASK) != tagset[seltags ^ 1])
|
||||||
tagset[seltags] = arg->i & TAGMASK;
|
tagset[seltags] = arg->i & TAGMASK;
|
||||||
arrange();
|
arrange();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue