/* Settings */ #if !(PERTAG_VANITYGAPS_PATCH || PERMON_VANITYGAPS_PATCH) static int enablegaps = 1; #endif // PERTAG_VANITYGAPS_PATCH static void setgaps(int oh, int ov, int ih, int iv) { if (oh < 0) oh = 0; if (ov < 0) ov = 0; if (ih < 0) ih = 0; if (iv < 0) iv = 0; selmon->gappoh = oh; selmon->gappov = ov; selmon->gappih = ih; selmon->gappiv = iv; #if PERTAG_VANITYGAPS_PATCH && PERTAG_PATCH selmon->pertag->gaps[selmon->pertag->curtag] = ((oh & 0xFF) << 0) | ((ov & 0xFF) << 8) | ((ih & 0xFF) << 16) | ((iv & 0xFF) << 24); #endif // PERTAG_VANITYGAPS_PATCH arrange(selmon); } #if IPC_PATCH || DWMC_PATCH /* External function that takes one integer and splits it * into four gap values: * - outer horizontal (oh) * - outer vertical (ov) * - inner horizontal (ih) * - inner vertical (iv) * * Each value is represented as one byte with the uppermost * bit of each byte indicating whether or not to keep the * current value. * * Example: * * 10000000 10000000 00001111 00001111 * | | | | * + keep oh + keep ov + ih 15px + iv 15px * * This gives an int of: * 10000000100000000000111100001111 = 2155876111 * * Thus this command should set inner gaps to 15: * xsetroot -name "fsignal:setgaps i 2155876111" */ static void setgapsex(const Arg *arg) { int oh = selmon->gappoh; int ov = selmon->gappov; int ih = selmon->gappih; int iv = selmon->gappiv; if (!(arg->i & (1 << 31))) oh = (arg->i & 0x7f000000) >> 24; if (!(arg->i & (1 << 23))) ov = (arg->i & 0x7f0000) >> 16; if (!(arg->i & (1 << 15))) ih = (arg->i & 0x7f00) >> 8; if (!(arg->i & (1 << 7))) iv = (arg->i & 0x7f); /* Auto enable gaps if disabled */ #if PERTAG_VANITYGAPS_PATCH && PERTAG_PATCH if (!selmon->pertag->enablegaps[selmon->pertag->curtag]) selmon->pertag->enablegaps[selmon->pertag->curtag] = 1; #elif PERMON_VANITYGAPS_PATCH selmon->enablegaps = 1; #else if (!enablegaps) enablegaps = 1; #endif // PERTAG_VANITYGAPS_PATCH | PERMON_VANITYGAPS_PATCH setgaps(oh, ov, ih, iv); } #endif // IPC_PATCH | DWMC_PATCH static void togglegaps(const Arg *arg) { #if PERTAG_VANITYGAPS_PATCH && PERTAG_PATCH selmon->pertag->enablegaps[selmon->pertag->curtag] = !selmon->pertag->enablegaps[selmon->pertag->curtag]; #elif PERMON_VANITYGAPS_PATCH selmon->enablegaps = !selmon->enablegaps; #else enablegaps = !enablegaps; #endif // PERTAG_VANITYGAPS_PATCH | PERMON_VANITYGAPS_PATCH #if BAR_PADDING_VANITYGAPS_PATCH #if PERMON_VANITYGAPS_PATCH updatebarpos(selmon); for (Bar *bar = selmon->bar; bar; bar = bar->next) XMoveResizeWindow(dpy, bar->win, bar->bx, bar->by, bar->bw, bar->bh); #else for (Monitor *m = mons; m; m = m->next) { updatebarpos(m); for (Bar *bar = m->bar; bar; bar = bar->next) XMoveResizeWindow(dpy, bar->win, bar->bx, bar->by, bar->bw, bar->bh); } #endif // PERMON_VANITYGAPS_PATCH #if BAR_SYSTRAY_PATCH drawbarwin(systray->bar); #endif // BAR_SYSTRAY_PATCH #endif // BAR_PADDING_VANITYGAPS_PATCH #if (PERTAG_VANITYGAPS_PATCH && PERTAG_PATCH) || PERMON_VANITYGAPS_PATCH arrange(selmon); #else arrange(NULL); #endif // PERTAG_VANITYGAPS_PATCH | PERMON_VANITYGAPS_PATCH } static void defaultgaps(const Arg *arg) { setgaps(gappoh, gappov, gappih, gappiv); } static void incrgaps(const Arg *arg) { setgaps( selmon->gappoh + arg->i, selmon->gappov + arg->i, selmon->gappih + arg->i, selmon->gappiv + arg->i ); } static void incrigaps(const Arg *arg) { setgaps( selmon->gappoh, selmon->gappov, selmon->gappih + arg->i, selmon->gappiv + arg->i ); } static void incrogaps(const Arg *arg) { setgaps( selmon->gappoh + arg->i, selmon->gappov + arg->i, selmon->gappih, selmon->gappiv ); } static void incrohgaps(const Arg *arg) { setgaps( selmon->gappoh + arg->i, selmon->gappov, selmon->gappih, selmon->gappiv ); } static void incrovgaps(const Arg *arg) { setgaps( selmon->gappoh, selmon->gappov + arg->i, selmon->gappih, selmon->gappiv ); } static void incrihgaps(const Arg *arg) { setgaps( selmon->gappoh, selmon->gappov, selmon->gappih + arg->i, selmon->gappiv ); } static void incrivgaps(const Arg *arg) { setgaps( selmon->gappoh, selmon->gappov, selmon->gappih, selmon->gappiv + arg->i ); } #if DRAGMFACT_PATCH || CENTEREDMASTER_LAYOUT || CENTEREDFLOATINGMASTER_LAYOUT || COLUMNS_LAYOUT || DECK_LAYOUT || FIBONACCI_DWINDLE_LAYOUT || FIBONACCI_SPIRAL_LAYOUT || GAPPLESSGRID_LAYOUT || NROWGRID_LAYOUT || HORIZGRID_LAYOUT || BSTACK_LAYOUT || BSTACKHORIZ_LAYOUT || GRIDMODE_LAYOUT || FLEXTILE_DELUXE_LAYOUT || TILE_LAYOUT || (VANITYGAPS_MONOCLE_PATCH && MONOCLE_LAYOUT) static void getgaps(Monitor *m, int *oh, int *ov, int *ih, int *iv, unsigned int *nc) { unsigned int n, oe, ie; #if PERTAG_VANITYGAPS_PATCH && PERTAG_PATCH oe = ie = m->pertag->enablegaps[m->pertag->curtag]; #elif PERMON_VANITYGAPS_PATCH oe = ie = m->enablegaps; #else oe = ie = enablegaps; #endif // PERTAG_VANITYGAPS_PATCH | PERMON_VANITYGAPS_PATCH Client *c; for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++); if (n == 1) { oe *= smartgaps_fact; // outer gaps disabled or multiplied when only one client } *oh = m->gappoh*oe; // outer horizontal gap *ov = m->gappov*oe; // outer vertical gap *ih = m->gappih*ie; // inner horizontal gap *iv = m->gappiv*ie; // inner vertical gap *nc = n; // number of clients } #endif