about summary refs log tree commit diff stats
Commit message (Collapse)AuthorAgeFilesLines
...
* | | Merge branch 'master' into developSilvino Silva2018-07-1874-1376/+1199
|\ \ \ | |/ / |/| / | |/
| * release 0.3.5Silvino Silva2018-07-1784-2295/+2276
| |\
| | * release revisionSilvino Silva2018-07-1712-1026/+1065
| | |
| | * dumped new version 0.3.5Silvino Silva2018-07-1666-350/+134
| | |
| * | Doc version 0.0.4Silvino Silva2018-04-1124-863/+1413
| |\ \
| * \ \ Release 0.3.3Silvino Silva2018-04-0670-6664/+5949
| |\ \ \
| * \ \ \ release 0.3.2Silvino Silva2017-09-2730-475/+1275
| |\ \ \ \
* | | | | | better comments backup-systemSilvino Silva2018-07-171-8/+8
| |_|_|_|/ |/| | | |
* | | | | core linux, backup and iptables script fixSilvino Silva2018-07-163-55/+151
| | | | |
* | | | | setup-iso revisionSilvino Silva2018-07-091-18/+85
| | | | |
* | | | | fix iptables let ssh out if serverSilvino Silva2018-06-121-6/+8
| | | | |
* | | | | network, iptables, sshd config fix'sSilvino Silva2018-06-125-296/+404
| | | | |
* | | | | vai tomar no cuSilvino Silva2018-05-182-8/+156
| | | | |
* | | | | allow client https to tap2Silvino Silva2018-05-061-1/+5
| | | | |
* | | | | added https client to server iptablesSilvino Silva2018-05-061-1/+2
| | | | |
* | | | | added dns server to brigdeSilvino Silva2018-05-061-0/+3
| | | | |
* | | | | iptables server revisionSilvino Silva2018-05-062-6/+21
| | | | |
* | | | | iptables, failtoban and dnsmasq revisionSilvino Silva2018-05-065-413/+53
| | | | |
* | | | | initial iptables revisionSilvino Silva2018-05-063-385/+455
| | | | |
* | | | | tools fix init git-daemon permSilvino Silva2018-04-131-1/+1
| | | | |
* | | | | gitolite revisionSilvino Silva2018-04-132-25/+28
| | | | |
* | | | | fix git-daemon init scriptSilvino Silva2018-04-121-1/+2
| | | | |
* | | | | Merge branch 'r-0.0.4' into developSilvino Silva2018-04-111-12/+10
|\ \ \ \ \ | | |_|_|/ | |/| | |
| * | | | index revisionSilvino Silva2018-04-111-11/+9
| | | | |
| * | | | fix index versionSilvino Silva2018-04-111-1/+1
|/ / / /
* | | | tools gitolite fix deploy permSilvino Silva2018-04-112-8/+16
| | | |
* | | | tools gitolite fix deploy scriptSilvino Silva2018-04-111-65/+241
| | | |
* | | | iptables moved to coreSilvino Silva2018-04-1110-547/+87
| | | |
* | | | tools syslogng revisionSilvino Silva2018-04-103-127/+20
| | | |
* | | | iptables revisionSilvino Silva2018-04-102-8/+415
| | | |
* | | | core added how to recover root passSilvino Silva2018-04-092-5/+34
| | | |
* | | | added nbd to kernelSilvino Silva2018-04-087-507/+1006
| | | |
* | | | Merge branch 'r-0.3.3' into developSilvino Silva2018-04-0670-6672/+5948
|\ \ \ \ | | |_|/ | |/| |
| * | | core fstab and linux-gnu port updatedSilvino Silva2018-04-067-480/+1827
| | | |
| * | | core apparmor parserSilvino Silva2018-04-041-0/+63
| | | |
| * | | core apparmor fstabSilvino Silva2018-04-031-0/+6
| | | |
| * | | iptables script revisionSilvino Silva2018-04-031-154/+223
| | | |
| * | | apparmor and hardening revisionSilvino Silva2018-04-032-10/+24
| | | |
| * | | dev php testingSilvino Silva2018-04-032-1/+51
| | | |
| * | | tools iptables revisionSilvino Silva2018-04-032-142/+167
| | | |
| * | | fstab to check file systemsSilvino Silva2018-04-031-8/+8
| | | |
| * | | dev c lib and index revisionSilvino Silva2018-04-032-128/+218
| | | |
| * | | tools storage, qemu, lvm revisionSilvino Silva2018-03-124-13/+87
| | | |
| * | | dev c added initial librariesSilvino Silva2018-03-126-211/+419
| | | |
| * | | core linux better config documentationSilvino Silva2018-03-103-242/+786
| | | |
| * | | core linux kernel revisionSilvino Silva2018-03-086-319/+40
| | | |
| * | | core linux and reboot revisionSilvino Silva2018-03-082-11/+10
| | | |
| * | | core linux-gnu port updatedSilvino Silva2018-03-0814-5507/+1710
| | | |
| * | | core reboot and linux revisionSilvino Silva2018-03-083-63/+44
| | | |
| * | | dev c datatypes initial documentSilvino Silva2018-03-072-2/+107
| | | |
">j = 0; j < modmap->max_keypermod; j++) { if(modmap->modifiermap[i * modmap->max_keypermod + j] == XKeysymToKeycode(dpy, XK_Num_Lock)) numlockmask = (1 << i); } } XFreeModifiermap(modmap); /* select for events */ wa.event_mask = SubstructureRedirectMask | SubstructureNotifyMask | EnterWindowMask | LeaveWindowMask; wa.cursor = cursor[CurNormal]; XChangeWindowAttributes(dpy, root, CWEventMask | CWCursor, &wa); grabkeys(); initrregs(); for(ntags = 0; tags[ntags]; ntags++); seltag = emallocz(sizeof(Bool) * ntags); seltag[0] = True; /* style */ dc.norm[ColBG] = getcolor(NORMBGCOLOR); dc.norm[ColFG] = getcolor(NORMFGCOLOR); dc.sel[ColBG] = getcolor(SELBGCOLOR); dc.sel[ColFG] = getcolor(SELFGCOLOR); dc.status[ColBG] = getcolor(STATUSBGCOLOR); dc.status[ColFG] = getcolor(STATUSFGCOLOR); setfont(FONT); /* geometry */ bmw = textw(TILESYMBOL) > textw(FLOATSYMBOL) ? textw(TILESYMBOL) : textw(FLOATSYMBOL); sx = sy = 0; sw = DisplayWidth(dpy, screen); sh = DisplayHeight(dpy, screen); master = MASTER; /* bar */ bx = sx; by = sy; bw = sw; dc.h = bh = dc.font.height + 2; wa.override_redirect = 1; wa.background_pixmap = ParentRelative; wa.event_mask = ButtonPressMask | ExposureMask; barwin = XCreateWindow(dpy, root, bx, by, bw, bh, 0, DefaultDepth(dpy, screen), CopyFromParent, DefaultVisual(dpy, screen), CWOverrideRedirect | CWBackPixmap | CWEventMask, &wa); XDefineCursor(dpy, barwin, cursor[CurNormal]); XMapRaised(dpy, barwin); strcpy(stext, "dwm-"VERSION); /* windowarea */ wax = sx; way = sy + bh; wah = sh - bh; waw = sw; /* pixmap for everything */ dc.drawable = XCreatePixmap(dpy, root, sw, bh, DefaultDepth(dpy, screen)); dc.gc = XCreateGC(dpy, root, 0, 0); XSetLineAttributes(dpy, dc.gc, 1, LineSolid, CapButt, JoinMiter); /* multihead support */ issel = XQueryPointer(dpy, root, &w, &w, &i, &i, &i, &i, &mask); } /* * Startup Error handler to check if another window manager * is already running. */ static int xerrorstart(Display *dsply, XErrorEvent *ee) { otherwm = True; return -1; } /* extern */ int getproto(Window w) { int i, format, protos, status; unsigned long extra, res; Atom *protocols, real; protos = 0; status = XGetWindowProperty(dpy, w, wmatom[WMProtocols], 0L, 20L, False, XA_ATOM, &real, &format, &res, &extra, (unsigned char **)&protocols); if(status != Success || protocols == 0) return protos; for(i = 0; i < res; i++) if(protocols[i] == wmatom[WMDelete]) protos |= PROTODELWIN; free(protocols); return protos; } void sendevent(Window w, Atom a, long value) { XEvent e; e.type = ClientMessage; e.xclient.window = w; e.xclient.message_type = a; e.xclient.format = 32; e.xclient.data.l[0] = value; e.xclient.data.l[1] = CurrentTime; XSendEvent(dpy, w, False, NoEventMask, &e); XSync(dpy, False); } void quit(Arg *arg) { readin = running = False; } /* There's no way to check accesses to destroyed windows, thus those cases are * ignored (especially on UnmapNotify's). Other types of errors call Xlibs * default error handler, which may call exit. */ int xerror(Display *dpy, XErrorEvent *ee) { if(ee->error_code == BadWindow || (ee->request_code == X_SetInputFocus && ee->error_code == BadMatch) || (ee->request_code == X_PolyText8 && ee->error_code == BadDrawable) || (ee->request_code == X_PolyFillRectangle && ee->error_code == BadDrawable) || (ee->request_code == X_PolySegment && ee->error_code == BadDrawable) || (ee->request_code == X_ConfigureWindow && ee->error_code == BadMatch) || (ee->request_code == X_GrabKey && ee->error_code == BadAccess) || (ee->request_code == X_CopyArea && ee->error_code == BadDrawable)) return 0; fprintf(stderr, "dwm: fatal error: request code=%d, error code=%d\n", ee->request_code, ee->error_code); return xerrorxlib(dpy, ee); /* may call exit */ } int main(int argc, char *argv[]) { char *p; int r, xfd; fd_set rd; if(argc == 2 && !strncmp("-v", argv[1], 3)) { fputs("dwm-"VERSION", (C)opyright MMVI-MMVII Anselm R. Garbe\n", stdout); exit(EXIT_SUCCESS); } else if(argc != 1) eprint("usage: dwm [-v]\n"); setlocale(LC_CTYPE, ""); dpy = XOpenDisplay(0); if(!dpy) eprint("dwm: cannot open display\n"); xfd = ConnectionNumber(dpy); screen = DefaultScreen(dpy); root = RootWindow(dpy, screen); otherwm = False; XSetErrorHandler(xerrorstart); /* this causes an error if some other window manager is running */ XSelectInput(dpy, root, SubstructureRedirectMask); XSync(dpy, False); if(otherwm) eprint("dwm: another window manager is already running\n"); XSync(dpy, False); XSetErrorHandler(NULL); xerrorxlib = XSetErrorHandler(xerror); XSync(dpy, False); setup(); drawstatus(); scan(); /* main event loop, also reads status text from stdin */ XSync(dpy, False); procevent(); readin = True; while(running) { FD_ZERO(&rd); if(readin) FD_SET(STDIN_FILENO, &rd); FD_SET(xfd, &rd); if(select(xfd + 1, &rd, NULL, NULL, NULL) == -1) { if(errno == EINTR) continue; eprint("select failed\n"); } if(FD_ISSET(STDIN_FILENO, &rd)) { switch(r = read(STDIN_FILENO, stext, sizeof stext - 1)) { case -1: strncpy(stext, strerror(errno), sizeof stext - 1); stext[sizeof stext - 1] = '\0'; readin = False; break; case 0: strncpy(stext, "EOF", 4); readin = False; break; default: for(stext[r] = '\0', p = stext + strlen(stext) - 1; p >= stext && *p == '\n'; *p-- = '\0'); for(p = stext + strlen(stext) - 1; p >= stext && *p != '\n'; --p); if(p > stext) strncpy(stext, p + 1, sizeof stext); } drawstatus(); } if(FD_ISSET(xfd, &rd)) procevent(); } cleanup(); XCloseDisplay(dpy); return 0; }