Xinqi Bao's Git
projects
/
dwm.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
renames swim[ming] into versatile
[dwm.git]
/
event.c
diff --git
a/event.c
b/event.c
index
fbce631
..
00c53b6
100644
(file)
--- a/
event.c
+++ b/
event.c
@@
-20,6
+20,14
@@
KEYS
#define CLEANMASK(mask) (mask & ~(numlockmask | LockMask))
#define MOUSEMASK (BUTTONMASK | PointerMotionMask)
#define CLEANMASK(mask) (mask & ~(numlockmask | LockMask))
#define MOUSEMASK (BUTTONMASK | PointerMotionMask)
+static Client *
+getclient(Window w) {
+ Client *c;
+
+ for(c = clients; c && c->win != w; c = c->next);
+ return c;
+}
+
static void
movemouse(Client *c) {
int x1, y1, ocx, ocy, di, nx, ny;
static void
movemouse(Client *c) {
int x1, y1, ocx, ocy, di, nx, ny;
@@
-129,10
+137,10
@@
buttonpress(XEvent *e) {
return;
}
}
return;
}
}
- if(ev->x < x + b
m
w)
+ if(ev->x < x + b
l
w)
switch(ev->button) {
case Button1:
switch(ev->button) {
case Button1:
- toggle
mode
(NULL);
+ toggle
layout
(NULL);
break;
case Button4:
a.i = 1;
break;
case Button4:
a.i = 1;
@@
-148,14
+156,14
@@
buttonpress(XEvent *e) {
focus(c);
if(CLEANMASK(ev->state) != MODKEY)
return;
focus(c);
if(CLEANMASK(ev->state) != MODKEY)
return;
- if(ev->button == Button1 && (
arrange == dofloat || c->isfloat
)) {
+ if(ev->button == Button1 && (
lt->arrange == versatile || c->versatile
)) {
restack();
movemouse(c);
}
else if(ev->button == Button2)
zoom(NULL);
else if(ev->button == Button3
restack();
movemouse(c);
}
else if(ev->button == Button2)
zoom(NULL);
else if(ev->button == Button3
- && (
arrange == dofloat || c->isfloat
) && !c->isfixed)
+ && (
lt->arrange == versatile || c->versatile
) && !c->isfixed)
{
restack();
resizemouse(c);
{
restack();
resizemouse(c);
@@
-165,7
+173,6
@@
buttonpress(XEvent *e) {
static void
configurerequest(XEvent *e) {
static void
configurerequest(XEvent *e) {
- int x, y, w, h;
Client *c;
XConfigureRequestEvent *ev = &e->xconfigurerequest;
XWindowChanges wc;
Client *c;
XConfigureRequestEvent *ev = &e->xconfigurerequest;
XWindowChanges wc;
@@
-174,25
+181,20
@@
configurerequest(XEvent *e) {
c->ismax = False;
if(ev->value_mask & CWBorderWidth)
c->border = ev->border_width;
c->ismax = False;
if(ev->value_mask & CWBorderWidth)
c->border = ev->border_width;
- if(c->isfixed || c->isfloat || (arrange == dofloat)) {
- x = (ev->value_mask & CWX) ? ev->x : c->x;
- y = (ev->value_mask & CWY) ? ev->y : c->y;
- w = (ev->value_mask & CWWidth) ? ev->width : c->w;
- h = (ev->value_mask & CWHeight) ? ev->height : c->h;
+ if(c->isfixed || c->versatile || (lt->arrange == versatile)) {
+ if(ev->value_mask & CWX)
+ c->x = ev->x;
+ if(ev->value_mask & CWY)
+ c->y = ev->y;
+ if(ev->value_mask & CWWidth)
+ c->w = ev->width;
+ if(ev->value_mask & CWHeight)
+ c->h = ev->height;
if((ev->value_mask & (CWX | CWY))
&& !(ev->value_mask & (CWWidth | CWHeight)))
if((ev->value_mask & (CWX | CWY))
&& !(ev->value_mask & (CWWidth | CWHeight)))
- {
- c->x = x;
- c->y = y;
configure(c);
configure(c);
- if(isvisible(c))
- XMoveWindow(dpy, c->win, c->x, c->y);
- }
- else {
- resize(c, x, y, w, h, False);
- if(!isvisible(c))
- ban(c);
- }
+ if(isvisible(c))
+ XMoveResizeWindow(dpy, c->win, c->x, c->y, c->w, c->h);
}
else
configure(c);
}
else
configure(c);
@@
-307,8
+309,8
@@
propertynotify(XEvent *e) {
default: break;
case XA_WM_TRANSIENT_FOR:
XGetTransientForHint(dpy, c->win, &trans);
default: break;
case XA_WM_TRANSIENT_FOR:
XGetTransientForHint(dpy, c->win, &trans);
- if(!c->
isfloat && (c->isfloat = (trans != 0
)))
- arrange();
+ if(!c->
versatile && (c->versatile = (getclient(trans) != NULL
)))
+
lt->
arrange();
break;
case XA_WM_NORMAL_HINTS:
updatesizehints(c);
break;
case XA_WM_NORMAL_HINTS:
updatesizehints(c);
@@
-366,14
+368,3
@@
grabkeys(void) {
GrabModeAsync, GrabModeAsync);
}
}
GrabModeAsync, GrabModeAsync);
}
}
-
-void
-procevent(void) {
- XEvent ev;
-
- while(XPending(dpy)) {
- XNextEvent(dpy, &ev);
- if(handler[ev.type])
- (handler[ev.type])(&ev); /* call handler */
- }
-}