{ Mod1Mask, XK_m, max, { 0 } },
{ Mod1Mask, XK_0, view, { .i = Tscratch } },
{ Mod1Mask, XK_1, view, { .i = Tdev } },
- { Mod1Mask, XK_2, view, { .i = Tirc } },
- { Mod1Mask, XK_3, view, { .i = Twww } },
- { Mod1Mask, XK_4, view, { .i = Twork } },
+ { Mod1Mask, XK_2, view, { .i = Twww } },
+ { Mod1Mask, XK_3, view, { .i = Twork } },
{ Mod1Mask, XK_space, tiling, { 0 } },
{ Mod1Mask|ShiftMask, XK_space, floating, { 0 } },
{ Mod1Mask|ShiftMask, XK_0, ttrunc, { .i = Tscratch } },
{ Mod1Mask|ShiftMask, XK_1, ttrunc, { .i = Tdev } },
- { Mod1Mask|ShiftMask, XK_2, ttrunc, { .i = Tirc } },
- { Mod1Mask|ShiftMask, XK_3, ttrunc, { .i = Twww } },
- { Mod1Mask|ShiftMask, XK_4, ttrunc, { .i = Twork } },
+ { Mod1Mask|ShiftMask, XK_2, ttrunc, { .i = Twww } },
+ { Mod1Mask|ShiftMask, XK_3, ttrunc, { .i = Twork } },
{ Mod1Mask|ShiftMask, XK_c, ckill, { 0 } },
{ Mod1Mask|ShiftMask, XK_q, quit, { 0 } },
{ Mod1Mask|ShiftMask, XK_Return, spawn, { .argv = term } },
{ Mod1Mask|ShiftMask, XK_l, spawn, { .argv = xlock } },
{ ControlMask, XK_0, tappend, { .i = Tscratch } },
{ ControlMask, XK_1, tappend, { .i = Tdev } },
- { ControlMask, XK_2, tappend, { .i = Tirc } },
- { ControlMask, XK_3, tappend, { .i = Twww } },
- { ControlMask, XK_4, tappend, { .i = Twork } },
+ { ControlMask, XK_2, tappend, { .i = Twww } },
+ { ControlMask, XK_3, tappend, { .i = Twork } },
};
/********** CUSTOMIZE **********/
* See LICENSE file for license details.
*/
+#include <errno.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include <unistd.h>
#include <X11/cursorfont.h>
#include <X11/Xatom.h>
char *tags[TLast] = {
[Tscratch] = "scratch",
[Tdev] = "dev",
- [Tirc] = "irc",
[Twww] = "www",
[Twork] = "work",
};
int
main(int argc, char *argv[])
{
- int i;
+ int i, n;
+ fd_set rd;
XSetWindowAttributes wa;
unsigned int mask;
Window w;
XEvent ev;
- /* command line args */
for(i = 1; (i < argc) && (argv[i][0] == '-'); i++) {
switch (argv[i][1]) {
case 'v':
scan_wins();
draw_bar();
+ /* main event loop, reads status text from stdin as well */
while(running) {
- XNextEvent(dpy, &ev);
- if(handler[ev.type])
- (handler[ev.type])(&ev); /* call handler */
+ FD_ZERO(&rd);
+ FD_SET(0, &rd);
+ FD_SET(ConnectionNumber(dpy), &rd);
+
+ i = select(ConnectionNumber(dpy) + 1, &rd, 0, 0, 0);
+ if(i == -1 && errno == EINTR)
+ continue;
+ if(i < 0)
+ error("select failed\n");
+ else if(i > 0) {
+ if(FD_ISSET(ConnectionNumber(dpy), &rd) && XPending(dpy) > 0) {
+ XNextEvent(dpy, &ev);
+ if(handler[ev.type])
+ (handler[ev.type])(&ev); /* call handler */
+ }
+ if(FD_ISSET(0, &rd)) {
+ i = n = 0;
+ while((i = getchar()) != '\n' && n < sizeof(stext) - 1)
+ stext[n++] = i;
+ stext[n] = 0;
+ draw_bar();
+ }
+ }
}
cleanup();