From 4a07bd68dd3e3ccdf613ebc1b7114dd277e29c47 Mon Sep 17 00:00:00 2001 From: BossCode45 Date: Thu, 25 Aug 2022 16:33:36 +1200 Subject: Moving windows betweeen workspaces --- main.cpp | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) (limited to 'main.cpp') diff --git a/main.cpp b/main.cpp index 2066993..1724b82 100644 --- a/main.cpp +++ b/main.cpp @@ -104,6 +104,30 @@ void changeWS(const KeyArg arg) tile(currWS, outerGaps, outerGaps, sW - outerGaps*2, sH - outerGaps*2); XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); } +void wToWS(const KeyArg arg) +{ + Window focusedWindow; + int revertToReturn; + XGetInputFocus(dpy, &focusedWindow, &revertToReturn); + if(focusedWindow == root) + return; + + int fID = frameIDS.find(focusedWindow)->second; + vector& pSF = frames.find(frames.find(fID)->second.pID)->second.subFrameIDs; + for(int i = 0; i < pSF.size(); i++) + { + if(pSF[i] == fID) + { + pSF.erase(pSF.begin() + i); + break; + } + } + frames.find(fID)->second.pID = arg.num; + frames.find(arg.num)->second.subFrameIDs.push_back(fID); + XUnmapWindow(dpy, focusedWindow); + tile(currWS, outerGaps, outerGaps, sW - outerGaps*2, sH - outerGaps*2); + XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); +} void keyPress(XKeyEvent e) { @@ -236,6 +260,7 @@ void destroyNotify(XDestroyWindowEvent e) break; } } + XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); tile(currWS, outerGaps, outerGaps, sW - outerGaps*2, sH - outerGaps*2); } -- cgit v1.2.3