summaryrefslogtreecommitdiff
path: root/patch/vanitygaps.c
diff options
context:
space:
mode:
authorBear <bear@bengtsson.win>2021-12-27 09:29:58 +0000
committerBear <bear@bengtsson.win>2021-12-27 09:29:58 +0000
commit69262b01ced79c2d776fab9b889926d1816a1e7a (patch)
treef304cd6fa8734e83a7772d07dc9b484781565155 /patch/vanitygaps.c
Added DWM
Diffstat (limited to 'patch/vanitygaps.c')
-rw-r--r--patch/vanitygaps.c199
1 files changed, 199 insertions, 0 deletions
diff --git a/patch/vanitygaps.c b/patch/vanitygaps.c
new file mode 100644
index 0000000..be2ef08
--- /dev/null
+++ b/patch/vanitygaps.c
@@ -0,0 +1,199 @@
+/* Settings */
+#if !PERTAG_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;
+ #else
+ if (!enablegaps)
+ enablegaps = 1;
+ #endif // PERTAG_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];
+ #else
+ enablegaps = !enablegaps;
+ #endif // PERTAG_VANITYGAPS_PATCH
+ arrange(NULL);
+}
+
+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 = selmon->pertag->enablegaps[selmon->pertag->curtag];
+ #else
+ oe = ie = enablegaps;
+ #endif // PERTAG_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
+