diff options
Diffstat (limited to 'sample/simple-egl/include/ivi-application-client-protocol.h')
-rw-r--r-- | sample/simple-egl/include/ivi-application-client-protocol.h | 245 |
1 files changed, 245 insertions, 0 deletions
diff --git a/sample/simple-egl/include/ivi-application-client-protocol.h b/sample/simple-egl/include/ivi-application-client-protocol.h new file mode 100644 index 0000000..ca31bf7 --- /dev/null +++ b/sample/simple-egl/include/ivi-application-client-protocol.h @@ -0,0 +1,245 @@ +/* Generated by wayland-scanner 1.11.0 */ + +#ifndef IVI_APPLICATION_CLIENT_PROTOCOL_H +#define IVI_APPLICATION_CLIENT_PROTOCOL_H + +#include <stdint.h> +#include <stddef.h> +#include "wayland-client.h" + +//#ifdef __cplusplus +//extern "C" { +//#endif + +/** + * @page page_ivi_application The ivi_application protocol + * @section page_ifaces_ivi_application Interfaces + * - @subpage page_iface_ivi_surface - application interface to surface in ivi compositor + * - @subpage page_iface_ivi_application - create ivi-style surfaces + * @section page_copyright_ivi_application Copyright + * <pre> + * + * Copyright (C) 2013 DENSO CORPORATION + * Copyright (c) 2013 BMW Car IT GmbH + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * </pre> + */ +struct ivi_application; +struct ivi_surface; +struct wl_surface; + +/** + * @page page_iface_ivi_surface ivi_surface + * @section page_iface_ivi_surface_desc Description + * @section page_iface_ivi_surface_api API + * See @ref iface_ivi_surface. + */ +/** + * @defgroup iface_ivi_surface The ivi_surface interface + */ +extern const struct wl_interface ivi_surface_interface; +/** + * @page page_iface_ivi_application ivi_application + * @section page_iface_ivi_application_desc Description + * + * This interface is exposed as a global singleton. + * This interface is implemented by servers that provide IVI-style user interfaces. + * It allows clients to associate a ivi_surface with wl_surface. + * @section page_iface_ivi_application_api API + * See @ref iface_ivi_application. + */ +/** + * @defgroup iface_ivi_application The ivi_application interface + * + * This interface is exposed as a global singleton. + * This interface is implemented by servers that provide IVI-style user interfaces. + * It allows clients to associate a ivi_surface with wl_surface. + */ +extern const struct wl_interface ivi_application_interface; + +/** + * @ingroup iface_ivi_surface + * @struct ivi_surface_listener + */ +struct ivi_surface_listener { + /** + * suggest resize + * + * 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 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 ivi_surface *ivi_surface, + int32_t width, + int32_t height); +}; + +/** + * @ingroup ivi_surface_iface + */ +static inline int +ivi_surface_add_listener(struct ivi_surface *ivi_surface, + const struct ivi_surface_listener *listener, void *data) +{ + return wl_proxy_add_listener((struct wl_proxy *) ivi_surface, + (void (**)(void)) listener, data); +} + +#define IVI_SURFACE_DESTROY 0 + +/** + * @ingroup iface_ivi_surface + */ +#define IVI_SURFACE_DESTROY_SINCE_VERSION 1 + +/** @ingroup iface_ivi_surface */ +static inline void +ivi_surface_set_user_data(struct ivi_surface *ivi_surface, void *user_data) +{ + wl_proxy_set_user_data((struct wl_proxy *) ivi_surface, user_data); +} + +/** @ingroup iface_ivi_surface */ +static inline void * +ivi_surface_get_user_data(struct ivi_surface *ivi_surface) +{ + return wl_proxy_get_user_data((struct wl_proxy *) ivi_surface); +} + +static inline uint32_t +ivi_surface_get_version(struct ivi_surface *ivi_surface) +{ + return wl_proxy_get_version((struct wl_proxy *) ivi_surface); +} + +/** + * @ingroup iface_ivi_surface + * + * This removes link from ivi_id to wl_surface and destroys ivi_surface. + * The ID, ivi_id, is free and can be used for surface_create again. + */ +static inline void +ivi_surface_destroy(struct ivi_surface *ivi_surface) +{ + wl_proxy_marshal((struct wl_proxy *) ivi_surface, + IVI_SURFACE_DESTROY); + + wl_proxy_destroy((struct wl_proxy *) ivi_surface); +} + +#ifndef IVI_APPLICATION_ERROR_ENUM +#define IVI_APPLICATION_ERROR_ENUM +enum ivi_application_error { + /** + * given wl_surface has another role + */ + IVI_APPLICATION_ERROR_ROLE = 0, + /** + * given ivi_id is assigned to another wl_surface + */ + IVI_APPLICATION_ERROR_IVI_ID = 1, +}; +#endif /* IVI_APPLICATION_ERROR_ENUM */ + +#define IVI_APPLICATION_SURFACE_CREATE 0 + +/** + * @ingroup iface_ivi_application + */ +#define IVI_APPLICATION_SURFACE_CREATE_SINCE_VERSION 1 + +/** @ingroup iface_ivi_application */ +static inline void +ivi_application_set_user_data(struct ivi_application *ivi_application, void *user_data) +{ + wl_proxy_set_user_data((struct wl_proxy *) ivi_application, user_data); +} + +/** @ingroup iface_ivi_application */ +static inline void * +ivi_application_get_user_data(struct ivi_application *ivi_application) +{ + return wl_proxy_get_user_data((struct wl_proxy *) ivi_application); +} + +static inline uint32_t +ivi_application_get_version(struct ivi_application *ivi_application) +{ + return wl_proxy_get_version((struct wl_proxy *) ivi_application); +} + +/** @ingroup iface_ivi_application */ +static inline void +ivi_application_destroy(struct ivi_application *ivi_application) +{ + wl_proxy_destroy((struct wl_proxy *) ivi_application); +} + +/** + * @ingroup iface_ivi_application + * + * This request gives the wl_surface the role of an IVI Surface. Creating more than + * one ivi_surface for a wl_surface is not allowed. Note, that this still allows the + * following example: + * + * 1. create a wl_surface + * 2. create ivi_surface for the wl_surface + * 3. destroy the ivi_surface + * 4. create ivi_surface for the wl_surface (with the same or another ivi_id as before) + * + * surface_create will create a interface:ivi_surface with numeric ID; ivi_id in + * ivi compositor. These ivi_ids are defined as unique in the system to identify + * it inside of ivi compositor. The ivi compositor implements business logic how to + * set properties of the surface with ivi_id according to status of the system. + * E.g. a unique ID for Car Navigation application is used for implementing special + * logic of the application about where it shall be located. + * The server regards following cases as protocol errors and disconnects the client. + * - wl_surface already has an nother role. + * - ivi_id is already assigned to an another wl_surface. + * + * If client destroys ivi_surface or wl_surface which is assigne to the ivi_surface, + * ivi_id which is assigned to the ivi_surface is free for reuse. + */ +static inline struct ivi_surface * +ivi_application_surface_create(struct ivi_application *ivi_application, uint32_t ivi_id, struct wl_surface *surface) +{ + struct wl_proxy *id; + + id = wl_proxy_marshal_constructor((struct wl_proxy *) ivi_application, + IVI_APPLICATION_SURFACE_CREATE, &ivi_surface_interface, ivi_id, surface, NULL); + + return (struct ivi_surface *) id; +} + +//#ifdef __cplusplus +//} +//#endif + +#endif |