Xinqi Bao's Git
projects
/
dwm.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
bar shows if currently is tiled (Mod1-space) or floating (Mod1-Shift-space) mode
[dwm.git]
/
bar.c
diff --git
a/bar.c
b/bar.c
index
9914e56
..
953ac6b
100644
(file)
--- a/
bar.c
+++ b/
bar.c
@@
-5,36
+5,46
@@
#include "dwm.h"
#include "dwm.h"
+void
+barclick(XButtonPressedEvent *e)
+{
+ int x = 0;
+ Arg a;
+ for(a.i = 0; a.i < TLast; a.i++) {
+ x += textw(tags[a.i]) + dc.font.height;
+ if(e->x < x) {
+ view(&a);
+ return;
+ }
+ }
+}
+
void
draw_bar()
{
int i;
void
draw_bar()
{
int i;
+ char *mode = arrange == tiling ? "#" : "~";
+
dc.x = dc.y = 0;
dc.w = bw;
dc.x = dc.y = 0;
dc.w = bw;
- drawtext(NULL, False);
+ drawtext(NULL, False, False);
+
+ dc.w = textw(mode) + dc.font.height;
+ drawtext(mode, True, True);
- dc.w = 0;
for(i = 0; i < TLast; i++) {
dc.x += dc.w;
dc.w = textw(tags[i]) + dc.font.height;
for(i = 0; i < TLast; i++) {
dc.x += dc.w;
dc.w = textw(tags[i]) + dc.font.height;
- if(i == tsel) {
- swap((void **)&dc.fg, (void **)&dc.bg);
- drawtext(tags[i], True);
- swap((void **)&dc.fg, (void **)&dc.bg);
- }
- else
- drawtext(tags[i], True);
+ drawtext(tags[i], i == tsel, True);
}
if(sel) {
}
if(sel) {
- swap((void **)&dc.fg, (void **)&dc.bg);
dc.x += dc.w;
dc.w = textw(sel->name) + dc.font.height;
dc.x += dc.w;
dc.w = textw(sel->name) + dc.font.height;
- drawtext(sel->name, True);
- swap((void **)&dc.fg, (void **)&dc.bg);
+ drawtext(sel->name, True, True);
}
dc.w = textw(stext) + dc.font.height;
dc.x = bx + bw - dc.w;
}
dc.w = textw(stext) + dc.font.height;
dc.x = bx + bw - dc.w;
- drawtext(stext, False);
+ drawtext(stext, False
, False
);
XCopyArea(dpy, dc.drawable, barwin, dc.gc, 0, 0, bw, bh, 0, 0);
XFlush(dpy);
}
XCopyArea(dpy, dc.drawable, barwin, dc.gc, 0, 0, bw, bh, 0, 0);
XFlush(dpy);
}