diff options
author | Zandr Martin <zandrmartin@gmail.com> | 2016-09-02 13:46:19 -0500 |
---|---|---|
committer | Zandr Martin <zandrmartin@gmail.com> | 2016-09-02 13:46:19 -0500 |
commit | 79ffea328c992c5109406771a59a9f016d85970d (patch) | |
tree | 5d965e72127f227ea0a38dc5c6e4fc14e08d9498 /include/sway/extensions.h | |
parent | b374c35758777f98e5ddbe4b0dc43bd7c80f36d7 (diff) | |
parent | 4e6d7b125895955e3a84583c6d61f3eb2f8a4fe9 (diff) | |
download | sway-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.h | 49 |
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 |