From a8a4a6cc916413efc6cae3d0f66419874b67482f Mon Sep 17 00:00:00 2001 From: Thomas Adam Date: Fri, 20 Oct 2023 19:52:13 +0100 Subject: [PATCH] EdgeScroll: implement per monitor Bring the EdgeScroll command inline with other command, such as EwmhBaseStruts whereby the dimensions can be specified per-monitor, such as: EdgeScroll 0 0 EdgeScroll screen DP-1 100 100 --- fvwm/virtual.c | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/fvwm/virtual.c b/fvwm/virtual.c index c88e5ecf0..370539af9 100644 --- a/fvwm/virtual.c +++ b/fvwm/virtual.c @@ -2140,8 +2140,22 @@ void CMD_EdgeThickness(F_CMD_ARGS) void CMD_EdgeScroll(F_CMD_ARGS) { int val1, val2, val1_unit, val2_unit, n; - char *token; - struct monitor *m; + char *token, *option; + struct monitor *m = NULL, *m_this = NULL; + + option = PeekToken(action, NULL); + if (StrEquals(option, "screen")) { + /* Skip literal 'screen' */ + option = PeekToken(action, &action); + /* Actually get the screen value. */ + option = PeekToken(action, &action); + + if ((m = monitor_resolve_name(option)) == NULL) { + fvwm_debug(__func__, "Invalid screen: %s", option); + return; + } + } + n = GetTwoArguments(action, &val1, &val2, &val1_unit, &val2_unit); if (n != 2) @@ -2194,10 +2208,20 @@ void CMD_EdgeScroll(F_CMD_ARGS) } } - TAILQ_FOREACH(m, &monitor_q, entry) { + if (m != NULL) { m->virtual_scr.EdgeScrollX = val1 * val1_unit / 100; m->virtual_scr.EdgeScrollY = val2 * val2_unit / 100; checkPanFrames(m); + + return; + } + + TAILQ_FOREACH(m_this, &monitor_q, entry) { + if (m != NULL && m == m_this) + continue; + m_this->virtual_scr.EdgeScrollX = val1 * val1_unit / 100; + m_this->virtual_scr.EdgeScrollY = val2 * val2_unit / 100; + checkPanFrames(m_this); }