mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-22 18:25:59 +01:00
windowrules: add fullscreenstate field (#7466)
* windowrules: add fullscreenstate field * fix typo
This commit is contained in:
parent
a3b75559b3
commit
688fe5c147
3 changed files with 61 additions and 23 deletions
|
@ -2326,8 +2326,12 @@ void CCompositor::setWindowFullscreenState(const PHLWINDOW PWINDOW, sFullscreenS
|
||||||
PWINDOW->m_sFullscreenState.client = state.client;
|
PWINDOW->m_sFullscreenState.client = state.client;
|
||||||
g_pXWaylandManager->setWindowFullscreen(PWINDOW, state.client & FSMODE_FULLSCREEN);
|
g_pXWaylandManager->setWindowFullscreen(PWINDOW, state.client & FSMODE_FULLSCREEN);
|
||||||
|
|
||||||
if (!CHANGEINTERNAL)
|
if (!CHANGEINTERNAL) {
|
||||||
|
PWINDOW->updateDynamicRules();
|
||||||
|
updateWindowAnimatedDecorationValues(PWINDOW);
|
||||||
|
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(PWINDOW->m_iMonitorID);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
g_pLayoutManager->getCurrentLayout()->fullscreenRequestForWindow(PWINDOW, CURRENT_EFFECTIVE_MODE, EFFECTIVE_MODE);
|
g_pLayoutManager->getCurrentLayout()->fullscreenRequestForWindow(PWINDOW, CURRENT_EFFECTIVE_MODE, EFFECTIVE_MODE);
|
||||||
|
|
||||||
|
@ -2339,7 +2343,6 @@ void CCompositor::setWindowFullscreenState(const PHLWINDOW PWINDOW, sFullscreenS
|
||||||
EMIT_HOOK_EVENT("fullscreen", PWINDOW);
|
EMIT_HOOK_EVENT("fullscreen", PWINDOW);
|
||||||
|
|
||||||
PWINDOW->updateDynamicRules();
|
PWINDOW->updateDynamicRules();
|
||||||
PWINDOW->updateWindowDecos();
|
|
||||||
updateWindowAnimatedDecorationValues(PWINDOW);
|
updateWindowAnimatedDecorationValues(PWINDOW);
|
||||||
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(PWINDOW->m_iMonitorID);
|
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(PWINDOW->m_iMonitorID);
|
||||||
|
|
||||||
|
|
|
@ -1212,6 +1212,32 @@ std::vector<SWindowRule> CConfigManager::getMatchingRules(PHLWINDOW pWindow, boo
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!rule.szFullscreenState.empty()) {
|
||||||
|
const auto ARGS = CVarList(rule.szFullscreenState, 2, ' ');
|
||||||
|
//
|
||||||
|
std::optional<eFullscreenMode> internalMode, clientMode;
|
||||||
|
|
||||||
|
if (ARGS[0] == "*")
|
||||||
|
internalMode = {};
|
||||||
|
else if (isNumber(ARGS[0]))
|
||||||
|
internalMode = (eFullscreenMode)std::stoi(ARGS[0]);
|
||||||
|
else
|
||||||
|
throw std::runtime_error("szFullscreenState internal mode not valid");
|
||||||
|
|
||||||
|
if (ARGS[1] == "*")
|
||||||
|
clientMode = {};
|
||||||
|
else if (isNumber(ARGS[1]))
|
||||||
|
clientMode = (eFullscreenMode)std::stoi(ARGS[1]);
|
||||||
|
else
|
||||||
|
throw std::runtime_error("szFullscreenState client mode not valid");
|
||||||
|
|
||||||
|
if (internalMode.has_value() && pWindow->m_sFullscreenState.internal != internalMode)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (clientMode.has_value() && pWindow->m_sFullscreenState.client != clientMode)
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (!rule.szOnWorkspace.empty()) {
|
if (!rule.szOnWorkspace.empty()) {
|
||||||
const auto PWORKSPACE = pWindow->m_pWorkspace;
|
const auto PWORKSPACE = pWindow->m_pWorkspace;
|
||||||
if (!PWORKSPACE || !PWORKSPACE->matchesStaticSelector(rule.szOnWorkspace))
|
if (!PWORKSPACE || !PWORKSPACE->matchesStaticSelector(rule.szOnWorkspace))
|
||||||
|
@ -2219,17 +2245,18 @@ std::optional<std::string> CConfigManager::handleWindowRuleV2(const std::string&
|
||||||
rule.szRule = RULE;
|
rule.szRule = RULE;
|
||||||
rule.szValue = VALUE;
|
rule.szValue = VALUE;
|
||||||
|
|
||||||
const auto TAGPOS = VALUE.find("tag:");
|
const auto TAGPOS = VALUE.find("tag:");
|
||||||
const auto TITLEPOS = VALUE.find("title:");
|
const auto TITLEPOS = VALUE.find("title:");
|
||||||
const auto CLASSPOS = VALUE.find("class:");
|
const auto CLASSPOS = VALUE.find("class:");
|
||||||
const auto INITIALTITLEPOS = VALUE.find("initialTitle:");
|
const auto INITIALTITLEPOS = VALUE.find("initialTitle:");
|
||||||
const auto INITIALCLASSPOS = VALUE.find("initialClass:");
|
const auto INITIALCLASSPOS = VALUE.find("initialClass:");
|
||||||
const auto X11POS = VALUE.find("xwayland:");
|
const auto X11POS = VALUE.find("xwayland:");
|
||||||
const auto FLOATPOS = VALUE.find("floating:");
|
const auto FLOATPOS = VALUE.find("floating:");
|
||||||
const auto FULLSCREENPOS = VALUE.find("fullscreen:");
|
const auto FULLSCREENPOS = VALUE.find("fullscreen:");
|
||||||
const auto PINNEDPOS = VALUE.find("pinned:");
|
const auto PINNEDPOS = VALUE.find("pinned:");
|
||||||
const auto FOCUSPOS = VALUE.find("focus:");
|
const auto FOCUSPOS = VALUE.find("focus:");
|
||||||
const auto ONWORKSPACEPOS = VALUE.find("onworkspace:");
|
const auto FULLSCREENSTATEPOS = VALUE.find("fullscreenstate:");
|
||||||
|
const auto ONWORKSPACEPOS = VALUE.find("onworkspace:");
|
||||||
|
|
||||||
// find workspacepos that isn't onworkspacepos
|
// find workspacepos that isn't onworkspacepos
|
||||||
size_t WORKSPACEPOS = std::string::npos;
|
size_t WORKSPACEPOS = std::string::npos;
|
||||||
|
@ -2242,9 +2269,8 @@ std::optional<std::string> CConfigManager::handleWindowRuleV2(const std::string&
|
||||||
currentPos = VALUE.find("workspace:", currentPos + 1);
|
currentPos = VALUE.find("workspace:", currentPos + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto checkPos = std::unordered_set{
|
const auto checkPos = std::unordered_set{TAGPOS, TITLEPOS, CLASSPOS, INITIALTITLEPOS, INITIALCLASSPOS, X11POS, FLOATPOS,
|
||||||
TAGPOS, TITLEPOS, CLASSPOS, INITIALTITLEPOS, INITIALCLASSPOS, X11POS, FLOATPOS, FULLSCREENPOS, PINNEDPOS, WORKSPACEPOS, FOCUSPOS, ONWORKSPACEPOS,
|
FULLSCREENPOS, PINNEDPOS, FULLSCREENSTATEPOS, WORKSPACEPOS, FOCUSPOS, ONWORKSPACEPOS};
|
||||||
};
|
|
||||||
if (checkPos.size() == 1 && checkPos.contains(std::string::npos)) {
|
if (checkPos.size() == 1 && checkPos.contains(std::string::npos)) {
|
||||||
Debug::log(ERR, "Invalid rulev2 syntax: {}", VALUE);
|
Debug::log(ERR, "Invalid rulev2 syntax: {}", VALUE);
|
||||||
return "Invalid rulev2 syntax: " + VALUE;
|
return "Invalid rulev2 syntax: " + VALUE;
|
||||||
|
@ -2273,6 +2299,8 @@ std::optional<std::string> CConfigManager::handleWindowRuleV2(const std::string&
|
||||||
min = FULLSCREENPOS;
|
min = FULLSCREENPOS;
|
||||||
if (PINNEDPOS > pos && PINNEDPOS < min)
|
if (PINNEDPOS > pos && PINNEDPOS < min)
|
||||||
min = PINNEDPOS;
|
min = PINNEDPOS;
|
||||||
|
if (FULLSCREENSTATEPOS > pos && FULLSCREENSTATEPOS < min)
|
||||||
|
min = FULLSCREENSTATEPOS;
|
||||||
if (ONWORKSPACEPOS > pos && ONWORKSPACEPOS < min)
|
if (ONWORKSPACEPOS > pos && ONWORKSPACEPOS < min)
|
||||||
min = ONWORKSPACEPOS;
|
min = ONWORKSPACEPOS;
|
||||||
if (WORKSPACEPOS > pos && WORKSPACEPOS < min)
|
if (WORKSPACEPOS > pos && WORKSPACEPOS < min)
|
||||||
|
@ -2317,6 +2345,9 @@ std::optional<std::string> CConfigManager::handleWindowRuleV2(const std::string&
|
||||||
if (PINNEDPOS != std::string::npos)
|
if (PINNEDPOS != std::string::npos)
|
||||||
rule.bPinned = extract(PINNEDPOS + 7) == "1" ? 1 : 0;
|
rule.bPinned = extract(PINNEDPOS + 7) == "1" ? 1 : 0;
|
||||||
|
|
||||||
|
if (FULLSCREENSTATEPOS != std::string::npos)
|
||||||
|
rule.szFullscreenState = extract(FULLSCREENSTATEPOS + 16);
|
||||||
|
|
||||||
if (WORKSPACEPOS != std::string::npos)
|
if (WORKSPACEPOS != std::string::npos)
|
||||||
rule.szWorkspace = extract(WORKSPACEPOS + 10);
|
rule.szWorkspace = extract(WORKSPACEPOS + 10);
|
||||||
|
|
||||||
|
@ -2358,6 +2389,9 @@ std::optional<std::string> CConfigManager::handleWindowRuleV2(const std::string&
|
||||||
if (rule.bPinned != -1 && rule.bPinned != other.bPinned)
|
if (rule.bPinned != -1 && rule.bPinned != other.bPinned)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if (!rule.szFullscreenState.empty() && rule.szFullscreenState != other.szFullscreenState)
|
||||||
|
return false;
|
||||||
|
|
||||||
if (!rule.szWorkspace.empty() && rule.szWorkspace != other.szWorkspace)
|
if (!rule.szWorkspace.empty() && rule.szWorkspace != other.szWorkspace)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
|
@ -196,13 +196,14 @@ struct SWindowRule {
|
||||||
std::string szInitialTitle;
|
std::string szInitialTitle;
|
||||||
std::string szInitialClass;
|
std::string szInitialClass;
|
||||||
std::string szTag;
|
std::string szTag;
|
||||||
int bX11 = -1; // -1 means "ANY"
|
int bX11 = -1; // -1 means "ANY"
|
||||||
int bFloating = -1;
|
int bFloating = -1;
|
||||||
int bFullscreen = -1;
|
int bFullscreen = -1;
|
||||||
int bPinned = -1;
|
int bPinned = -1;
|
||||||
int bFocus = -1;
|
int bFocus = -1;
|
||||||
std::string szOnWorkspace = ""; // empty means any
|
std::string szFullscreenState = ""; // empty means any
|
||||||
std::string szWorkspace = ""; // empty means any
|
std::string szOnWorkspace = ""; // empty means any
|
||||||
|
std::string szWorkspace = ""; // empty means any
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SInitialWorkspaceToken {
|
struct SInitialWorkspaceToken {
|
||||||
|
|
Loading…
Reference in a new issue