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:
Anselm R Garbe 2008-06-11 20:41:28 +01:00
parent e3838e8585
commit 5cd65f8cd8
2 changed files with 111 additions and 74 deletions

View file

@ -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 } }
@ -64,14 +64,48 @@ static Key keys[] = {
{ 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)
};

99
dwm.c
View file

@ -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))
click = ClkStatusText;
else else
view((Arg*)&mask); click = ClkWinTitle;
}
else if(ev->button == Button3) {
if(ev->state & MODKEY)
toggletag((Arg*)&mask);
else
toggleview((Arg*)&mask);
}
return;
} }
} }
if(ev->x < x + blw) { else if((c = getclient(ev->window)))
if(ev->button == Button1) click = ClkClientWin;
togglelayout(NULL);
else if(ev->button == Button3) for(i = 0; i < LENGTH(buttons); i++)
togglemax(NULL); if(click == buttons[i].click && buttons[i].func && buttons[i].button == ev->button && CLEANMASK(buttons[i].mask) == CLEANMASK(ev->state))
} buttons[i].func(&buttons[i].arg);
}
else if((c = getclient(ev->window))) {
focus(c);
if(CLEANMASK(ev->state) != MODKEY || (ismax && !c->isfixed))
return;
if(ev->button == Button1)
movemouse(c);
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();
} }