aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2016-07-05 08:09:22 -0400
committerGitHub <noreply@github.com>2016-07-05 08:09:22 -0400
commit58804a044f782a397302173deb1416e47b3c3357 (patch)
tree9e155febd82e37ba6cb7b9e1b8ee7fda044d5147 /include
parentc3373c6815b5c8cff8f48d1acb46be08b9654331 (diff)
parentd9bcea381a69ebc6367aede7816b8e27d5fc9417 (diff)
downloadsway-58804a044f782a397302173deb1416e47b3c3357.tar.xz
Merge pull request #738 from deklov/panel-as-shell-02
Make swaybar and swaybg shell surfaces, take 2
Diffstat (limited to 'include')
-rw-r--r--include/client/window.h1
-rw-r--r--include/extensions.h40
2 files changed, 23 insertions, 18 deletions
diff --git a/include/client/window.h b/include/client/window.h
index eff9032d..e48ec4f3 100644
--- a/include/client/window.h
+++ b/include/client/window.h
@@ -42,5 +42,6 @@ struct window *window_setup(struct registry *registry, uint32_t width, uint32_t
void window_teardown(struct window *state);
int window_prerender(struct window *state);
int window_render(struct window *state);
+void window_make_shell(struct window *window);
#endif
diff --git a/include/extensions.h b/include/extensions.h
index 158a40a2..7c508b5e 100644
--- a/include/extensions.h
+++ b/include/extensions.h
@@ -7,33 +7,37 @@
#include "list.h"
struct background_config {
- wlc_handle output;
- wlc_resource surface;
- // we need the wl_resource of the surface in the destructor
- struct wl_resource *wl_surface_res;
+ wlc_handle output;
+ wlc_resource surface;
+ // we need the wl_resource of the surface in the destructor
+ struct wl_resource *wl_surface_res;
+ // used to determine if client is a background
+ struct wl_client *client;
};
struct panel_config {
- // wayland resource used in callbacks, is used to track this panel
- struct wl_resource *wl_resource;
- wlc_handle output;
- wlc_resource surface;
- // we need the wl_resource of the surface in the destructor
- struct wl_resource *wl_surface_res;
- enum desktop_shell_panel_position panel_position;
+ // wayland resource used in callbacks, is used to track this panel
+ struct wl_resource *wl_resource;
+ wlc_handle output;
+ wlc_resource surface;
+ // we need the wl_resource of the surface in the destructor
+ struct wl_resource *wl_surface_res;
+ enum desktop_shell_panel_position panel_position;
+ // used to determine if client is a panel
+ struct wl_client *client;
};
struct desktop_shell_state {
- list_t *backgrounds;
- list_t *panels;
- list_t *lock_surfaces;
- bool is_locked;
+ list_t *backgrounds;
+ list_t *panels;
+ list_t *lock_surfaces;
+ bool is_locked;
};
struct swaylock_state {
- bool active;
- wlc_handle output;
- wlc_resource surface;
+ bool active;
+ wlc_handle output;
+ wlc_resource surface;
};
extern struct desktop_shell_state desktop_shell;