1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
Binary files dwm/drw.o and dwm.patched/drw.o differ
Binary files dwm/dwm and dwm.patched/dwm differ
diff -ruN dwm/dwm.c dwm.patched/dwm.c
--- dwm/dwm.c 2018-05-22 20:05:47.208417141 -0700
+++ dwm.patched/dwm.c 2018-06-20 15:08:07.380496725 -0700
@@ -147,6 +147,7 @@
static void arrange(Monitor *m);
static void arrangemon(Monitor *m);
static void attach(Client *c);
+static void attachbelow(Client *c);
static void attachstack(Client *c);
static void buttonpress(XEvent *e);
static void checkotherwm(void);
@@ -407,6 +408,17 @@
}
void
+attachbelow(Client *c)
+{
+ Client *below = c->mon->clients;
+ for (; below && below->next; below = below->next);
+ if (below)
+ below->next = c;
+ else
+ c->mon->clients = c;
+}
+
+void
attachstack(Client *c)
{
c->snext = c->mon->stack;
@@ -1065,7 +1077,7 @@
c->isfloating = c->oldstate = trans != None || c->isfixed;
if (c->isfloating)
XRaiseWindow(dpy, c->win);
- attach(c);
+ attachbelow(c);
attachstack(c);
XChangeProperty(dpy, root, netatom[NetClientList], XA_WINDOW, 32, PropModeAppend,
(unsigned char *) &(c->win), 1);
@@ -1420,7 +1432,7 @@
detachstack(c);
c->mon = m;
c->tags = m->tagset[m->seltags]; /* assign tags of target monitor */
- attach(c);
+ attachbelow(c);
attachstack(c);
focus(NULL);
arrange(NULL);
@@ -1900,7 +1912,7 @@
m->clients = c->next;
detachstack(c);
c->mon = mons;
- attach(c);
+ attachbelow(c);
attachstack(c);
}
if (m == selmon)
Binary files dwm/dwm.o and dwm.patched/dwm.o differ
Binary files dwm/util.o and dwm.patched/util.o differ
|