-
Notifications
You must be signed in to change notification settings - Fork 0
/
lockwm.patch
83 lines (79 loc) · 2.07 KB
/
lockwm.patch
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
--- /Users/brian/dwm/dwm-6.0/dwm.c 2011-12-19 08:02:46.000000000 -0700
+++ ./dwm.c 2015-04-28 19:16:00.000000000 -0600
@@ -90,7 +90,7 @@
int basew, baseh, incw, inch, maxw, maxh, minw, minh;
int bw, oldbw;
unsigned int tags;
- Bool isfixed, isfloating, isurgent, neverfocus, oldstate, isfullscreen;
+ Bool isfixed, isfloating, isurgent, neverfocus, oldstate, isfullscreen, islocked;
Client *next;
Client *snext;
Monitor *mon;
@@ -151,6 +151,7 @@
const char *title;
unsigned int tags;
Bool isfloating;
+ Bool islocked;
int monitor;
} Rule;
@@ -313,6 +314,7 @@
{
c->isfloating = r->isfloating;
c->tags |= r->tags;
+ c->islocked = r->islocked;
for(m = mons; m && m->num != r->monitor; m = m->next);
if(m)
c->mon = m;
@@ -724,8 +726,11 @@
for(c = m->clients; c; c = c->next) {
occ |= c->tags;
- if(c->isurgent)
- urg |= c->tags;
+ if (!c->islocked) {
+ occ |= c->tags;
+ if(c->isurgent)
+ urg |= c->tags;
+ }
}
dc.x = 0;
for(i = 0; i < LENGTH(tags); i++) {
@@ -1677,15 +1682,17 @@
void
tag(const Arg *arg) {
if(selmon->sel && arg->ui & TAGMASK) {
- selmon->sel->tags = arg->ui & TAGMASK;
- focus(NULL);
- arrange(selmon);
+ if (!selmon->sel->islocked) {
+ selmon->sel->tags = arg->ui & TAGMASK;
+ focus(NULL);
+ arrange(selmon);
+ }
}
}
void
tagmon(const Arg *arg) {
- if(!selmon->sel || !mons->next)
+ if(!selmon->sel || !mons->next)
return;
sendmon(selmon->sel, dirtomon(arg->i));
}
@@ -1739,7 +1746,9 @@
togglefloating(const Arg *arg) {
if(!selmon->sel)
return;
- selmon->sel->isfloating = !selmon->sel->isfloating || selmon->sel->isfixed;
+ if (selmon->sel->islocked)
+ return;
+ selmon->sel->isfloating = !selmon->sel->isfloating || selmon->sel->isfixed;
if(selmon->sel->isfloating)
resize(selmon->sel, selmon->sel->x, selmon->sel->y,
selmon->sel->w, selmon->sel->h, False);
@@ -1752,6 +1761,8 @@
if(!selmon->sel)
return;
+ if (selmon->sel->islocked)
+ return;
newtags = selmon->sel->tags ^ (arg->ui & TAGMASK);
if(newtags) {
selmon->sel->tags = newtags;