2015-08-18 06:50:28 -07:00
|
|
|
#ifndef _ECORE_WL2_H_
|
|
|
|
# define _ECORE_WL2_H_
|
|
|
|
|
|
|
|
# include <Eina.h>
|
|
|
|
# include <Ecore.h>
|
|
|
|
# include <wayland-client.h>
|
|
|
|
# include <wayland-cursor.h>
|
|
|
|
# include <xkbcommon/xkbcommon.h>
|
|
|
|
|
2015-08-18 08:56:07 -07:00
|
|
|
# define WL_HIDE_DEPRECATED
|
|
|
|
# include <wayland-server.h>
|
|
|
|
|
2015-08-18 06:50:28 -07:00
|
|
|
# ifdef EAPI
|
|
|
|
# undef EAPI
|
|
|
|
# endif
|
|
|
|
|
|
|
|
# ifdef __GNUC__
|
|
|
|
# if __GNUC__ >= 4
|
|
|
|
# define EAPI __attribute__ ((visibility("default")))
|
|
|
|
# else
|
|
|
|
# define EAPI
|
|
|
|
# endif
|
|
|
|
# else
|
|
|
|
# define EAPI
|
|
|
|
# endif
|
|
|
|
|
|
|
|
/* # ifdef __cplusplus */
|
|
|
|
/* extern "C" { */
|
|
|
|
/* # endif */
|
|
|
|
|
2015-08-20 09:39:39 -07:00
|
|
|
# ifndef _ECORE_WL2_WINDOW_PREDEF
|
|
|
|
typedef struct _Ecore_Wl2_Window Ecore_Wl2_Window;
|
2015-08-18 06:50:28 -07:00
|
|
|
# endif
|
|
|
|
|
2015-08-18 10:50:02 -07:00
|
|
|
typedef struct _Ecore_Wl2_Display Ecore_Wl2_Display;
|
|
|
|
|
2015-08-18 12:05:05 -07:00
|
|
|
typedef struct _Ecore_Wl2_Global
|
|
|
|
{
|
2015-08-18 12:11:09 -07:00
|
|
|
Eina_Stringshare *interface;
|
2015-08-18 12:05:05 -07:00
|
|
|
unsigned int id, version;
|
|
|
|
} Ecore_Wl2_Global;
|
|
|
|
|
|
|
|
typedef struct _Ecore_Wl2_Event_Global
|
|
|
|
{
|
|
|
|
Eina_Stringshare *interface;
|
|
|
|
unsigned int id, version;
|
|
|
|
} Ecore_Wl2_Event_Global;
|
|
|
|
|
2015-08-18 07:06:40 -07:00
|
|
|
EAPI extern int ECORE_WL2_EVENT_GLOBAL_ADDED;
|
|
|
|
EAPI extern int ECORE_WL2_EVENT_GLOBAL_REMOVED;
|
|
|
|
|
2015-08-18 07:57:32 -07:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief Ecore functions for dealing with the Wayland display protocol
|
|
|
|
*
|
|
|
|
* @defgroup Ecore_Wl2_Group Ecore_Wl2 - Wayland integration
|
|
|
|
* @ingroup Ecore
|
|
|
|
*
|
|
|
|
* Ecore_Wl2 provides a wrapper and convenience functions for using the
|
|
|
|
* Wayland protocol in implementing a window system. Function groups for
|
|
|
|
* this part of the library include the following:
|
|
|
|
*
|
|
|
|
* @li @ref Ecore_Wl2_Init_Group
|
|
|
|
* @li @ref Ecore_Wl2_Display_Group
|
2015-08-20 09:39:39 -07:00
|
|
|
* @li @ref Ecore_Wl2_Window_Group
|
2015-08-18 07:57:32 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup Ecore_Wl2_Init_Group Wayland Library Init and Shutdown Functions
|
|
|
|
* @ingroup Ecore_Wl2_Group
|
|
|
|
*
|
|
|
|
* Functions that start and shutdown the Ecore Wl2 Library.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the Ecore_Wl2 library
|
|
|
|
*
|
|
|
|
* @return The number of times the library has been initialized without being
|
|
|
|
* shutdown. 0 is returned if an error occurs.
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Init_Group
|
|
|
|
*/
|
2015-08-18 07:06:40 -07:00
|
|
|
EAPI int ecore_wl2_init(void);
|
2015-08-18 07:57:32 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Shutdown the Ecore_Wl2 Library
|
|
|
|
*
|
|
|
|
* @return The number of times the library has been initialized without
|
|
|
|
* being shutdown.
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Init_Group
|
|
|
|
*/
|
2015-08-18 07:06:40 -07:00
|
|
|
EAPI int ecore_wl2_shutdown(void);
|
|
|
|
|
2015-08-18 08:56:07 -07:00
|
|
|
/**
|
|
|
|
* @defgroup Ecore_Wl2_Display_Group Wayland Library Display Functions
|
|
|
|
* @ingroup Ecore_Wl2_Group
|
|
|
|
*
|
|
|
|
* Functions that deal with creating, connecting, or interacting with
|
|
|
|
* Wayland displays
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new Wayland display
|
|
|
|
*
|
|
|
|
* @brief This function is typically used to create a new display for
|
|
|
|
* use with compositors, or to create a new display for use in nested
|
|
|
|
* compositors.
|
|
|
|
*
|
2015-08-18 12:55:24 -07:00
|
|
|
* @param name The display target name to create. If @c NULL, a default
|
|
|
|
* display name will be assigned.
|
2015-08-18 10:50:02 -07:00
|
|
|
* @return The newly created Ecore_Wl2_Display
|
2015-08-18 08:56:07 -07:00
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
2015-08-18 12:55:24 -07:00
|
|
|
EAPI Ecore_Wl2_Display *ecore_wl2_display_create(const char *name);
|
2015-08-18 08:56:07 -07:00
|
|
|
|
2015-08-20 07:22:03 -07:00
|
|
|
/**
|
|
|
|
* Destroy an existing Wayland display
|
|
|
|
*
|
|
|
|
* @brief This function is typically used by servers to terminate an
|
|
|
|
* existing Wayland display.
|
|
|
|
*
|
|
|
|
* @param display The display to terminate
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI void ecore_wl2_display_destroy(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-18 08:56:07 -07:00
|
|
|
/**
|
|
|
|
* Connect to an existing Wayland display
|
|
|
|
*
|
|
|
|
* @brief This function is typically used by clients to connect to an
|
2015-08-18 10:50:02 -07:00
|
|
|
* existing Wayland display.
|
2015-08-18 08:56:07 -07:00
|
|
|
*
|
|
|
|
* @param name The display target name to connect to. If @c NULL, the default
|
|
|
|
* display is assumed.
|
|
|
|
*
|
2015-08-18 10:50:02 -07:00
|
|
|
* @return The Ecore_Wl2_Display which was connected to
|
2015-08-18 08:56:07 -07:00
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
2015-08-18 10:50:02 -07:00
|
|
|
EAPI Ecore_Wl2_Display *ecore_wl2_display_connect(const char *name);
|
2015-08-18 08:56:07 -07:00
|
|
|
|
2015-08-20 07:15:07 -07:00
|
|
|
/**
|
|
|
|
* Disconnect an existing Wayland display
|
|
|
|
*
|
|
|
|
* @brief This function is typically used by clients to disconnect from an
|
|
|
|
* existing Wayland display.
|
|
|
|
*
|
|
|
|
* @param display The display to disconnect from
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI void ecore_wl2_display_disconnect(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-20 07:57:07 -07:00
|
|
|
/**
|
|
|
|
* Terminate a Wayland display's main loop
|
|
|
|
*
|
|
|
|
* @brief This function is typically used by servers to terminate the
|
|
|
|
* Wayland display main loop. This is usually only called when a server
|
|
|
|
* encounters an error.
|
|
|
|
*
|
|
|
|
* @param display The Ecore_Wl2_Display to terminate
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI void ecore_wl2_display_terminate(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-19 10:41:01 -07:00
|
|
|
/**
|
|
|
|
* Retrieve the existing Wayland display
|
|
|
|
*
|
|
|
|
* @param display The Ecore_Wl2_Display for which to retrieve the existing
|
|
|
|
* Wayland display from
|
|
|
|
*
|
|
|
|
* @return The wl_display which this Ecore_Wl2_Display is using
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI struct wl_display *ecore_wl2_display_get(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-20 06:56:18 -07:00
|
|
|
/**
|
|
|
|
* Retrieve the wl_shm from a given Ecore_Wl2_Display
|
|
|
|
*
|
|
|
|
* @param display The Ecore_Wl2_Display for which to retrieve the existing
|
|
|
|
* Wayland shm interface from
|
|
|
|
*
|
|
|
|
* @return The wl_shm which this Ecore_Wl2_Display is using
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI struct wl_shm *ecore_wl2_display_shm_get(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-20 09:18:52 -07:00
|
|
|
/**
|
|
|
|
* Return an Eina_Iterator that can be used to iterate through globals
|
|
|
|
*
|
|
|
|
* @param display The Ecore_Wl2_Display for which to return a global iterator
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Display_Group
|
|
|
|
*/
|
|
|
|
EAPI Eina_Iterator *ecore_wl2_display_globals_get(Ecore_Wl2_Display *display);
|
|
|
|
|
2015-08-20 09:39:39 -07:00
|
|
|
/**
|
|
|
|
* @defgroup Ecore_Wl2_Window_Group Wayland Library Window Functions
|
|
|
|
* @ingroup Ecore_Wl2_Group
|
|
|
|
*
|
|
|
|
* Functions that deal with creating, connecting, or interacting with
|
|
|
|
* Wayland windows
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new Ecore_Wl2_Window
|
|
|
|
*
|
|
|
|
* @param display The Ecore_Wl2_Display on which to create this new window
|
|
|
|
* @param parent The Ecore_Wl2_Window which is the parent of this window
|
|
|
|
* @param x Initial x position of window
|
|
|
|
* @param y Initial y position of window
|
|
|
|
* @param w Initial width of window
|
|
|
|
* @param h Initial height of window
|
|
|
|
*
|
|
|
|
* @ingroup Ecore_Wl2_Window_Group
|
|
|
|
*/
|
|
|
|
EAPI Ecore_Wl2_Window *ecore_wl2_window_new(Ecore_Wl2_Display *display, Ecore_Wl2_Window *parent, int x, int y, int w, int h);
|
|
|
|
|
2015-08-20 09:44:17 -07:00
|
|
|
/**
|
|
|
|
* Get the window id associated with an Ecore_Wl2_Window
|
|
|
|
*
|
|
|
|
* @param window The Ecore_Wl2_Window of which to retrieve the window id
|
|
|
|
*
|
|
|
|
* @return The id associated with this window
|
|
|
|
*/
|
|
|
|
EAPI int ecore_wl2_window_id_get(Ecore_Wl2_Window *window);
|
|
|
|
|
2015-08-18 06:50:28 -07:00
|
|
|
/* # ifdef __cplusplus */
|
|
|
|
/* } */
|
|
|
|
/* # endif */
|
|
|
|
|
|
|
|
# undef EAPI
|
|
|
|
# define EAPI
|
|
|
|
|
|
|
|
#endif
|