aboutsummaryrefslogtreecommitdiff
path: root/include/sway/extensions.h
diff options
context:
space:
mode:
authorZandr Martin <zandrmartin@gmail.com>2016-09-02 13:46:19 -0500
committerZandr Martin <zandrmartin@gmail.com>2016-09-02 13:46:19 -0500
commit79ffea328c992c5109406771a59a9f016d85970d (patch)
tree5d965e72127f227ea0a38dc5c6e4fc14e08d9498 /include/sway/extensions.h
parentb374c35758777f98e5ddbe4b0dc43bd7c80f36d7 (diff)
parent4e6d7b125895955e3a84583c6d61f3eb2f8a4fe9 (diff)
downloadsway-79ffea328c992c5109406771a59a9f016d85970d.tar.xz
Merge branch 'master' of git://github.com/SirCmpwn/sway into commands-refactor
Diffstat (limited to 'include/sway/extensions.h')
-rw-r--r--include/sway/extensions.h49
1 files changed, 49 insertions, 0 deletions
diff --git a/include/sway/extensions.h b/include/sway/extensions.h
new file mode 100644
index 00000000..f6b0c00e
--- /dev/null
+++ b/include/sway/extensions.h
@@ -0,0 +1,49 @@
+#ifndef _SWAY_EXTENSIONS_H
+#define _SWAY_EXTENSIONS_H
+
+#include <wayland-server.h>
+#include <wlc/wlc-wayland.h>
+#include "wayland-desktop-shell-server-protocol.h"
+#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;
+ struct wl_client *client;
+ wlc_handle handle;
+};
+
+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;
+ // used to determine if client is a panel
+ struct wl_client *client;
+ // wlc handle for this panel's surface, not set until panel is created
+ wlc_handle handle;
+};
+
+struct desktop_shell_state {
+ list_t *backgrounds;
+ list_t *panels;
+ list_t *lock_surfaces;
+ bool is_locked;
+};
+
+struct swaylock_state {
+ bool active;
+ wlc_handle output;
+ wlc_resource surface;
+};
+
+extern struct desktop_shell_state desktop_shell;
+
+void register_extensions(void);
+
+#endif