aboutsummaryrefslogtreecommitdiffstats
path: root/dwm.c
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@vidhukant.com>2025-05-10 19:53:23 +0530
committerVidhu Kant Sharma <vidhukant@vidhukant.com>2025-05-10 19:53:23 +0530
commit480532692b4f41d2cf990012327e7b47cc2fb3f0 (patch)
tree34fa0c00bfe5513a3681a6acfc776d0ab97b4825 /dwm.c
parentf2558593e41a462b7137954c1b27d79fa42851aa (diff)
patched dwm-movekeyboard-6.4.diff
Diffstat (limited to 'dwm.c')
-rw-r--r--dwm.c88
1 files changed, 88 insertions, 0 deletions
diff --git a/dwm.c b/dwm.c
index 56784ff..37ca293 100644
--- a/dwm.c
+++ b/dwm.c
@@ -185,6 +185,8 @@ static void maprequest(XEvent *e);
static void monocle(Monitor *m);
static void motionnotify(XEvent *e);
static void movemouse(const Arg *arg);
+static void movekeyboard_x(const Arg *arg);
+static void movekeyboard_y(const Arg *arg);
static Client *nexttiled(Client *c);
static void pop(Client *c);
static void propertynotify(XEvent *e);
@@ -1206,6 +1208,92 @@ movemouse(const Arg *arg)
}
}
+void
+movekeyboard_x(const Arg *arg){
+ int ocx, ocy, nx, ny;
+ Client *c;
+ Monitor *m;
+
+ if (!(c = selmon->sel))
+ return;
+
+ if (c->isfullscreen) /* no support moving fullscreen windows by mouse */
+ return;
+
+ restack(selmon);
+
+ ocx = c->x;
+ ocy = c->y;
+
+ nx = ocx + arg->i;
+ ny = ocy;
+
+ if (abs(selmon->wx - nx) < snap)
+ nx = selmon->wx;
+ else if (abs((selmon->wx + selmon->ww) - (nx + WIDTH(c))) < snap)
+ nx = selmon->wx + selmon->ww - WIDTH(c);
+
+ if (abs(selmon->wy - ny) < snap)
+ ny = selmon->wy;
+ else if (abs((selmon->wy + selmon->wh) - (ny + HEIGHT(c))) < snap)
+ ny = selmon->wy + selmon->wh - HEIGHT(c);
+
+ if (!c->isfloating)
+ togglefloating(NULL);
+
+ if (!selmon->lt[selmon->sellt]->arrange || c->isfloating)
+ resize(c, nx, ny, c->w, c->h, 1);
+
+ if ((m = recttomon(c->x, c->y, c->w, c->h)) != selmon) {
+ sendmon(c, m);
+ selmon = m;
+ focus(NULL);
+ }
+}
+
+void
+movekeyboard_y(const Arg *arg){
+ int ocx, ocy, nx, ny;
+ Client *c;
+ Monitor *m;
+
+ if (!(c = selmon->sel))
+ return;
+
+ if (c->isfullscreen) /* no support moving fullscreen windows by mouse */
+ return;
+
+ restack(selmon);
+
+ ocx = c->x;
+ ocy = c->y;
+
+ nx = ocx;
+ ny = ocy + arg->i;
+
+ if (abs(selmon->wx - nx) < snap)
+ nx = selmon->wx;
+ else if (abs((selmon->wx + selmon->ww) - (nx + WIDTH(c))) < snap)
+ nx = selmon->wx + selmon->ww - WIDTH(c);
+
+ if (abs(selmon->wy - ny) < snap)
+ ny = selmon->wy;
+ else if (abs((selmon->wy + selmon->wh) - (ny + HEIGHT(c))) < snap)
+ ny = selmon->wy + selmon->wh - HEIGHT(c);
+
+ if (!c->isfloating)
+ togglefloating(NULL);
+
+ if (!selmon->lt[selmon->sellt]->arrange || c->isfloating)
+ resize(c, nx, ny, c->w, c->h, 1);
+
+ if ((m = recttomon(c->x, c->y, c->w, c->h)) != selmon) {
+ sendmon(c, m);
+ selmon = m;
+ focus(NULL);
+ }
+}
+
Client *
nexttiled(Client *c)
{