sway wl_shell

master
Tony Crisci 7 years ago
parent b6f4120afc
commit 59db38ce17

@ -42,5 +42,6 @@ void output_add_notify(struct wl_listener *listener, void *data);
void output_remove_notify(struct wl_listener *listener, void *data); void output_remove_notify(struct wl_listener *listener, void *data);
void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data); void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data);
void handle_wl_shell_surface(struct wl_listener *listener, void *data);
#endif #endif

@ -29,9 +29,8 @@ enum sway_view_type {
enum sway_view_prop { enum sway_view_prop {
VIEW_PROP_TITLE, VIEW_PROP_TITLE,
VIEW_PROP_CLASS,
VIEW_PROP_INSTANCE,
VIEW_PROP_APP_ID, VIEW_PROP_APP_ID,
VIEW_PROP_INSTANCE,
}; };
/** /**
@ -46,10 +45,12 @@ struct sway_view {
union { union {
struct wlr_xdg_surface_v6 *wlr_xdg_surface_v6; struct wlr_xdg_surface_v6 *wlr_xdg_surface_v6;
struct wlr_wl_shell_surface *wlr_wl_shell_surface;
}; };
union { union {
struct sway_xdg_surface_v6 *sway_xdg_surface_v6; struct sway_xdg_surface_v6 *sway_xdg_surface_v6;
struct sway_wl_shell_surface *sway_wl_shell_surface;
}; };
struct { struct {

@ -0,0 +1,30 @@
#define _POSIX_C_SOURCE 199309L
#include <stdbool.h>
#include <stdlib.h>
#include <wayland-server.h>
#include <wlr/types/wlr_wl_shell.h>
#include "sway/container.h"
#include "sway/layout.h"
#include "sway/server.h"
#include "sway/view.h"
#include "log.h"
static bool assert_wl_shell(struct sway_view *view) {
return sway_assert(view->type == SWAY_WL_SHELL_VIEW,
"Expecting wl_shell view!");
}
static const char *get_prop(struct sway_view *view, enum sway_view_prop prop) {
if (!assert_wl_shell(view)) {
return NULL;
}
switch (prop) {
case VIEW_PROP_TITLE:
return view->wlr_wl_shell_surface->title;
case VIEW_PROP_APP_ID:
return view->wlr_wl_shell_surface->class;
default:
return NULL;
}
}
Loading…
Cancel
Save