pH/sommelier/sommelier-gtk-shell.cc

173 lines
6.7 KiB
C++
Raw Normal View History

// Copyright 2018 The ChromiumOS Authors
2019-09-20 22:57:28 +00:00
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "sommelier.h" // NOLINT(build/include_directory)
#include "sommelier-tracing.h" // NOLINT(build/include_directory)
2019-09-20 22:57:28 +00:00
#include <assert.h>
#include <stdlib.h>
#include <string.h>
#include "aura-shell-client-protocol.h" // NOLINT(build/include_directory)
#include "gtk-shell-server-protocol.h" // NOLINT(build/include_directory)
#define NATIVE_WAYLAND_APPLICATION_ID_FORMAT \
"org.chromium.guest_os.%s.wayland.%s"
2019-09-20 22:57:28 +00:00
struct sl_host_gtk_shell {
struct sl_aura_shell* aura_shell;
struct wl_resource* resource;
struct zaura_shell* proxy;
struct wl_callback* callback;
char* startup_id;
struct wl_list surfaces;
};
struct sl_host_gtk_surface {
struct wl_resource* resource;
struct zaura_surface* proxy;
struct wl_list link;
struct sl_aura_shell* aura_shell;
};
static void sl_gtk_surface_set_dbus_properties(
struct wl_client* client,
struct wl_resource* resource,
const char* application_id,
const char* app_menu_path,
const char* menubar_path,
const char* window_object_path,
const char* application_object_path,
const char* unique_bus_name) {
struct sl_host_gtk_surface* host =
static_cast<sl_host_gtk_surface*>(wl_resource_get_user_data(resource));
2019-09-20 22:57:28 +00:00
char* application_id_str =
sl_xasprintf(NATIVE_WAYLAND_APPLICATION_ID_FORMAT,
host->aura_shell->ctx->vm_id, application_id);
zaura_surface_set_application_id(host->proxy, application_id_str);
} // NOLINT(whitespace/indent)
2019-09-20 22:57:28 +00:00
static void sl_gtk_surface_set_modal(struct wl_client* client,
struct wl_resource* resource) {}
static void sl_gtk_surface_unset_modal(struct wl_client* client,
struct wl_resource* resource) {}
static void sl_gtk_surface_present(struct wl_client* client,
struct wl_resource* resource,
uint32_t time) {}
static const struct gtk_surface1_interface sl_gtk_surface_implementation = {
sl_gtk_surface_set_dbus_properties, sl_gtk_surface_set_modal,
sl_gtk_surface_unset_modal, sl_gtk_surface_present};
static void sl_destroy_host_gtk_surface(struct wl_resource* resource) {
struct sl_host_gtk_surface* host =
static_cast<sl_host_gtk_surface*>(wl_resource_get_user_data(resource));
2019-09-20 22:57:28 +00:00
zaura_surface_destroy(host->proxy);
wl_list_remove(&host->link);
wl_resource_set_user_data(resource, NULL);
delete host;
2019-09-20 22:57:28 +00:00
}
static void sl_gtk_shell_get_gtk_surface(struct wl_client* client,
struct wl_resource* resource,
uint32_t id,
struct wl_resource* surface_resource) {
struct sl_host_gtk_shell* host =
static_cast<sl_host_gtk_shell*>(wl_resource_get_user_data(resource));
struct sl_host_surface* host_surface = static_cast<sl_host_surface*>(
wl_resource_get_user_data(surface_resource));
struct sl_host_gtk_surface* host_gtk_surface = new sl_host_gtk_surface();
2019-09-20 22:57:28 +00:00
wl_list_insert(&host->surfaces, &host_gtk_surface->link);
host_gtk_surface->aura_shell = host->aura_shell;
host_gtk_surface->resource =
wl_resource_create(client, &gtk_surface1_interface, 1, id);
wl_resource_set_implementation(host_gtk_surface->resource,
&sl_gtk_surface_implementation,
host_gtk_surface, sl_destroy_host_gtk_surface);
host_gtk_surface->proxy =
zaura_shell_get_aura_surface(host->proxy, host_surface->proxy);
zaura_surface_set_startup_id(host_gtk_surface->proxy, host->startup_id);
}
// TODO(b/244651040): when adding changing the startup id format, also add vm_id
// here.
2019-09-20 22:57:28 +00:00
static void sl_gtk_shell_set_startup_id(struct wl_client* client,
struct wl_resource* resource,
const char* startup_id) {
struct sl_host_gtk_shell* host =
static_cast<sl_host_gtk_shell*>(wl_resource_get_user_data(resource));
2019-09-20 22:57:28 +00:00
struct sl_host_gtk_surface* surface;
free(host->startup_id);
host->startup_id = startup_id ? strdup(startup_id) : NULL;
wl_list_for_each(surface, &host->surfaces, link)
zaura_surface_set_startup_id(surface->proxy, host->startup_id);
}
static void sl_gtk_shell_system_bell(struct wl_client* client,
struct wl_resource* resource,
struct wl_resource* surface_resource) {}
static const struct gtk_shell1_interface sl_gtk_shell_implementation = {
sl_gtk_shell_get_gtk_surface, sl_gtk_shell_set_startup_id,
sl_gtk_shell_system_bell};
static void sl_destroy_host_gtk_shell(struct wl_resource* resource) {
struct sl_host_gtk_shell* host =
static_cast<sl_host_gtk_shell*>(wl_resource_get_user_data(resource));
2019-09-20 22:57:28 +00:00
free(host->startup_id);
wl_callback_destroy(host->callback);
zaura_shell_destroy(host->proxy);
wl_resource_set_user_data(resource, NULL);
delete host;
2019-09-20 22:57:28 +00:00
}
static void sl_gtk_shell_callback_done(void* data,
struct wl_callback* callback,
uint32_t serial) {
TRACE_EVENT("shell", "sl_gtk_shell_callback_done");
struct sl_host_gtk_shell* host =
static_cast<sl_host_gtk_shell*>(wl_callback_get_user_data(callback));
2019-09-20 22:57:28 +00:00
gtk_shell1_send_capabilities(host->resource, 0);
}
static const struct wl_callback_listener sl_gtk_shell_callback_listener = {
sl_gtk_shell_callback_done};
static void sl_bind_host_gtk_shell(struct wl_client* client,
void* data,
uint32_t version,
uint32_t id) {
struct sl_context* ctx = (struct sl_context*)data;
struct sl_host_gtk_shell* host = new sl_host_gtk_shell();
2019-09-20 22:57:28 +00:00
host->aura_shell = ctx->aura_shell;
host->startup_id = NULL;
wl_list_init(&host->surfaces);
host->resource = wl_resource_create(client, &gtk_shell1_interface, 1, id);
wl_resource_set_implementation(host->resource, &sl_gtk_shell_implementation,
host, sl_destroy_host_gtk_shell);
host->proxy = static_cast<zaura_shell*>(wl_registry_bind(
wl_display_get_registry(ctx->display), ctx->aura_shell->id,
&zaura_shell_interface, ctx->aura_shell->version));
2019-09-20 22:57:28 +00:00
zaura_shell_set_user_data(host->proxy, host);
host->callback = wl_display_sync(ctx->aura_shell->ctx->display);
wl_callback_add_listener(host->callback, &sl_gtk_shell_callback_listener,
host);
}
struct sl_global* sl_gtk_shell_global_create(struct sl_context* ctx) {
return sl_global_create(ctx, &gtk_shell1_interface, 1, ctx,
sl_bind_host_gtk_shell);
}