diff options
Diffstat (limited to 'tz-launcher/toytoolkit/xdg-shell-client-protocol.h')
-rw-r--r-- | tz-launcher/toytoolkit/xdg-shell-client-protocol.h | 512 |
1 files changed, 512 insertions, 0 deletions
diff --git a/tz-launcher/toytoolkit/xdg-shell-client-protocol.h b/tz-launcher/toytoolkit/xdg-shell-client-protocol.h new file mode 100644 index 0000000..353d38a --- /dev/null +++ b/tz-launcher/toytoolkit/xdg-shell-client-protocol.h @@ -0,0 +1,512 @@ +/* + * Copyright © 2008-2013 Kristian Høgsberg + * Copyright © 2013 Rafael Antognolli + * Copyright © 2013 Jasper St. Pierre + * Copyright © 2010-2013 Intel Corporation + * + * Permission to use, copy, modify, distribute, and sell this + * software and its documentation for any purpose is hereby granted + * without fee, provided that the above copyright notice appear in + * all copies and that both that copyright notice and this permission + * notice appear in supporting documentation, and that the name of + * the copyright holders not be used in advertising or publicity + * pertaining to distribution of the software without specific, + * written prior permission. The copyright holders make no + * representations about the suitability of this software for any + * purpose. It is provided "as is" without express or implied + * warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS + * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND + * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY + * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN + * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, + * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF + * THIS SOFTWARE. + */ + +#ifndef XDG_SHELL_CLIENT_PROTOCOL_H +#define XDG_SHELL_CLIENT_PROTOCOL_H + +#ifdef __cplusplus +extern "C" { +#endif + +#include <stdint.h> +#include <stddef.h> +#include "wayland-client.h" + +struct wl_client; +struct wl_resource; + +struct xdg_shell; +struct xdg_surface; +struct xdg_popup; + +extern const struct wl_interface xdg_shell_interface; +extern const struct wl_interface xdg_surface_interface; +extern const struct wl_interface xdg_popup_interface; + +#ifndef XDG_SHELL_VERSION_ENUM +#define XDG_SHELL_VERSION_ENUM +/** + * xdg_shell_version - latest protocol version + * @XDG_SHELL_VERSION_CURRENT: Always the latest version + * + * Use this enum to check the protocol version, and it will be updated + * automatically. + */ +enum xdg_shell_version { + XDG_SHELL_VERSION_CURRENT = 1, +}; +#endif /* XDG_SHELL_VERSION_ENUM */ + +#define XDG_SHELL_USE_UNSTABLE_VERSION 0 +#define XDG_SHELL_GET_XDG_SURFACE 1 +#define XDG_SHELL_GET_XDG_POPUP 2 + +static inline void +xdg_shell_set_user_data(struct xdg_shell *xdg_shell, void *user_data) +{ + wl_proxy_set_user_data((struct wl_proxy *) xdg_shell, user_data); +} + +static inline void * +xdg_shell_get_user_data(struct xdg_shell *xdg_shell) +{ + return wl_proxy_get_user_data((struct wl_proxy *) xdg_shell); +} + +static inline void +xdg_shell_destroy(struct xdg_shell *xdg_shell) +{ + wl_proxy_destroy((struct wl_proxy *) xdg_shell); +} + +static inline void +xdg_shell_use_unstable_version(struct xdg_shell *xdg_shell, int32_t version) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_shell, + XDG_SHELL_USE_UNSTABLE_VERSION, version); +} + +static inline struct xdg_surface * +xdg_shell_get_xdg_surface(struct xdg_shell *xdg_shell, struct wl_surface *surface) +{ + struct wl_proxy *id; + + id = wl_proxy_marshal_constructor((struct wl_proxy *) xdg_shell, + XDG_SHELL_GET_XDG_SURFACE, &xdg_surface_interface, NULL, surface); + + return (struct xdg_surface *) id; +} + +static inline struct xdg_popup * +xdg_shell_get_xdg_popup(struct xdg_shell *xdg_shell, struct wl_surface *surface, struct wl_surface *parent, struct wl_seat *seat, uint32_t serial, int32_t x, int32_t y, uint32_t flags) +{ + struct wl_proxy *id; + + id = wl_proxy_marshal_constructor((struct wl_proxy *) xdg_shell, + XDG_SHELL_GET_XDG_POPUP, &xdg_popup_interface, NULL, surface, parent, seat, serial, x, y, flags); + + return (struct xdg_popup *) id; +} + +#ifndef XDG_SURFACE_RESIZE_EDGE_ENUM +#define XDG_SURFACE_RESIZE_EDGE_ENUM +/** + * xdg_surface_resize_edge - edge values for resizing + * @XDG_SURFACE_RESIZE_EDGE_NONE: (none) + * @XDG_SURFACE_RESIZE_EDGE_TOP: (none) + * @XDG_SURFACE_RESIZE_EDGE_BOTTOM: (none) + * @XDG_SURFACE_RESIZE_EDGE_LEFT: (none) + * @XDG_SURFACE_RESIZE_EDGE_TOP_LEFT: (none) + * @XDG_SURFACE_RESIZE_EDGE_BOTTOM_LEFT: (none) + * @XDG_SURFACE_RESIZE_EDGE_RIGHT: (none) + * @XDG_SURFACE_RESIZE_EDGE_TOP_RIGHT: (none) + * @XDG_SURFACE_RESIZE_EDGE_BOTTOM_RIGHT: (none) + * + * These values are used to indicate which edge of a surface is being + * dragged in a resize operation. The server may use this information to + * adapt its behavior, e.g. choose an appropriate cursor image. + */ +enum xdg_surface_resize_edge { + XDG_SURFACE_RESIZE_EDGE_NONE = 0, + XDG_SURFACE_RESIZE_EDGE_TOP = 1, + XDG_SURFACE_RESIZE_EDGE_BOTTOM = 2, + XDG_SURFACE_RESIZE_EDGE_LEFT = 4, + XDG_SURFACE_RESIZE_EDGE_TOP_LEFT = 5, + XDG_SURFACE_RESIZE_EDGE_BOTTOM_LEFT = 6, + XDG_SURFACE_RESIZE_EDGE_RIGHT = 8, + XDG_SURFACE_RESIZE_EDGE_TOP_RIGHT = 9, + XDG_SURFACE_RESIZE_EDGE_BOTTOM_RIGHT = 10, +}; +#endif /* XDG_SURFACE_RESIZE_EDGE_ENUM */ + +/** + * xdg_surface - desktop-style metadata interface + * @ping: ping client + * @configure: suggest resize + * @request_set_fullscreen: server requests that the client set + * fullscreen + * @request_unset_fullscreen: server requests that the client unset + * fullscreen + * @request_set_maximized: server requests that the client set maximized + * @request_unset_maximized: server requests that the client unset + * maximized + * @request_set_minimized: server requests that the client set minimized + * @request_unset_minimized: server requests that the client unset + * maximized + * @focused_set: surface was focused + * @focused_unset: surface was unfocused + * + * An interface that may be implemented by a wl_surface, for + * implementations that provide a desktop-style user interface. + * + * It provides requests to treat surfaces like windows, allowing to set + * properties like maximized, fullscreen, minimized, and to move and resize + * them, and associate metadata like title and app id. + * + * On the server side the object is automatically destroyed when the + * related wl_surface is destroyed. On client side, xdg_surface.destroy() + * must be called before destroying the wl_surface object. + */ +struct xdg_surface_listener { + /** + * ping - ping client + * @serial: (none) + * + * Ping a client to check if it is receiving events and sending + * requests. A client is expected to reply with a pong request. + */ + void (*ping)(void *data, + struct xdg_surface *xdg_surface, + uint32_t serial); + /** + * configure - suggest resize + * @edges: (none) + * @width: (none) + * @height: (none) + * + * The configure event asks the client to resize its surface. + * + * The size is a hint, in the sense that the client is free to + * ignore it if it doesn't resize, pick a smaller size (to satisfy + * aspect ratio or resize in steps of NxM pixels). + * + * The edges parameter provides a hint about how the surface was + * resized. The client may use this information to decide how to + * adjust its content to the new size (e.g. a scrolling area might + * adjust its content position to leave the viewable content + * unmoved). Valid edge values are from resize_edge enum. + * + * The client is free to dismiss all but the last configure event + * it received. + * + * The width and height arguments specify the size of the window in + * surface local coordinates. + */ + void (*configure)(void *data, + struct xdg_surface *xdg_surface, + uint32_t edges, + int32_t width, + int32_t height); + /** + * request_set_fullscreen - server requests that the client set + * fullscreen + * + * Event sent from the compositor to the client requesting that + * the client goes to a fullscreen state. It's the client job to + * call set_fullscreen and really trigger the fullscreen state. + */ + void (*request_set_fullscreen)(void *data, + struct xdg_surface *xdg_surface); + /** + * request_unset_fullscreen - server requests that the client + * unset fullscreen + * + * Event sent from the compositor to the client requesting that + * the client leaves the fullscreen state. It's the client job to + * call unset_fullscreen and really leave the fullscreen state. + */ + void (*request_unset_fullscreen)(void *data, + struct xdg_surface *xdg_surface); + /** + * request_set_maximized - server requests that the client set + * maximized + * + * Event sent from the compositor to the client requesting that + * the client goes to a maximized state. It's the client job to + * call set_maximized and really trigger the maximized state. + */ + void (*request_set_maximized)(void *data, + struct xdg_surface *xdg_surface); + /** + * request_unset_maximized - server requests that the client + * unset maximized + * + * Event sent from the compositor to the client requesting that + * the client leaves the maximized state. It's the client job to + * call unset_maximized and really leave the maximized state. + */ + void (*request_unset_maximized)(void *data, + struct xdg_surface *xdg_surface); + /** + * request_set_minimized - server requests that the client set + * minimized + * + * Event sent from the compositor to the client requesting that + * the client goes to a minimized state. It's the client job to + * call set_minimized and trigger its minimized state. + */ + void (*request_set_minimized)(void *data, + struct xdg_surface *xdg_surface); + /** + * request_unset_minimized - server requests that the client + * unset maximized + * + * Event sent from the compositor to the client requesting that + * the client leaves the minimized state. It's the client job to + * call unset_maximized and leave its minimized state. + */ + void (*request_unset_minimized)(void *data, + struct xdg_surface *xdg_surface); + /** + * focused_set - surface was focused + * + * The focused_set event is sent when this surface has been + * activated. Window decorations should be updated accordingly. + */ + void (*focused_set)(void *data, + struct xdg_surface *xdg_surface); + /** + * focused_unset - surface was unfocused + * + * The focused_unset event is sent when this surface has been + * deactivated, because another surface has been activated. Window + * decorations should be updated accordingly. + */ + void (*focused_unset)(void *data, + struct xdg_surface *xdg_surface); +}; + +static inline int +xdg_surface_add_listener(struct xdg_surface *xdg_surface, + const struct xdg_surface_listener *listener, void *data) +{ + return wl_proxy_add_listener((struct wl_proxy *) xdg_surface, + (void (**)(void)) listener, data); +} + +#define XDG_SURFACE_DESTROY 0 +#define XDG_SURFACE_SET_TRANSIENT_FOR 1 +#define XDG_SURFACE_SET_TITLE 2 +#define XDG_SURFACE_SET_APP_ID 3 +#define XDG_SURFACE_PONG 4 +#define XDG_SURFACE_MOVE 5 +#define XDG_SURFACE_RESIZE 6 +#define XDG_SURFACE_SET_OUTPUT 7 +#define XDG_SURFACE_SET_FULLSCREEN 8 +#define XDG_SURFACE_UNSET_FULLSCREEN 9 +#define XDG_SURFACE_SET_MAXIMIZED 10 +#define XDG_SURFACE_UNSET_MAXIMIZED 11 +#define XDG_SURFACE_SET_MINIMIZED 12 + +static inline void +xdg_surface_set_user_data(struct xdg_surface *xdg_surface, void *user_data) +{ + wl_proxy_set_user_data((struct wl_proxy *) xdg_surface, user_data); +} + +static inline void * +xdg_surface_get_user_data(struct xdg_surface *xdg_surface) +{ + return wl_proxy_get_user_data((struct wl_proxy *) xdg_surface); +} + +static inline void +xdg_surface_destroy(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_DESTROY); + + wl_proxy_destroy((struct wl_proxy *) xdg_surface); +} + +static inline void +xdg_surface_set_transient_for(struct xdg_surface *xdg_surface, struct wl_surface *parent) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_TRANSIENT_FOR, parent); +} + +static inline void +xdg_surface_set_title(struct xdg_surface *xdg_surface, const char *title) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_TITLE, title); +} + +static inline void +xdg_surface_set_app_id(struct xdg_surface *xdg_surface, const char *app_id) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_APP_ID, app_id); +} + +static inline void +xdg_surface_pong(struct xdg_surface *xdg_surface, uint32_t serial) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_PONG, serial); +} + +static inline void +xdg_surface_move(struct xdg_surface *xdg_surface, struct wl_seat *seat, uint32_t serial) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_MOVE, seat, serial); +} + +static inline void +xdg_surface_resize(struct xdg_surface *xdg_surface, struct wl_seat *seat, uint32_t serial, uint32_t edges) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_RESIZE, seat, serial, edges); +} + +static inline void +xdg_surface_set_output(struct xdg_surface *xdg_surface, struct wl_output *output) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_OUTPUT, output); +} + +static inline void +xdg_surface_set_fullscreen(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_FULLSCREEN); +} + +static inline void +xdg_surface_unset_fullscreen(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_UNSET_FULLSCREEN); +} + +static inline void +xdg_surface_set_maximized(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_MAXIMIZED); +} + +static inline void +xdg_surface_unset_maximized(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_UNSET_MAXIMIZED); +} + +static inline void +xdg_surface_set_minimized(struct xdg_surface *xdg_surface) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_surface, + XDG_SURFACE_SET_MINIMIZED); +} + +/** + * xdg_popup - desktop-style metadata interface + * @ping: ping client + * @popup_done: popup interaction is done + * + * An interface that may be implemented by a wl_surface, for + * implementations that provide a desktop-style popups/menus. A popup + * surface is a transient surface with an added pointer grab. + * + * An existing implicit grab will be changed to owner-events mode, and the + * popup grab will continue after the implicit grab ends (i.e. releasing + * the mouse button does not cause the popup to be unmapped). + * + * The popup grab continues until the window is destroyed or a mouse button + * is pressed in any other clients window. A click in any of the clients + * surfaces is reported as normal, however, clicks in other clients + * surfaces will be discarded and trigger the callback. + * + * The x and y arguments specify the locations of the upper left corner of + * the surface relative to the upper left corner of the parent surface, in + * surface local coordinates. + * + * xdg_popup surfaces are always transient for another surface. + */ +struct xdg_popup_listener { + /** + * ping - ping client + * @serial: (none) + * + * Ping a client to check if it is receiving events and sending + * requests. A client is expected to reply with a pong request. + */ + void (*ping)(void *data, + struct xdg_popup *xdg_popup, + uint32_t serial); + /** + * popup_done - popup interaction is done + * @serial: serial of the implicit grab on the pointer + * + * The popup_done event is sent out when a popup grab is broken, + * that is, when the users clicks a surface that doesn't belong to + * the client owning the popup surface. + */ + void (*popup_done)(void *data, + struct xdg_popup *xdg_popup, + uint32_t serial); +}; + +static inline int +xdg_popup_add_listener(struct xdg_popup *xdg_popup, + const struct xdg_popup_listener *listener, void *data) +{ + return wl_proxy_add_listener((struct wl_proxy *) xdg_popup, + (void (**)(void)) listener, data); +} + +#define XDG_POPUP_DESTROY 0 +#define XDG_POPUP_PONG 1 + +static inline void +xdg_popup_set_user_data(struct xdg_popup *xdg_popup, void *user_data) +{ + wl_proxy_set_user_data((struct wl_proxy *) xdg_popup, user_data); +} + +static inline void * +xdg_popup_get_user_data(struct xdg_popup *xdg_popup) +{ + return wl_proxy_get_user_data((struct wl_proxy *) xdg_popup); +} + +static inline void +xdg_popup_destroy(struct xdg_popup *xdg_popup) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_popup, + XDG_POPUP_DESTROY); + + wl_proxy_destroy((struct wl_proxy *) xdg_popup); +} + +static inline void +xdg_popup_pong(struct xdg_popup *xdg_popup, uint32_t serial) +{ + wl_proxy_marshal((struct wl_proxy *) xdg_popup, + XDG_POPUP_PONG, serial); +} + +#ifdef __cplusplus +} +#endif + +#endif |