mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-22 21:25:58 +01:00
keybinds: Better handling of workspace_back_and_forth (#4952)
* Removed redundant boolean condition * Better handling of workspace_back_and_forth when using focusworkspaceoncurrentmonitor dispatcher * Fixed config acquisition --------- Co-authored-by: Tom Benham <tom.benham@quadrille.fr>
This commit is contained in:
parent
12da0fc84f
commit
07c7235b72
2 changed files with 28 additions and 12 deletions
|
@ -2042,6 +2042,9 @@ void CCompositor::swapActiveWorkspaces(CMonitor* pMonitorA, CMonitor* pMonitorB)
|
||||||
pMonitorA->activeWorkspace = PWORKSPACEB->m_iID;
|
pMonitorA->activeWorkspace = PWORKSPACEB->m_iID;
|
||||||
pMonitorB->activeWorkspace = PWORKSPACEA->m_iID;
|
pMonitorB->activeWorkspace = PWORKSPACEA->m_iID;
|
||||||
|
|
||||||
|
PWORKSPACEA->rememberPrevWorkspace(PWORKSPACEB);
|
||||||
|
PWORKSPACEB->rememberPrevWorkspace(PWORKSPACEA);
|
||||||
|
|
||||||
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(pMonitorA->ID);
|
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(pMonitorA->ID);
|
||||||
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(pMonitorB->ID);
|
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(pMonitorB->ID);
|
||||||
|
|
||||||
|
@ -2150,7 +2153,7 @@ void CCompositor::moveWorkspaceToMonitor(CWorkspace* pWorkspace, CMonitor* pMoni
|
||||||
|
|
||||||
// fix old mon
|
// fix old mon
|
||||||
int nextWorkspaceOnMonitorID = -1;
|
int nextWorkspaceOnMonitorID = -1;
|
||||||
if (!SWITCHINGISACTIVE || !POLDMON)
|
if (!SWITCHINGISACTIVE)
|
||||||
nextWorkspaceOnMonitorID = pWorkspace->m_iID;
|
nextWorkspaceOnMonitorID = pWorkspace->m_iID;
|
||||||
else {
|
else {
|
||||||
for (auto& w : m_vWorkspaces) {
|
for (auto& w : m_vWorkspaces) {
|
||||||
|
|
|
@ -1546,9 +1546,9 @@ void CKeybindManager::moveWorkspaceToMonitor(std::string args) {
|
||||||
|
|
||||||
void CKeybindManager::focusWorkspaceOnCurrentMonitor(std::string args) {
|
void CKeybindManager::focusWorkspaceOnCurrentMonitor(std::string args) {
|
||||||
std::string workspaceName;
|
std::string workspaceName;
|
||||||
const int WORKSPACEID = getWorkspaceIDFromString(args, workspaceName);
|
int workspaceID = getWorkspaceIDFromString(args, workspaceName);
|
||||||
|
|
||||||
if (WORKSPACEID == WORKSPACE_INVALID) {
|
if (workspaceID == WORKSPACE_INVALID) {
|
||||||
Debug::log(ERR, "focusWorkspaceOnCurrentMonitor invalid workspace!");
|
Debug::log(ERR, "focusWorkspaceOnCurrentMonitor invalid workspace!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1560,30 +1560,43 @@ void CKeybindManager::focusWorkspaceOnCurrentMonitor(std::string args) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto PWORKSPACE = g_pCompositor->getWorkspaceByID(WORKSPACEID);
|
auto pWorkspace = g_pCompositor->getWorkspaceByID(workspaceID);
|
||||||
|
|
||||||
if (!PWORKSPACE) {
|
if (!pWorkspace) {
|
||||||
PWORKSPACE = g_pCompositor->createNewWorkspace(WORKSPACEID, PCURRMONITOR->ID);
|
pWorkspace = g_pCompositor->createNewWorkspace(workspaceID, PCURRMONITOR->ID);
|
||||||
// we can skip the moving, since it's already on the current monitor
|
// we can skip the moving, since it's already on the current monitor
|
||||||
changeworkspace(PWORKSPACE->getConfigName());
|
changeworkspace(pWorkspace->getConfigName());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (PWORKSPACE->m_iMonitorID != PCURRMONITOR->ID) {
|
static auto PBACKANDFORTH = CConfigValue<Hyprlang::INT>("binds:workspace_back_and_forth");
|
||||||
const auto POLDMONITOR = g_pCompositor->getMonitorFromID(PWORKSPACE->m_iMonitorID);
|
|
||||||
|
if (*PBACKANDFORTH && PCURRMONITOR->activeWorkspace == workspaceID && pWorkspace->m_sPrevWorkspace.iID != -1) {
|
||||||
|
const int PREVWORKSPACEID = pWorkspace->m_sPrevWorkspace.iID;
|
||||||
|
const auto PREVWORKSPACENAME = pWorkspace->m_sPrevWorkspace.name;
|
||||||
|
// Workspace to focus is previous workspace
|
||||||
|
pWorkspace = g_pCompositor->getWorkspaceByID(PREVWORKSPACEID);
|
||||||
|
if (!pWorkspace)
|
||||||
|
pWorkspace = g_pCompositor->createNewWorkspace(PREVWORKSPACEID, PCURRMONITOR->ID, PREVWORKSPACENAME);
|
||||||
|
|
||||||
|
workspaceID = pWorkspace->m_iID;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pWorkspace->m_iMonitorID != PCURRMONITOR->ID) {
|
||||||
|
const auto POLDMONITOR = g_pCompositor->getMonitorFromID(pWorkspace->m_iMonitorID);
|
||||||
if (!POLDMONITOR) { // wat
|
if (!POLDMONITOR) { // wat
|
||||||
Debug::log(ERR, "focusWorkspaceOnCurrentMonitor old monitor doesn't exist!");
|
Debug::log(ERR, "focusWorkspaceOnCurrentMonitor old monitor doesn't exist!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (POLDMONITOR->activeWorkspace == WORKSPACEID) {
|
if (POLDMONITOR->activeWorkspace == workspaceID) {
|
||||||
g_pCompositor->swapActiveWorkspaces(POLDMONITOR, PCURRMONITOR);
|
g_pCompositor->swapActiveWorkspaces(POLDMONITOR, PCURRMONITOR);
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
g_pCompositor->moveWorkspaceToMonitor(PWORKSPACE, PCURRMONITOR, true);
|
g_pCompositor->moveWorkspaceToMonitor(pWorkspace, PCURRMONITOR, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
changeworkspace(PWORKSPACE->getConfigName());
|
changeworkspace(pWorkspace->getConfigName());
|
||||||
}
|
}
|
||||||
|
|
||||||
void CKeybindManager::toggleSpecialWorkspace(std::string args) {
|
void CKeybindManager::toggleSpecialWorkspace(std::string args) {
|
||||||
|
|
Loading…
Reference in a new issue