From 8479190d2356e376c574c5433de1f6d0c5ba04ff Mon Sep 17 00:00:00 2001 From: Vasyl Vavrychuk Date: Mon, 6 Jun 2022 19:57:49 +0300 Subject: Cluster application configurable to run on particular output. Bug-AGL: SPEC-3818 Signed-off-by: Vasyl Vavrychuk Change-Id: If10020e4a5be7d3706215c39b8828b87c78d79e3 --- app/main.cpp | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/app/main.cpp b/app/main.cpp index 3d02a51..775f7f5 100644 --- a/app/main.cpp +++ b/app/main.cpp @@ -142,6 +142,18 @@ create_component(QPlatformNativeInterface *native, QQmlComponent *comp, return getWlSurface(native, win); } +static QScreen *find_screen(const char *screen_name) +{ + QList screens = qApp->screens(); + QString name(screen_name); + + for (QScreen *screen : screens) { + if (name == screen->name()) + return screen; + } + + return nullptr; +} int main(int argc, char *argv[]) { @@ -163,7 +175,11 @@ int main(int argc, char *argv[]) std::shared_ptr shell{agl_shell, agl_shell_destroy}; - screen = qApp->primaryScreen(); + const char *screen_name = getenv("DASHBOARD_START_SCREEN"); + if (screen_name) + screen = find_screen(screen_name); + else + screen = qApp->primaryScreen(); output = getWlOutput(native, screen); read_config(); -- cgit 1.2.3-korg