diff options
author | Marius Vlad <marius.vlad@collabora.com> | 2023-10-11 12:08:16 +0300 |
---|---|---|
committer | Marius Vlad <marius.vlad@collabora.com> | 2023-10-26 00:41:50 +0300 |
commit | 36e2c9697e431414ae0263635f3ebf1f3c200723 (patch) | |
tree | 5a4c103039ee6e0a7f68c3e34248893f3425899a /homescreen/src/homescreenhandler.cpp | |
parent | 8db829a4a790e30b5dfd27b531aa8018918fde10 (diff) |
AglShellGrpcClient: Add activation with gRPC proxy
This follow-ups in footsteps of flutter-homescreen to have activation
using gRPC. Note that setting up wayland surfaces is still need to
have the agl-shell protocol available. In Qt this is managed directly
by Qt/QPA while on other toolkits this happens at a lower level
(flutter-auto or chromium CEF).
With it, create a listening thread for gRRC events in order to perform
the initial start + activate sequence.
Bug-AGL: SPEC-4912
Signed-off-by: Marius Vlad <marius.vlad@collabora.com>
Change-Id: I019d0e7944dde02c84b2841e22d3971f226d610a
Diffstat (limited to 'homescreen/src/homescreenhandler.cpp')
-rw-r--r-- | homescreen/src/homescreenhandler.cpp | 48 |
1 files changed, 18 insertions, 30 deletions
diff --git a/homescreen/src/homescreenhandler.cpp b/homescreen/src/homescreenhandler.cpp index 9353713..d81e22f 100644 --- a/homescreen/src/homescreenhandler.cpp +++ b/homescreen/src/homescreenhandler.cpp @@ -5,6 +5,7 @@ */ #include <QGuiApplication> +#include <QScreen> #include <QFileInfo> #include <functional> @@ -20,12 +21,10 @@ QScreen *find_screen(const char *output); // a user session by systemd #define LAUNCHER_APP_ID "launcher" -static struct wl_output * -getWlOutput(QPlatformNativeInterface *native, QScreen *screen); -HomescreenHandler::HomescreenHandler(Shell *_aglShell, ApplicationLauncher *launcher, QObject *parent) : - QObject(parent), - aglShell(_aglShell) +HomescreenHandler::HomescreenHandler(ApplicationLauncher *launcher, GrpcClient *_client, QObject *parent) : + QObject(parent) + , m_grpc_client(_client) { mp_launcher = launcher; mp_applauncher_client = new AppLauncherClient(); @@ -43,16 +42,10 @@ HomescreenHandler::HomescreenHandler(Shell *_aglShell, ApplicationLauncher *laun HomescreenHandler::~HomescreenHandler() { + delete m_grpc_client; delete mp_applauncher_client; } -static struct wl_output * -getWlOutput(QPlatformNativeInterface *native, QScreen *screen) -{ - void *output = native->nativeResourceForScreen("output", screen); - return static_cast<struct ::wl_output*>(output); -} - void HomescreenHandler::tapShortcut(QString app_id) { HMI_DEBUG("HomeScreen","tapShortcut %s", app_id.toStdString().c_str()); @@ -92,18 +85,15 @@ void HomescreenHandler::addAppToStack(const QString& app_id) void HomescreenHandler::activateApp(const QString& app_id) { - struct agl_shell *agl_shell = aglShell->shell.get(); - QScreen *tmp_screen = qApp->screens().first(); - QPlatformNativeInterface *native = qApp->platformNativeInterface(); - struct wl_output *mm_output = nullptr; + QScreen *default_screen = qApp->screens().first(); + std::string default_output_name; - if (!tmp_screen) { - HMI_DEBUG("HomeScreen", "No output found to activate on!\n"); + if (!default_screen) { + HMI_DEBUG("HomeScreen", "No default output found to activate on!\n"); } else { - mm_output = getWlOutput(native, tmp_screen); - - HMI_DEBUG("HomeScreen", "Activating app_id %s by default on output %p\n", - app_id.toStdString().c_str(), mm_output); + default_output_name = default_screen->name().toStdString(); + HMI_DEBUG("HomeScreen", "Activating app_id %s by default on output %s\n", + app_id.toStdString().c_str(), default_output_name.c_str()); } if (mp_launcher) { @@ -155,27 +145,25 @@ void HomescreenHandler::activateApp(const QString& app_id) HMI_DEBUG("HomeScreen", "Found a stream remoting output %s to activate application %s on", new_remote_output.c_str(), app_id.toStdString().c_str()); + default_output_name = new_remote_output; } - mm_output = getWlOutput(native, screen); pending_app_list.erase(iter); - HMI_DEBUG("HomeScreen", "For application %s found another " "output to activate %s\n", app_id.toStdString().c_str(), - output_name.toStdString().c_str()); + default_output_name.c_str()); } - if (!mm_output) { + if (default_output_name.empty()) { HMI_DEBUG("HomeScreen", "No suitable output found for activating %s", app_id.toStdString().c_str()); return; } - HMI_DEBUG("HomeScreen", "Activating application %s", - app_id.toStdString().c_str()); - - agl_shell_activate_app(agl_shell, app_id.toStdString().c_str(), mm_output); + HMI_DEBUG("HomeScreen", "Activating application %s on output %s", + app_id.toStdString().c_str(), default_output_name.c_str()); + m_grpc_client->ActivateApp(app_id.toStdString(), default_output_name); } void HomescreenHandler::deactivateApp(const QString& app_id) |