queue warps and log more

This commit is contained in:
vaxerski 2022-01-05 11:00:11 +01:00
parent c194ca26c0
commit b4092dcbaf
2 changed files with 37 additions and 6 deletions

View file

@ -220,6 +220,9 @@ bool CWindowManager::handleEvent() {
// remove unused workspaces // remove unused workspaces
cleanupUnusedWorkspaces(); cleanupUnusedWorkspaces();
// Process the queued warp
dispatchQueuedWarp();
// Update last window name // Update last window name
updateActiveWindowName(); updateActiveWindowName();
@ -507,6 +510,9 @@ void CWindowManager::refreshDirtyWindows() {
void CWindowManager::setFocusedWindow(xcb_drawable_t window) { void CWindowManager::setFocusedWindow(xcb_drawable_t window) {
if (window && window != Screen->root) { if (window && window != Screen->root) {
Debug::log(LOG, "Setting focus to " + std::to_string(window));
// border color // border color
if (const auto PLASTWIN = getWindowFromDrawable(LastWindow); PLASTWIN) { if (const auto PLASTWIN = getWindowFromDrawable(LastWindow); PLASTWIN) {
PLASTWIN->setEffectiveBorderColor(CFloatingColor(ConfigManager::getInt("col.inactive_border"))); PLASTWIN->setEffectiveBorderColor(CFloatingColor(ConfigManager::getInt("col.inactive_border")));
@ -1472,7 +1478,7 @@ void CWindowManager::moveActiveWindowTo(char dir) {
// finish by moving the cursor to the new current window // finish by moving the cursor to the new current window
warpCursorTo(CURRENTWINDOW->getPosition() + CURRENTWINDOW->getSize() / 2.f); QueuedPointerWarp = Vector2D(CURRENTWINDOW->getPosition() + CURRENTWINDOW->getSize() / 2.f);
} }
CWindow* CWindowManager::getFullscreenWindowByWorkspace(const int& id) { CWindow* CWindowManager::getFullscreenWindowByWorkspace(const int& id) {
@ -1504,7 +1510,7 @@ void CWindowManager::moveActiveFocusTo(char dir) {
setFocusedWindow(NEIGHBOR->getDrawable()); setFocusedWindow(NEIGHBOR->getDrawable());
// finish by moving the cursor to the neighbor window // finish by moving the cursor to the neighbor window
warpCursorTo(NEIGHBOR->getPosition() + (NEIGHBOR->getSize() / 2.f)); QueuedPointerWarp = Vector2D(NEIGHBOR->getPosition() + (NEIGHBOR->getSize() / 2.f));
} }
void CWindowManager::changeWorkspaceByID(int ID) { void CWindowManager::changeWorkspaceByID(int ID) {
@ -1518,6 +1524,7 @@ void CWindowManager::changeWorkspaceByID(int ID) {
// Don't change if already opened // Don't change if already opened
if (isWorkspaceVisible(ID)) { if (isWorkspaceVisible(ID)) {
Debug::log(LOG, "Workspace visible, only focus.");
focusOnWorkspace(ID); focusOnWorkspace(ID);
return; return;
} }
@ -1531,6 +1538,8 @@ void CWindowManager::changeWorkspaceByID(int ID) {
for (auto& workspace : workspaces) { for (auto& workspace : workspaces) {
if (workspace.getID() == ID) { if (workspace.getID() == ID) {
Debug::log(LOG, "Workspace open, bringing to active.");
// set workspaces dirty // set workspaces dirty
setAllWorkspaceWindowsDirtyByID(activeWorkspaces[workspace.getMonitor()]); setAllWorkspaceWindowsDirtyByID(activeWorkspaces[workspace.getMonitor()]);
setAllWorkspaceWindowsDirtyByID(ID); setAllWorkspaceWindowsDirtyByID(ID);
@ -1545,6 +1554,8 @@ void CWindowManager::changeWorkspaceByID(int ID) {
// Update bar info // Update bar info
updateBarInfo(); updateBarInfo();
Debug::log(LOG, "Bar info updated with workspace changed.");
// Wipe animation // Wipe animation
startWipeAnimOnWorkspace(OLDWORKSPACE, ID); startWipeAnimOnWorkspace(OLDWORKSPACE, ID);
@ -1552,6 +1563,8 @@ void CWindowManager::changeWorkspaceByID(int ID) {
} }
} }
Debug::log(LOG, "New workspace, creating.");
// If we are here it means the workspace is new. Let's create it. // If we are here it means the workspace is new. Let's create it.
CWorkspace newWorkspace; CWorkspace newWorkspace;
newWorkspace.setID(ID); newWorkspace.setID(ID);
@ -1566,8 +1579,10 @@ void CWindowManager::changeWorkspaceByID(int ID) {
// Wipe animation // Wipe animation
startWipeAnimOnWorkspace(OLDWORKSPACE, ID); startWipeAnimOnWorkspace(OLDWORKSPACE, ID);
Debug::log(LOG, "New workspace created.");
if (getMonitorFromCursor() && MONITOR->ID != getMonitorFromCursor()->ID) if (getMonitorFromCursor() && MONITOR->ID != getMonitorFromCursor()->ID)
warpCursorTo(MONITOR->vecPosition + MONITOR->vecSize / 2.f); QueuedPointerWarp = Vector2D(MONITOR->vecPosition + MONITOR->vecSize / 2.f);
// no need for the new dirty, it's empty // no need for the new dirty, it's empty
} }
@ -1576,6 +1591,8 @@ void CWindowManager::focusOnWorkspace(const int& work) {
const auto PWORKSPACE = getWorkspaceByID(work); const auto PWORKSPACE = getWorkspaceByID(work);
const auto PMONITOR = getMonitorFromWorkspace(work); const auto PMONITOR = getMonitorFromWorkspace(work);
Debug::log(LOG, "Focusing on workspace " + std::to_string(work));
if (!PMONITOR) { if (!PMONITOR) {
Debug::log(ERR, "Orphaned workspace at focusOnWorkspace ???"); Debug::log(ERR, "Orphaned workspace at focusOnWorkspace ???");
return; return;
@ -1583,28 +1600,31 @@ void CWindowManager::focusOnWorkspace(const int& work) {
if (PWORKSPACE) { if (PWORKSPACE) {
if (!PWORKSPACE->getHasFullscreenWindow()) { if (!PWORKSPACE->getHasFullscreenWindow()) {
Debug::log(LOG, "No fullscreen window");
bool shouldHopToScreen = true; bool shouldHopToScreen = true;
for (auto& window : windows) { for (auto& window : windows) {
if (window.getWorkspaceID() == work && window.getDrawable() > 0) { if (window.getWorkspaceID() == work && window.getDrawable() > 0) {
setFocusedWindow(window.getDrawable()); setFocusedWindow(window.getDrawable());
if (getMonitorFromCursor() && getMonitorFromCursor()->ID != PMONITOR->ID) if (getMonitorFromCursor() && getMonitorFromCursor()->ID != PMONITOR->ID)
warpCursorTo(window.getPosition() + window.getSize() / 2.f); QueuedPointerWarp = Vector2D(window.getPosition() + window.getSize() / 2.f);
shouldHopToScreen = false; shouldHopToScreen = false;
Debug::log(LOG, "No hopping to new workspace");
break; break;
} }
} }
if (shouldHopToScreen) if (shouldHopToScreen)
warpCursorTo(PMONITOR->vecPosition + PMONITOR->vecSize / 2.f); QueuedPointerWarp = Vector2D(PMONITOR->vecPosition + PMONITOR->vecSize / 2.f);
} else { } else {
const auto PFULLWINDOW = getFullscreenWindowByWorkspace(work); const auto PFULLWINDOW = getFullscreenWindowByWorkspace(work);
if (PFULLWINDOW) { if (PFULLWINDOW) {
Debug::log(LOG, "Fullscreen window id " + std::to_string(PFULLWINDOW->getDrawable()));
setFocusedWindow(PFULLWINDOW->getDrawable()); setFocusedWindow(PFULLWINDOW->getDrawable());
if (getMonitorFromCursor() && getMonitorFromCursor()->ID != PMONITOR->ID) if (getMonitorFromCursor() && getMonitorFromCursor()->ID != PMONITOR->ID)
warpCursorTo(PFULLWINDOW->getPosition() + PFULLWINDOW->getSize() / 2.f); QueuedPointerWarp = Vector2D(PFULLWINDOW->getPosition() + PFULLWINDOW->getSize() / 2.f);
} }
} }
} }
@ -2145,4 +2165,12 @@ void CWindowManager::startWipeAnimOnWorkspace(const int& oldwork, const int& new
work.setAnimationInProgress(true); work.setAnimationInProgress(true);
} }
} }
}
void CWindowManager::dispatchQueuedWarp() {
if (QueuedPointerWarp.x == -1 && QueuedPointerWarp.y == -1)
return;
warpCursorTo(QueuedPointerWarp);
QueuedPointerWarp = Vector2D(-1,-1);
} }

View file

@ -64,6 +64,8 @@ public:
xcb_cursor_t pointerCursor; xcb_cursor_t pointerCursor;
xcb_cursor_context_t* pointerContext; xcb_cursor_context_t* pointerContext;
Vector2D QueuedPointerWarp = {-1, -1};
CWindow* getWindowFromDrawable(int64_t); CWindow* getWindowFromDrawable(int64_t);
void addWindowToVectorSafe(CWindow); void addWindowToVectorSafe(CWindow);
void removeWindowFromVectorSafe(int64_t); void removeWindowFromVectorSafe(int64_t);
@ -154,6 +156,7 @@ private:
void fixMasterWorkspaceOnClosed(CWindow* pWindow); void fixMasterWorkspaceOnClosed(CWindow* pWindow);
void startWipeAnimOnWorkspace(const int&, const int&); void startWipeAnimOnWorkspace(const int&, const int&);
void focusOnWorkspace(const int&); void focusOnWorkspace(const int&);
void dispatchQueuedWarp();
}; };
inline std::unique_ptr<CWindowManager> g_pWindowManager = std::make_unique<CWindowManager>(); inline std::unique_ptr<CWindowManager> g_pWindowManager = std::make_unique<CWindowManager>();