diff options
author | Ronan Le Martret <ronan@fridu.net> | 2014-12-30 14:48:09 +0100 |
---|---|---|
committer | Patrick Ohly <patrick.ohly@intel.com> | 2015-01-09 09:24:01 -0800 |
commit | 793a34608cd12c3142fb725f509c5a9af993f753 (patch) | |
tree | 1112e2e418971d256881bfe82461ea6a1ab0c925 | |
parent | 21534960870a4548e8353c10e06e096e5ad18ba9 (diff) | |
download | tizen-distro-793a34608cd12c3142fb725f509c5a9af993f753.tar.gz tizen-distro-793a34608cd12c3142fb725f509c5a9af993f753.tar.bz2 tizen-distro-793a34608cd12c3142fb725f509c5a9af993f753.zip |
meta-tizen: add fix for Tizen ivi
Change-Id: I709822d6b6f1aba57a59408f332abd3aed882a9b
(From meta-tizen rev: 6fa9f017272d3ff510c07835cb63a2138eb07e56)
Signed-off-by: Ronan Le Martret <ronan@fridu.net>
Signed-off-by: Patrick Ohly <patrick.ohly@intel.com>
2 files changed, 2413 insertions, 0 deletions
diff --git a/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/files/0001-Added-APIstosupportmultiseatinwayland.patch b/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/files/0001-Added-APIstosupportmultiseatinwayland.patch new file mode 100644 index 0000000000..3bc44bf891 --- /dev/null +++ b/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/files/0001-Added-APIstosupportmultiseatinwayland.patch @@ -0,0 +1,2407 @@ +From 7d52489471905f42741f99d50474eaa0a4c9698c Mon Sep 17 00:00:00 2001 +From: Imran Zaman <imran.zaman@intel.com> +Date: Wed, 15 Oct 2014 18:02:48 +0300 +Subject: [PATCH] meta-tizen: Added APIs to support multiseat in wayland + +Clients can use name and/or seatname of the outputs +to select the output(s) as per its need + +Change-Id: I92377f262a19371a747ce1cdeddcb790171e51c1 +Signed-off-by: Imran Zaman <imran.zaman@intel.com> +--- + Makefile.am | 16 +- + configure.ac | 8 + + doc/publican/Makefile.am | 14 +- + doc/publican/sources/Protocol.xml | 2 + + packaging/wayland.spec | 7 +- + protocol/wayland.xml | 1 + + protocol/wayland_multiseat.xml | 2113 +++++++++++++++++++++++++++++++++++++ + src/scanner.c | 2 +- + src/wayland-client.c | 10 +- + src/wayland-server.c | 50 +- + 10 files changed, 2210 insertions(+), 13 deletions(-) + create mode 100644 protocol/wayland_multiseat.xml + +diff --git a/Makefile.am b/Makefile.am +index 1551762..2e0531c 100644 +--- a/Makefile.am ++++ b/Makefile.am +@@ -9,9 +9,17 @@ dist_aclocal_DATA = wayland-scanner.m4 + + dist_pkgdata_DATA = \ + wayland-scanner.mk \ +- protocol/wayland.xml \ ++ protocol/wayland.xml \ + protocol/wayland.dtd + ++if HAVE_MULTISEAT ++GCC_CFLAGS += -DHAVE_MULTISEAT ++wayland_api = $(top_srcdir)/protocol/wayland_multiseat.xml ++dist_pkgdata_DATA += protocol/wayland_multiseat.xml ++else ++wayland_api = $(top_srcdir)/protocol/wayland.xml ++endif ++ + pkgconfigdir = $(libdir)/pkgconfig + pkgconfig_DATA = + +@@ -72,13 +80,13 @@ else + wayland_scanner = wayland-scanner + endif + +-protocol/%-protocol.c : $(top_srcdir)/protocol/%.xml ++protocol/%-protocol.c : $(wayland_api) + $(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) code < $< > $@ + +-protocol/%-server-protocol.h : $(top_srcdir)/protocol/%.xml ++protocol/%-server-protocol.h : $(wayland_api) + $(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) server-header < $< > $@ + +-protocol/%-client-protocol.h : $(top_srcdir)/protocol/%.xml ++protocol/%-client-protocol.h : $(wayland_api) + $(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) client-header < $< > $@ + + BUILT_SOURCES = \ +diff --git a/configure.ac b/configure.ac +index cc7b535..6e9166a 100644 +--- a/configure.ac ++++ b/configure.ac +@@ -66,6 +66,14 @@ AC_ARG_ENABLE([documentation], + + AM_CONDITIONAL(ENABLE_SCANNER, test "x$enable_scanner" = xyes) + ++AC_ARG_ENABLE([multiseat], ++ [AC_HELP_STRING([--enable-multiseat], ++ [Enable multiseat feature])], ++ [], ++ [enable_multiseat=no]) ++ ++AM_CONDITIONAL(HAVE_MULTISEAT, test "x$enable_multiseat" = xyes) ++ + AC_ARG_WITH(icondir, [ --with-icondir=<dir> Look for cursor icons here], + [ ICONDIR=$withval], + [ ICONDIR=${datadir}/icons]) +diff --git a/doc/publican/Makefile.am b/doc/publican/Makefile.am +index 47fc66d..4d8feb8 100644 +--- a/doc/publican/Makefile.am ++++ b/doc/publican/Makefile.am +@@ -40,20 +40,26 @@ if HAVE_XSLTPROC + noinst_DATA = Wayland $(publican_targets) + pubdir = $(docdir)/Wayland/en-US + ++if HAVE_MULTISEAT ++wayland_api = $(top_srcdir)/protocol/wayland_multiseat.xml ++else ++wayland_api = $(top_srcdir)/protocol/wayland.xml ++endif ++ + publican_targets = $(publican_sources:$(srcdir)/sources%=$(builddir)/en-US%) \ + en-US/ProtocolSpec.xml en-US/ProtocolInterfaces.xml \ + en-US/WaylandClientAPI.xml en-US/WaylandServerAPI.xml + + # The Protocol.xml is purely generated and required before running publican +-en-US/ProtocolSpec.xml: $(top_srcdir)/protocol/wayland.xml $(srcdir)/protocol-to-docbook.xsl ++en-US/ProtocolSpec.xml: $(wayland_api) $(srcdir)/protocol-to-docbook.xsl + $(AM_V_GEN)$(MKDIR_P) en-US/images + $(AM_V_GEN)$(XSLTPROC) $(srcdir)/protocol-to-docbook.xsl \ +- $(top_srcdir)/protocol/wayland.xml > en-US/ProtocolSpec.xml ++ $(wayland_api) > en-US/ProtocolSpec.xml + +-en-US/ProtocolInterfaces.xml: $(top_srcdir)/protocol/wayland.xml $(srcdir)/protocol-interfaces-to-docbook.xsl ++en-US/ProtocolInterfaces.xml: $(wayland_api) $(srcdir)/protocol-interfaces-to-docbook.xsl + $(AM_V_GEN)$(MKDIR_P) en-US/images + $(AM_V_GEN)$(XSLTPROC) $(srcdir)/protocol-interfaces-to-docbook.xsl \ +- $(top_srcdir)/protocol/wayland.xml > en-US/ProtocolInterfaces.xml ++ $(wayland_api) > en-US/ProtocolInterfaces.xml + + # * we don't want wayland-{server|client}_8h.xml to avoid duplicating output methods, + # move it out of the way first. +diff --git a/doc/publican/sources/Protocol.xml b/doc/publican/sources/Protocol.xml +index b79b6be..0d4f36e 100644 +--- a/doc/publican/sources/Protocol.xml ++++ b/doc/publican/sources/Protocol.xml +@@ -48,6 +48,8 @@ + <filename>protocol/wayland.xml</filename>. + This xml is used to generate the function prototypes that can be used by + clients and compositors. ++ When multiseat is enabled, <filename>protocol/wayland_multiseat.xml</filename> ++ is used. + </para> + <para> + The protocol entry points are generated as inline functions which just +diff --git a/protocol/wayland.xml b/protocol/wayland.xml +index bb457bc..6dbd1f1 100644 +--- a/protocol/wayland.xml ++++ b/protocol/wayland.xml +@@ -1829,6 +1829,7 @@ + </description> + <arg name="factor" type="int" summary="scaling factor of output"/> + </event> ++ + </interface> + + <interface name="wl_region" version="1"> +diff --git a/protocol/wayland_multiseat.xml b/protocol/wayland_multiseat.xml +new file mode 100644 +index 0000000..cd12152 +--- /dev/null ++++ b/protocol/wayland_multiseat.xml +@@ -0,0 +1,2113 @@ ++<?xml version="1.0" encoding="UTF-8"?> ++<protocol name="wayland"> ++ ++ <copyright> ++ Copyright © 2008-2011 Kristian Høgsberg ++ Copyright © 2010-2011 Intel Corporation ++ Copyright © 2012-2013 Collabora, Ltd. ++ ++ 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. ++ </copyright> ++ ++ <interface name="wl_display" version="1"> ++ <description summary="core global object"> ++ The core global object. This is a special singleton object. It ++ is used for internal Wayland protocol features. ++ </description> ++ ++ <request name="sync"> ++ <description summary="asynchronous roundtrip"> ++ The sync request asks the server to emit the 'done' event ++ on the returned wl_callback object. Since requests are ++ handled in-order and events are delivered in-order, this can ++ be used as a barrier to ensure all previous requests and the ++ resulting events have been handled. ++ ++ The object returned by this request will be destroyed by the ++ compositor after the callback is fired and as such the client must not ++ attempt to use it after that point. ++ ++ The callback_data passed in the callback is the event serial. ++ </description> ++ <arg name="callback" type="new_id" interface="wl_callback"/> ++ </request> ++ ++ <request name="get_registry"> ++ <description summary="get global registry object"> ++ This request creates a registry object that allows the client ++ to list and bind the global objects available from the ++ compositor. ++ </description> ++ <arg name="registry" type="new_id" interface="wl_registry"/> ++ </request> ++ ++ <event name="error"> ++ <description summary="fatal error event"> ++ The error event is sent out when a fatal (non-recoverable) ++ error has occurred. The object_id argument is the object ++ where the error occurred, most often in response to a request ++ to that object. The code identifies the error and is defined ++ by the object interface. As such, each interface defines its ++ own set of error codes. The message is an brief description ++ of the error, for (debugging) convenience. ++ </description> ++ <arg name="object_id" type="object"/> ++ <arg name="code" type="uint"/> ++ <arg name="message" type="string"/> ++ </event> ++ ++ <enum name="error"> ++ <description summary="global error values"> ++ These errors are global and can be emitted in response to any ++ server request. ++ </description> ++ <entry name="invalid_object" value="0" ++ summary="server couldn't find object"/> ++ <entry name="invalid_method" value="1" ++ summary="method doesn't exist on the specified interface"/> ++ <entry name="no_memory" value="2" ++ summary="server is out of memory"/> ++ </enum> ++ ++ <event name="delete_id"> ++ <description summary="acknowledge object ID deletion"> ++ This event is used internally by the object ID management ++ logic. When a client deletes an object, the server will send ++ this event to acknowledge that it has seen the delete request. ++ When the client receive this event, it will know that it can ++ safely reuse the object ID. ++ </description> ++ <arg name="id" type="uint" /> ++ </event> ++ </interface> ++ ++ <interface name="wl_registry" version="1"> ++ <description summary="global registry object"> ++ The global registry object. The server has a number of global ++ objects that are available to all clients. These objects ++ typically represent an actual object in the server (for example, ++ an input device) or they are singleton objects that provide ++ extension functionality. ++ ++ When a client creates a registry object, the registry object ++ will emit a global event for each global currently in the ++ registry. Globals come and go as a result of device or ++ monitor hotplugs, reconfiguration or other events, and the ++ registry will send out global and global_remove events to ++ keep the client up to date with the changes. To mark the end ++ of the initial burst of events, the client can use the ++ wl_display.sync request immediately after calling ++ wl_display.get_registry. ++ ++ A client can bind to a global object by using the bind ++ request. This creates a client-side handle that lets the object ++ emit events to the client and lets the client invoke requests on ++ the object. ++ </description> ++ ++ <request name="bind"> ++ <description summary="bind an object to the display"> ++ Binds a new, client-created object to the server using the ++ specified name as the identifier. ++ </description> ++ <arg name="name" type="uint" summary="unique name for the object"/> ++ <arg name="id" type="new_id"/> ++ </request> ++ ++ <event name="global"> ++ <description summary="announce global object"> ++ Notify the client of global objects. ++ ++ The event notifies the client that a global object with ++ the given name is now available, and it implements the ++ given version of the given interface. ++ </description> ++ <arg name="name" type="uint"/> ++ <arg name="interface" type="string"/> ++ <arg name="version" type="uint"/> ++ </event> ++ ++ <event name="global_remove"> ++ <description summary="announce removal of global object"> ++ Notify the client of removed global objects. ++ ++ This event notifies the client that the global identified ++ by name is no longer available. If the client bound to ++ the global using the bind request, the client should now ++ destroy that object. ++ ++ The object remains valid and requests to the object will be ++ ignored until the client destroys it, to avoid races between ++ the global going away and a client sending a request to it. ++ </description> ++ <arg name="name" type="uint"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_callback" version="1"> ++ <description summary="callback object"> ++ Clients can handle the 'done' event to get notified when ++ the related request is done. ++ </description> ++ <event name="done"> ++ <description summary="done event"> ++ Notify the client when the related request is done. ++ </description> ++ <arg name="callback_data" type="uint" summary="request-specific data for the wl_callback"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_compositor" version="3"> ++ <description summary="the compositor singleton"> ++ A compositor. This object is a singleton global. The ++ compositor is in charge of combining the contents of multiple ++ surfaces into one displayable output. ++ </description> ++ ++ <request name="create_surface"> ++ <description summary="create new surface"> ++ Ask the compositor to create a new surface. ++ </description> ++ <arg name="id" type="new_id" interface="wl_surface"/> ++ </request> ++ ++ <request name="create_region"> ++ <description summary="create new region"> ++ Ask the compositor to create a new region. ++ </description> ++ <arg name="id" type="new_id" interface="wl_region"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_shm_pool" version="1"> ++ <description summary="a shared memory pool"> ++ The wl_shm_pool object encapsulates a piece of memory shared ++ between the compositor and client. Through the wl_shm_pool ++ object, the client can allocate shared memory wl_buffer objects. ++ All objects created through the same pool share the same ++ underlying mapped memory. Reusing the mapped memory avoids the ++ setup/teardown overhead and is useful when interactively resizing ++ a surface or for many small buffers. ++ </description> ++ ++ <request name="create_buffer"> ++ <description summary="create a buffer from the pool"> ++ Create a wl_buffer object from the pool. ++ ++ The buffer is created offset bytes into the pool and has ++ width and height as specified. The stride arguments specifies ++ the number of bytes from beginning of one row to the beginning ++ of the next. The format is the pixel format of the buffer and ++ must be one of those advertised through the wl_shm.format event. ++ ++ A buffer will keep a reference to the pool it was created from ++ so it is valid to destroy the pool immediately after creating ++ a buffer from it. ++ </description> ++ ++ <arg name="id" type="new_id" interface="wl_buffer"/> ++ <arg name="offset" type="int"/> ++ <arg name="width" type="int"/> ++ <arg name="height" type="int"/> ++ <arg name="stride" type="int"/> ++ <arg name="format" type="uint"/> ++ </request> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="destroy the pool"> ++ Destroy the shared memory pool. ++ ++ The mmapped memory will be released when all ++ buffers that have been created from this pool ++ are gone. ++ </description> ++ </request> ++ ++ <request name="resize"> ++ <description summary="change the size of the pool mapping"> ++ This request will cause the server to remap the backing memory ++ for the pool from the file descriptor passed when the pool was ++ created, but using the new size. This request can only be ++ used to make the pool bigger. ++ </description> ++ ++ <arg name="size" type="int"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_shm" version="1"> ++ <description summary="shared memory support"> ++ A global singleton object that provides support for shared ++ memory. ++ ++ Clients can create wl_shm_pool objects using the create_pool ++ request. ++ ++ At connection setup time, the wl_shm object emits one or more ++ format events to inform clients about the valid pixel formats ++ that can be used for buffers. ++ </description> ++ ++ <enum name="error"> ++ <description summary="wl_shm error values"> ++ These errors can be emitted in response to wl_shm requests. ++ </description> ++ <entry name="invalid_format" value="0" summary="buffer format is not known"/> ++ <entry name="invalid_stride" value="1" summary="invalid size or stride during pool or buffer creation"/> ++ <entry name="invalid_fd" value="2" summary="mmapping the file descriptor failed"/> ++ </enum> ++ ++ <enum name="format"> ++ <description summary="pixel formats"> ++ This describes the memory layout of an individual pixel. ++ ++ All renderers should support argb8888 and xrgb8888 but any other ++ formats are optional and may not be supported by the particular ++ renderer in use. ++ </description> ++ <entry name="argb8888" value="0" summary="32-bit ARGB format"/> ++ <entry name="xrgb8888" value="1" summary="32-bit RGB format"/> ++ <!-- The drm format codes match the #defines in drm_fourcc.h. ++ The formats actually supported by the compositor will be ++ reported by the format event. --> ++ <entry name="c8" value="0x20203843"/> ++ <entry name="rgb332" value="0x38424752"/> ++ <entry name="bgr233" value="0x38524742"/> ++ <entry name="xrgb4444" value="0x32315258"/> ++ <entry name="xbgr4444" value="0x32314258"/> ++ <entry name="rgbx4444" value="0x32315852"/> ++ <entry name="bgrx4444" value="0x32315842"/> ++ <entry name="argb4444" value="0x32315241"/> ++ <entry name="abgr4444" value="0x32314241"/> ++ <entry name="rgba4444" value="0x32314152"/> ++ <entry name="bgra4444" value="0x32314142"/> ++ <entry name="xrgb1555" value="0x35315258"/> ++ <entry name="xbgr1555" value="0x35314258"/> ++ <entry name="rgbx5551" value="0x35315852"/> ++ <entry name="bgrx5551" value="0x35315842"/> ++ <entry name="argb1555" value="0x35315241"/> ++ <entry name="abgr1555" value="0x35314241"/> ++ <entry name="rgba5551" value="0x35314152"/> ++ <entry name="bgra5551" value="0x35314142"/> ++ <entry name="rgb565" value="0x36314752"/> ++ <entry name="bgr565" value="0x36314742"/> ++ <entry name="rgb888" value="0x34324752"/> ++ <entry name="bgr888" value="0x34324742"/> ++ <entry name="xbgr8888" value="0x34324258"/> ++ <entry name="rgbx8888" value="0x34325852"/> ++ <entry name="bgrx8888" value="0x34325842"/> ++ <entry name="abgr8888" value="0x34324241"/> ++ <entry name="rgba8888" value="0x34324152"/> ++ <entry name="bgra8888" value="0x34324142"/> ++ <entry name="xrgb2101010" value="0x30335258"/> ++ <entry name="xbgr2101010" value="0x30334258"/> ++ <entry name="rgbx1010102" value="0x30335852"/> ++ <entry name="bgrx1010102" value="0x30335842"/> ++ <entry name="argb2101010" value="0x30335241"/> ++ <entry name="abgr2101010" value="0x30334241"/> ++ <entry name="rgba1010102" value="0x30334152"/> ++ <entry name="bgra1010102" value="0x30334142"/> ++ <entry name="yuyv" value="0x56595559"/> ++ <entry name="yvyu" value="0x55595659"/> ++ <entry name="uyvy" value="0x59565955"/> ++ <entry name="vyuy" value="0x59555956"/> ++ <entry name="ayuv" value="0x56555941"/> ++ <entry name="nv12" value="0x3231564e"/> ++ <entry name="nv21" value="0x3132564e"/> ++ <entry name="nv16" value="0x3631564e"/> ++ <entry name="nv61" value="0x3136564e"/> ++ <entry name="yuv410" value="0x39565559"/> ++ <entry name="yvu410" value="0x39555659"/> ++ <entry name="yuv411" value="0x31315559"/> ++ <entry name="yvu411" value="0x31315659"/> ++ <entry name="yuv420" value="0x32315559"/> ++ <entry name="yvu420" value="0x32315659"/> ++ <entry name="yuv422" value="0x36315559"/> ++ <entry name="yvu422" value="0x36315659"/> ++ <entry name="yuv444" value="0x34325559"/> ++ <entry name="yvu444" value="0x34325659"/> ++ </enum> ++ ++ <request name="create_pool"> ++ <description summary="create a shm pool"> ++ Create a new wl_shm_pool object. ++ ++ The pool can be used to create shared memory based buffer ++ objects. The server will mmap size bytes of the passed file ++ descriptor, to use as backing memory for the pool. ++ </description> ++ ++ <arg name="id" type="new_id" interface="wl_shm_pool"/> ++ <arg name="fd" type="fd"/> ++ <arg name="size" type="int"/> ++ </request> ++ ++ <event name="format"> ++ <description summary="pixel format description"> ++ Informs the client about a valid pixel format that ++ can be used for buffers. Known formats include ++ argb8888 and xrgb8888. ++ </description> ++ <arg name="format" type="uint"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_buffer" version="1"> ++ <description summary="content for a wl_surface"> ++ A buffer provides the content for a wl_surface. Buffers are ++ created through factory interfaces such as wl_drm, wl_shm or ++ similar. It has a width and a height and can be attached to a ++ wl_surface, but the mechanism by which a client provides and ++ updates the contents is defined by the buffer factory interface. ++ </description> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="destroy a buffer"> ++ Destroy a buffer. If and how you need to release the backing ++ storage is defined by the buffer factory interface. ++ ++ For possible side-effects to a surface, see wl_surface.attach. ++ </description> ++ </request> ++ ++ <event name="release"> ++ <description summary="compositor releases buffer"> ++ Sent when this wl_buffer is no longer used by the compositor. ++ The client is now free to re-use or destroy this buffer and its ++ backing storage. ++ ++ If a client receives a release event before the frame callback ++ requested in the same wl_surface.commit that attaches this ++ wl_buffer to a surface, then the client is immediately free to ++ re-use the buffer and its backing storage, and does not need a ++ second buffer for the next surface content update. Typically ++ this is possible, when the compositor maintains a copy of the ++ wl_surface contents, e.g. as a GL texture. This is an important ++ optimization for GL(ES) compositors with wl_shm clients. ++ </description> ++ </event> ++ </interface> ++ ++ ++ <interface name="wl_data_offer" version="1"> ++ <description summary="offer to transfer data"> ++ A wl_data_offer represents a piece of data offered for transfer ++ by another client (the source client). It is used by the ++ copy-and-paste and drag-and-drop mechanisms. The offer ++ describes the different mime types that the data can be ++ converted to and provides the mechanism for transferring the ++ data directly from the source client. ++ </description> ++ ++ <request name="accept"> ++ <description summary="accept one of the offered mime types"> ++ Indicate that the client can accept the given mime type, or ++ NULL for not accepted. ++ ++ Used for feedback during drag-and-drop. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="mime_type" type="string" allow-null="true"/> ++ </request> ++ ++ <request name="receive"> ++ <description summary="request that the data is transferred"> ++ To transfer the offered data, the client issues this request ++ and indicates the mime type it wants to receive. The transfer ++ happens through the passed file descriptor (typically created ++ with the pipe system call). The source client writes the data ++ in the mime type representation requested and then closes the ++ file descriptor. ++ ++ The receiving client reads from the read end of the pipe until ++ EOF and the closes its end, at which point the transfer is ++ complete. ++ </description> ++ <arg name="mime_type" type="string"/> ++ <arg name="fd" type="fd"/> ++ </request> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="destroy data offer"> ++ Destroy the data offer. ++ </description> ++ </request> ++ ++ <event name="offer"> ++ <description summary="advertise offered mime type"> ++ Sent immediately after creating the wl_data_offer object. One ++ event per offered mime type. ++ </description> ++ ++ <arg name="mime_type" type="string"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_data_source" version="1"> ++ <description summary="offer to transfer data"> ++ The wl_data_source object is the source side of a wl_data_offer. ++ It is created by the source client in a data transfer and ++ provides a way to describe the offered data and a way to respond ++ to requests to transfer the data. ++ </description> ++ ++ <request name="offer"> ++ <description summary="add an offered mime type"> ++ This request adds a mime type to the set of mime types ++ advertised to targets. Can be called several times to offer ++ multiple types. ++ </description> ++ <arg name="mime_type" type="string"/> ++ </request> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="destroy the data source"> ++ Destroy the data source. ++ </description> ++ </request> ++ ++ <event name="target"> ++ <description summary="a target accepts an offered mime type"> ++ Sent when a target accepts pointer_focus or motion events. If ++ a target does not accept any of the offered types, type is NULL. ++ ++ Used for feedback during drag-and-drop. ++ </description> ++ ++ <arg name="mime_type" type="string" allow-null="true"/> ++ </event> ++ ++ <event name="send"> ++ <description summary="send the data"> ++ Request for data from the client. Send the data as the ++ specified mime type over the passed file descriptor, then ++ close it. ++ </description> ++ ++ <arg name="mime_type" type="string"/> ++ <arg name="fd" type="fd"/> ++ </event> ++ ++ <event name="cancelled"> ++ <description summary="selection was cancelled"> ++ This data source has been replaced by another data source. ++ The client should clean up and destroy this data source. ++ </description> ++ </event> ++ ++ </interface> ++ ++ <interface name="wl_data_device" version="1"> ++ <description summary="data transfer device"> ++ There is one wl_data_device per seat which can be obtained ++ from the global wl_data_device_manager singleton. ++ ++ A wl_data_device provides access to inter-client data transfer ++ mechanisms such as copy-and-paste and drag-and-drop. ++ </description> ++ <request name="start_drag"> ++ <description summary="start drag-and-drop operation"> ++ This request asks the compositor to start a drag-and-drop ++ operation on behalf of the client. ++ ++ The source argument is the data source that provides the data ++ for the eventual data transfer. If source is NULL, enter, leave ++ and motion events are sent only to the client that initiated the ++ drag and the client is expected to handle the data passing ++ internally. ++ ++ The origin surface is the surface where the drag originates and ++ the client must have an active implicit grab that matches the ++ serial. ++ ++ The icon surface is an optional (can be NULL) surface that ++ provides an icon to be moved around with the cursor. Initially, ++ the top-left corner of the icon surface is placed at the cursor ++ hotspot, but subsequent wl_surface.attach request can move the ++ relative position. Attach requests must be confirmed with ++ wl_surface.commit as usual. ++ ++ The current and pending input regions of the icon wl_surface are ++ cleared, and wl_surface.set_input_region is ignored until the ++ wl_surface is no longer used as the icon surface. When the use ++ as an icon ends, the current and pending input regions become ++ undefined, and the wl_surface is unmapped. ++ </description> ++ <arg name="source" type="object" interface="wl_data_source" allow-null="true"/> ++ <arg name="origin" type="object" interface="wl_surface"/> ++ <arg name="icon" type="object" interface="wl_surface" allow-null="true"/> ++ <arg name="serial" type="uint" summary="serial of the implicit grab on the origin"/> ++ </request> ++ ++ <request name="set_selection"> ++ <description summary="copy data to the selection"> ++ This request asks the compositor to set the selection ++ to the data from the source on behalf of the client. ++ ++ To unset the selection, set the source to NULL. ++ </description> ++ <arg name="source" type="object" interface="wl_data_source" allow-null="true"/> ++ <arg name="serial" type="uint" summary="serial of the event that triggered this request"/> ++ </request> ++ ++ <event name="data_offer"> ++ <description summary="introduce a new wl_data_offer"> ++ The data_offer event introduces a new wl_data_offer object, ++ which will subsequently be used in either the ++ data_device.enter event (for drag-and-drop) or the ++ data_device.selection event (for selections). Immediately ++ following the data_device_data_offer event, the new data_offer ++ object will send out data_offer.offer events to describe the ++ mime types it offers. ++ </description> ++ ++ <arg name="id" type="new_id" interface="wl_data_offer"/> ++ </event> ++ ++ <event name="enter"> ++ <description summary="initiate drag-and-drop session"> ++ This event is sent when an active drag-and-drop pointer enters ++ a surface owned by the client. The position of the pointer at ++ enter time is provided by the x and y arguments, in surface ++ local coordinates. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ <arg name="x" type="fixed"/> ++ <arg name="y" type="fixed"/> ++ <arg name="id" type="object" interface="wl_data_offer" allow-null="true"/> ++ </event> ++ ++ <event name="leave"> ++ <description summary="end drag-and-drop session"> ++ This event is sent when the drag-and-drop pointer leaves the ++ surface and the session ends. The client must destroy the ++ wl_data_offer introduced at enter time at this point. ++ </description> ++ </event> ++ ++ <event name="motion"> ++ <description summary="drag-and-drop session motion"> ++ This event is sent when the drag-and-drop pointer moves within ++ the currently focused surface. The new position of the pointer ++ is provided by the x and y arguments, in surface local ++ coordinates. ++ </description> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="x" type="fixed"/> ++ <arg name="y" type="fixed"/> ++ </event> ++ ++ <event name="drop"> ++ <description summary="end drag-and-drag session successfully"> ++ The event is sent when a drag-and-drop operation is ended ++ because the implicit grab is removed. ++ </description> ++ </event> ++ ++ <event name="selection"> ++ <description summary="advertise new selection"> ++ The selection event is sent out to notify the client of a new ++ wl_data_offer for the selection for this device. The ++ data_device.data_offer and the data_offer.offer events are ++ sent out immediately before this event to introduce the data ++ offer object. The selection event is sent to a client ++ immediately before receiving keyboard focus and when a new ++ selection is set while the client has keyboard focus. The ++ data_offer is valid until a new data_offer or NULL is received ++ or until the client loses keyboard focus. ++ </description> ++ <arg name="id" type="object" interface="wl_data_offer" allow-null="true"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_data_device_manager" version="1"> ++ <description summary="data transfer interface"> ++ The wl_data_device_manager is a singleton global object that ++ provides access to inter-client data transfer mechanisms such as ++ copy-and-paste and drag-and-drop. These mechanisms are tied to ++ a wl_seat and this interface lets a client get a wl_data_device ++ corresponding to a wl_seat. ++ </description> ++ ++ <request name="create_data_source"> ++ <description summary="create a new data source"> ++ Create a new data source. ++ </description> ++ <arg name="id" type="new_id" interface="wl_data_source"/> ++ </request> ++ ++ <request name="get_data_device"> ++ <description summary="create a new data device"> ++ Create a new data device for a given seat. ++ </description> ++ <arg name="id" type="new_id" interface="wl_data_device"/> ++ <arg name="seat" type="object" interface="wl_seat"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_shell" version="1"> ++ <description summary="create desktop-style surfaces"> ++ This interface is implemented by servers that provide ++ desktop-style user interfaces. ++ ++ It allows clients to associate a wl_shell_surface with ++ a basic surface. ++ </description> ++ ++ <request name="get_shell_surface"> ++ <description summary="create a shell surface from a surface"> ++ Create a shell surface for an existing surface. ++ ++ Only one shell surface can be associated with a given surface. ++ </description> ++ <arg name="id" type="new_id" interface="wl_shell_surface"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_shell_surface" version="1"> ++ ++ <description summary="desktop-style metadata interface"> ++ 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 toplevel, fullscreen ++ or popup windows, move, resize or maximize them, associate ++ metadata like title and class, etc. ++ ++ On the server side the object is automatically destroyed when ++ the related wl_surface is destroyed. On client side, ++ wl_shell_surface_destroy() must be called before destroying ++ the wl_surface object. ++ </description> ++ ++ <request name="pong"> ++ <description summary="respond to a ping event"> ++ A client must respond to a ping event with a pong request or ++ the client may be deemed unresponsive. ++ </description> ++ <arg name="serial" type="uint" summary="serial of the ping event"/> ++ </request> ++ ++ <request name="move"> ++ <description summary="start an interactive move"> ++ Start a pointer-driven move of the surface. ++ ++ This request must be used in response to a button press event. ++ The server may ignore move requests depending on the state of ++ the surface (e.g. fullscreen or maximized). ++ </description> ++ <arg name="seat" type="object" interface="wl_seat" summary="the wl_seat whose pointer is used"/> ++ <arg name="serial" type="uint" summary="serial of the implicit grab on the pointer"/> ++ </request> ++ ++ <enum name="resize"> ++ <description summary="edge values for resizing"> ++ 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. ++ </description> ++ <entry name="none" value="0"/> ++ <entry name="top" value="1"/> ++ <entry name="bottom" value="2"/> ++ <entry name="left" value="4"/> ++ <entry name="top_left" value="5"/> ++ <entry name="bottom_left" value="6"/> ++ <entry name="right" value="8"/> ++ <entry name="top_right" value="9"/> ++ <entry name="bottom_right" value="10"/> ++ </enum> ++ ++ <request name="resize"> ++ <description summary="start an interactive resize"> ++ Start a pointer-driven resizing of the surface. ++ ++ This request must be used in response to a button press event. ++ The server may ignore resize requests depending on the state of ++ the surface (e.g. fullscreen or maximized). ++ </description> ++ <arg name="seat" type="object" interface="wl_seat" summary="the wl_seat whose pointer is used"/> ++ <arg name="serial" type="uint" summary="serial of the implicit grab on the pointer"/> ++ <arg name="edges" type="uint" summary="which edge or corner is being dragged"/> ++ </request> ++ ++ <request name="set_toplevel"> ++ <description summary="make the surface a toplevel surface"> ++ Map the surface as a toplevel surface. ++ ++ A toplevel surface is not fullscreen, maximized or transient. ++ </description> ++ </request> ++ ++ <enum name="transient"> ++ <description summary="details of transient behaviour"> ++ These flags specify details of the expected behaviour ++ of transient surfaces. Used in the set_transient request. ++ </description> ++ <entry name="inactive" value="0x1" summary="do not set keyboard focus"/> ++ </enum> ++ ++ <request name="set_transient"> ++ <description summary="make the surface a transient surface"> ++ Map the surface relative to an existing surface. ++ ++ 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. ++ ++ The flags argument controls details of the transient behaviour. ++ </description> ++ ++ <arg name="parent" type="object" interface="wl_surface"/> ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ <arg name="flags" type="uint"/> ++ </request> ++ ++ <enum name="fullscreen_method"> ++ <description summary="different method to set the surface fullscreen"> ++ Hints to indicate to the compositor how to deal with a conflict ++ between the dimensions of the surface and the dimensions of the ++ output. The compositor is free to ignore this parameter. ++ </description> ++ <entry name="default" value="0" summary="no preference, apply default policy"/> ++ <entry name="scale" value="1" summary="scale, preserve the surface's aspect ratio and center on output"/> ++ <entry name="driver" value="2" summary="switch output mode to the smallest mode that can fit the surface, add black borders to compensate size mismatch"/> ++ <entry name="fill" value="3" summary="no upscaling, center on output and add black borders to compensate size mismatch"/> ++ </enum> ++ ++ <request name="set_fullscreen"> ++ <description summary="make the surface a fullscreen surface"> ++ Map the surface as a fullscreen surface. ++ ++ If an output parameter is given then the surface will be made ++ fullscreen on that output. If the client does not specify the ++ output then the compositor will apply its policy - usually ++ choosing the output on which the surface has the biggest surface ++ area. ++ ++ The client may specify a method to resolve a size conflict ++ between the output size and the surface size - this is provided ++ through the method parameter. ++ ++ The framerate parameter is used only when the method is set ++ to "driver", to indicate the preferred framerate. A value of 0 ++ indicates that the app does not care about framerate. The ++ framerate is specified in mHz, that is framerate of 60000 is 60Hz. ++ ++ A method of "scale" or "driver" implies a scaling operation of ++ the surface, either via a direct scaling operation or a change of ++ the output mode. This will override any kind of output scaling, so ++ that mapping a surface with a buffer size equal to the mode can ++ fill the screen independent of buffer_scale. ++ ++ A method of "fill" means we don't scale up the buffer, however ++ any output scale is applied. This means that you may run into ++ an edge case where the application maps a buffer with the same ++ size of the output mode but buffer_scale 1 (thus making a ++ surface larger than the output). In this case it is allowed to ++ downscale the results to fit the screen. ++ ++ The compositor must reply to this request with a configure event ++ with the dimensions for the output on which the surface will ++ be made fullscreen. ++ </description> ++ <arg name="method" type="uint"/> ++ <arg name="framerate" type="uint"/> ++ <arg name="output" type="object" interface="wl_output" allow-null="true"/> ++ </request> ++ ++ <request name="set_popup"> ++ <description summary="make the surface a popup surface"> ++ Map the surface as a popup. ++ ++ 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. ++ </description> ++ ++ <arg name="seat" type="object" interface="wl_seat" summary="the wl_seat whose pointer is used"/> ++ <arg name="serial" type="uint" summary="serial of the implicit grab on the pointer"/> ++ <arg name="parent" type="object" interface="wl_surface"/> ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ <arg name="flags" type="uint"/> ++ </request> ++ ++ <request name="set_maximized"> ++ <description summary="make the surface a maximized surface"> ++ Map the surface as a maximized surface. ++ ++ If an output parameter is given then the surface will be ++ maximized on that output. If the client does not specify the ++ output then the compositor will apply its policy - usually ++ choosing the output on which the surface has the biggest surface ++ area. ++ ++ The compositor will reply with a configure event telling ++ the expected new surface size. The operation is completed ++ on the next buffer attach to this surface. ++ ++ A maximized surface typically fills the entire output it is ++ bound to, except for desktop element such as panels. This is ++ the main difference between a maximized shell surface and a ++ fullscreen shell surface. ++ ++ The details depend on the compositor implementation. ++ </description> ++ <arg name="output" type="object" interface="wl_output" allow-null="true"/> ++ </request> ++ ++ <request name="set_title"> ++ <description summary="set surface title"> ++ Set a short title for the surface. ++ ++ This string may be used to identify the surface in a task bar, ++ window list, or other user interface elements provided by the ++ compositor. ++ ++ The string must be encoded in UTF-8. ++ </description> ++ <arg name="title" type="string"/> ++ </request> ++ ++ <request name="set_class"> ++ <description summary="set surface class"> ++ Set a class for the surface. ++ ++ The surface class identifies the general class of applications ++ to which the surface belongs. A common convention is to use the ++ file name (or the full path if it is a non-standard location) of ++ the application's .desktop file as the class. ++ </description> ++ <arg name="class_" type="string"/> ++ </request> ++ ++ <event name="ping"> ++ <description summary="ping client"> ++ Ping a client to check if it is receiving events and sending ++ requests. A client is expected to reply with a pong request. ++ </description> ++ <arg name="serial" type="uint"/> ++ </event> ++ ++ <event name="configure"> ++ <description summary="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 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). ++ ++ 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. ++ </description> ++ ++ <arg name="edges" type="uint"/> ++ <arg name="width" type="int"/> ++ <arg name="height" type="int"/> ++ </event> ++ ++ <event name="popup_done"> ++ <description summary="popup interaction is done"> ++ The popup_done event is sent out when a popup grab is broken, ++ that is, when the user clicks a surface that doesn't belong ++ to the client owning the popup surface. ++ </description> ++ </event> ++ </interface> ++ ++ <interface name="wl_surface" version="3"> ++ <description summary="an onscreen surface"> ++ A surface is a rectangular area that is displayed on the screen. ++ It has a location, size and pixel contents. ++ ++ The size of a surface (and relative positions on it) is described ++ in surface local coordinates, which may differ from the buffer ++ local coordinates of the pixel content, in case a buffer_transform ++ or a buffer_scale is used. ++ ++ Surfaces are also used for some special purposes, e.g. as ++ cursor images for pointers, drag icons, etc. ++ </description> ++ ++ <enum name="error"> ++ <description summary="wl_surface error values"> ++ These errors can be emitted in response to wl_surface requests. ++ </description> ++ <entry name="invalid_scale" value="0" summary="buffer scale value is invalid"/> ++ <entry name="invalid_transform" value="1" summary="buffer transform value is invalid"/> ++ </enum> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="delete surface"> ++ Deletes the surface and invalidates its object ID. ++ </description> ++ </request> ++ ++ <request name="attach"> ++ <description summary="set the surface contents"> ++ Set a buffer as the content of this surface. ++ ++ The new size of the surface is calculated based on the buffer ++ size transformed by the inverse buffer_transform and the ++ inverse buffer_scale. This means that the supplied buffer ++ must be an integer multiple of the buffer_scale. ++ ++ The x and y arguments specify the location of the new pending ++ buffer's upper left corner, relative to the current buffer's upper ++ left corner, in surface local coordinates. In other words, the ++ x and y, combined with the new surface size define in which ++ directions the surface's size changes. ++ ++ Surface contents are double-buffered state, see wl_surface.commit. ++ ++ The initial surface contents are void; there is no content. ++ wl_surface.attach assigns the given wl_buffer as the pending ++ wl_buffer. wl_surface.commit makes the pending wl_buffer the new ++ surface contents, and the size of the surface becomes the size ++ calculated from the wl_buffer, as described above. After commit, ++ there is no pending buffer until the next attach. ++ ++ Committing a pending wl_buffer allows the compositor to read the ++ pixels in the wl_buffer. The compositor may access the pixels at ++ any time after the wl_surface.commit request. When the compositor ++ will not access the pixels anymore, it will send the ++ wl_buffer.release event. Only after receiving wl_buffer.release, ++ the client may re-use the wl_buffer. A wl_buffer that has been ++ attached and then replaced by another attach instead of committed ++ will not receive a release event, and is not used by the ++ compositor. ++ ++ Destroying the wl_buffer after wl_buffer.release does not change ++ the surface contents. However, if the client destroys the ++ wl_buffer before receiving the wl_buffer.release event, the surface ++ contents become undefined immediately. ++ ++ If wl_surface.attach is sent with a NULL wl_buffer, the ++ following wl_surface.commit will remove the surface content. ++ </description> ++ ++ <arg name="buffer" type="object" interface="wl_buffer" allow-null="true"/> ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ </request> ++ ++ <request name="damage"> ++ <description summary="mark part of the surface damaged"> ++ This request is used to describe the regions where the pending ++ buffer is different from the current surface contents, and where ++ the surface therefore needs to be repainted. The pending buffer ++ must be set by wl_surface.attach before sending damage. The ++ compositor ignores the parts of the damage that fall outside of ++ the surface. ++ ++ Damage is double-buffered state, see wl_surface.commit. ++ ++ The damage rectangle is specified in surface local coordinates. ++ ++ The initial value for pending damage is empty: no damage. ++ wl_surface.damage adds pending damage: the new pending damage ++ is the union of old pending damage and the given rectangle. ++ ++ wl_surface.commit assigns pending damage as the current damage, ++ and clears pending damage. The server will clear the current ++ damage as it repaints the surface. ++ </description> ++ ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ <arg name="width" type="int"/> ++ <arg name="height" type="int"/> ++ </request> ++ ++ <request name="frame"> ++ <description summary="request a frame throttling hint"> ++ Request a notification when it is a good time start drawing a new ++ frame, by creating a frame callback. This is useful for throttling ++ redrawing operations, and driving animations. ++ ++ When a client is animating on a wl_surface, it can use the 'frame' ++ request to get notified when it is a good time to draw and commit the ++ next frame of animation. If the client commits an update earlier than ++ that, it is likely that some updates will not make it to the display, ++ and the client is wasting resources by drawing too often. ++ ++ The frame request will take effect on the next wl_surface.commit. ++ The notification will only be posted for one frame unless ++ requested again. For a wl_surface, the notifications are posted in ++ the order the frame requests were committed. ++ ++ The server must send the notifications so that a client ++ will not send excessive updates, while still allowing ++ the highest possible update rate for clients that wait for the reply ++ before drawing again. The server should give some time for the client ++ to draw and commit after sending the frame callback events to let them ++ hit the next output refresh. ++ ++ A server should avoid signalling the frame callbacks if the ++ surface is not visible in any way, e.g. the surface is off-screen, ++ or completely obscured by other opaque surfaces. ++ ++ The object returned by this request will be destroyed by the ++ compositor after the callback is fired and as such the client must not ++ attempt to use it after that point. ++ ++ The callback_data passed in the callback is the current time, in ++ milliseconds, with an undefined base. ++ </description> ++ ++ <arg name="callback" type="new_id" interface="wl_callback"/> ++ </request> ++ ++ <request name="set_opaque_region"> ++ <description summary="set opaque region"> ++ This request sets the region of the surface that contains ++ opaque content. ++ ++ The opaque region is an optimization hint for the compositor ++ that lets it optimize out redrawing of content behind opaque ++ regions. Setting an opaque region is not required for correct ++ behaviour, but marking transparent content as opaque will result ++ in repaint artifacts. ++ ++ The opaque region is specified in surface local coordinates. ++ ++ The compositor ignores the parts of the opaque region that fall ++ outside of the surface. ++ ++ Opaque region is double-buffered state, see wl_surface.commit. ++ ++ wl_surface.set_opaque_region changes the pending opaque region. ++ wl_surface.commit copies the pending region to the current region. ++ Otherwise, the pending and current regions are never changed. ++ ++ The initial value for opaque region is empty. Setting the pending ++ opaque region has copy semantics, and the wl_region object can be ++ destroyed immediately. A NULL wl_region causes the pending opaque ++ region to be set to empty. ++ </description> ++ ++ <arg name="region" type="object" interface="wl_region" allow-null="true"/> ++ </request> ++ ++ <request name="set_input_region"> ++ <description summary="set input region"> ++ This request sets the region of the surface that can receive ++ pointer and touch events. ++ ++ Input events happening outside of this region will try the next ++ surface in the server surface stack. The compositor ignores the ++ parts of the input region that fall outside of the surface. ++ ++ The input region is specified in surface local coordinates. ++ ++ Input region is double-buffered state, see wl_surface.commit. ++ ++ wl_surface.set_input_region changes the pending input region. ++ wl_surface.commit copies the pending region to the current region. ++ Otherwise the pending and current regions are never changed, ++ except cursor and icon surfaces are special cases, see ++ wl_pointer.set_cursor and wl_data_device.start_drag. ++ ++ The initial value for input region is infinite. That means the ++ whole surface will accept input. Setting the pending input region ++ has copy semantics, and the wl_region object can be destroyed ++ immediately. A NULL wl_region causes the input region to be set ++ to infinite. ++ </description> ++ ++ <arg name="region" type="object" interface="wl_region" allow-null="true"/> ++ </request> ++ ++ <request name="commit"> ++ <description summary="commit pending surface state"> ++ Surface state (input, opaque, and damage regions, attached buffers, ++ etc.) is double-buffered. Protocol requests modify the pending ++ state, as opposed to current state in use by the compositor. Commit ++ request atomically applies all pending state, replacing the current ++ state. After commit, the new pending state is as documented for each ++ related request. ++ ++ On commit, a pending wl_buffer is applied first, all other state ++ second. This means that all coordinates in double-buffered state are ++ relative to the new wl_buffer coming into use, except for ++ wl_surface.attach itself. If there is no pending wl_buffer, the ++ coordinates are relative to the current surface contents. ++ ++ All requests that need a commit to become effective are documented ++ to affect double-buffered state. ++ ++ Other interfaces may add further double-buffered surface state. ++ </description> ++ </request> ++ ++ <event name="enter"> ++ <description summary="surface enters an output"> ++ This is emitted whenever a surface's creation, movement, or resizing ++ results in some part of it being within the scanout region of an ++ output. ++ ++ Note that a surface may be overlapping with zero or more outputs. ++ </description> ++ <arg name="output" type="object" interface="wl_output"/> ++ </event> ++ ++ <event name="leave"> ++ <description summary="surface leaves an output"> ++ This is emitted whenever a surface's creation, movement, or resizing ++ results in it no longer having any part of it within the scanout region ++ of an output. ++ </description> ++ <arg name="output" type="object" interface="wl_output"/> ++ </event> ++ ++ <!-- Version 2 additions --> ++ ++ <request name="set_buffer_transform" since="2"> ++ <description summary="sets the buffer transformation"> ++ This request sets an optional transformation on how the compositor ++ interprets the contents of the buffer attached to the surface. The ++ accepted values for the transform parameter are the values for ++ wl_output.transform. ++ ++ Buffer transform is double-buffered state, see wl_surface.commit. ++ ++ A newly created surface has its buffer transformation set to normal. ++ ++ wl_surface.set_buffer_transform changes the pending buffer ++ transformation. wl_surface.commit copies the pending buffer ++ transformation to the current one. Otherwise, the pending and current ++ values are never changed. ++ ++ The purpose of this request is to allow clients to render content ++ according to the output transform, thus permiting the compositor to ++ use certain optimizations even if the display is rotated. Using ++ hardware overlays and scanning out a client buffer for fullscreen ++ surfaces are examples of such optimizations. Those optimizations are ++ highly dependent on the compositor implementation, so the use of this ++ request should be considered on a case-by-case basis. ++ ++ Note that if the transform value includes 90 or 270 degree rotation, ++ the width of the buffer will become the surface height and the height ++ of the buffer will become the surface width. ++ ++ If transform is not one of the values from the ++ wl_output.transform enum the invalid_transform protocol error ++ is raised. ++ </description> ++ <arg name="transform" type="int"/> ++ </request> ++ ++ <!-- Version 3 additions --> ++ ++ <request name="set_buffer_scale" since="3"> ++ <description summary="sets the buffer scaling factor"> ++ This request sets an optional scaling factor on how the compositor ++ interprets the contents of the buffer attached to the window. ++ ++ Buffer scale is double-buffered state, see wl_surface.commit. ++ ++ A newly created surface has its buffer scale set to 1. ++ ++ wl_surface.set_buffer_scale changes the pending buffer scale. ++ wl_surface.commit copies the pending buffer scale to the current one. ++ Otherwise, the pending and current values are never changed. ++ ++ The purpose of this request is to allow clients to supply higher ++ resolution buffer data for use on high resolution outputs. Its ++ intended that you pick the same buffer scale as the scale of the ++ output that the surface is displayed on.This means the compositor ++ can avoid scaling when rendering the surface on that output. ++ ++ Note that if the scale is larger than 1, then you have to attach ++ a buffer that is larger (by a factor of scale in each dimension) ++ than the desired surface size. ++ ++ If scale is not positive the invalid_scale protocol error is ++ raised. ++ </description> ++ <arg name="scale" type="int"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_seat" version="4"> ++ <description summary="group of input devices"> ++ A seat is a group of keyboards, pointer and touch devices. This ++ object is published as a global during start up, or when such a ++ device is hot plugged. A seat typically has a pointer and ++ maintains a keyboard focus and a pointer focus. ++ </description> ++ ++ <enum name="capability"> ++ <description summary="seat capability bitmask"> ++ This is a bitmask of capabilities this seat has; if a member is ++ set, then it is present on the seat. ++ </description> ++ <entry name="pointer" value="1" summary="The seat has pointer devices"/> ++ <entry name="keyboard" value="2" summary="The seat has one or more keyboards"/> ++ <entry name="touch" value="4" summary="The seat has touch devices"/> ++ </enum> ++ ++ <event name="capabilities"> ++ <description summary="seat capabilities changed"> ++ This is emitted whenever a seat gains or loses the pointer, ++ keyboard or touch capabilities. The argument is a capability ++ enum containing the complete set of capabilities this seat has. ++ </description> ++ <arg name="capabilities" type="uint"/> ++ </event> ++ ++ <request name="get_pointer"> ++ <description summary="return pointer object"> ++ The ID provided will be initialized to the wl_pointer interface ++ for this seat. ++ ++ This request only takes effect if the seat has the pointer ++ capability. ++ </description> ++ <arg name="id" type="new_id" interface="wl_pointer"/> ++ </request> ++ ++ <request name="get_keyboard"> ++ <description summary="return keyboard object"> ++ The ID provided will be initialized to the wl_keyboard interface ++ for this seat. ++ ++ This request only takes effect if the seat has the keyboard ++ capability. ++ </description> ++ <arg name="id" type="new_id" interface="wl_keyboard"/> ++ </request> ++ ++ <request name="get_touch"> ++ <description summary="return touch object"> ++ The ID provided will be initialized to the wl_touch interface ++ for this seat. ++ ++ This request only takes effect if the seat has the touch ++ capability. ++ </description> ++ <arg name="id" type="new_id" interface="wl_touch"/> ++ </request> ++ ++ <!-- Version 2 of additions --> ++ ++ <event name="name" since="2"> ++ <description summary="unique identifier for this seat"> ++ In a multiseat configuration this can be used by the client to help ++ identify which physical devices the seat represents. Based on ++ the seat configuration used by the compositor. ++ </description> ++ <arg name="name" type="string"/> ++ </event> ++ ++ </interface> ++ ++ <interface name="wl_pointer" version="3"> ++ <description summary="pointer input device"> ++ The wl_pointer interface represents one or more input devices, ++ such as mice, which control the pointer location and pointer_focus ++ of a seat. ++ ++ The wl_pointer interface generates motion, enter and leave ++ events for the surfaces that the pointer is located over, ++ and button and axis events for button presses, button releases ++ and scrolling. ++ </description> ++ ++ <request name="set_cursor"> ++ <description summary="set the pointer surface"> ++ Set the pointer surface, i.e., the surface that contains the ++ pointer image (cursor). This request only takes effect if the pointer ++ focus for this device is one of the requesting client's surfaces ++ or the surface parameter is the current pointer surface. If ++ there was a previous surface set with this request it is ++ replaced. If surface is NULL, the pointer image is hidden. ++ ++ The parameters hotspot_x and hotspot_y define the position of ++ the pointer surface relative to the pointer location. Its ++ top-left corner is always at (x, y) - (hotspot_x, hotspot_y), ++ where (x, y) are the coordinates of the pointer location, in surface ++ local coordinates. ++ ++ On surface.attach requests to the pointer surface, hotspot_x ++ and hotspot_y are decremented by the x and y parameters ++ passed to the request. Attach must be confirmed by ++ wl_surface.commit as usual. ++ ++ The hotspot can also be updated by passing the currently set ++ pointer surface to this request with new values for hotspot_x ++ and hotspot_y. ++ ++ The current and pending input regions of the wl_surface are ++ cleared, and wl_surface.set_input_region is ignored until the ++ wl_surface is no longer used as the cursor. When the use as a ++ cursor ends, the current and pending input regions become ++ undefined, and the wl_surface is unmapped. ++ </description> ++ ++ <arg name="serial" type="uint" summary="serial of the enter event"/> ++ <arg name="surface" type="object" interface="wl_surface" allow-null="true"/> ++ <arg name="hotspot_x" type="int" summary="x coordinate in surface-relative coordinates"/> ++ <arg name="hotspot_y" type="int" summary="y coordinate in surface-relative coordinates"/> ++ </request> ++ ++ <event name="enter"> ++ <description summary="enter event"> ++ Notification that this seat's pointer is focused on a certain ++ surface. ++ ++ When an seat's focus enters a surface, the pointer image ++ is undefined and a client should respond to this event by setting ++ an appropriate pointer image with the set_cursor request. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ <arg name="surface_x" type="fixed" summary="x coordinate in surface-relative coordinates"/> ++ <arg name="surface_y" type="fixed" summary="y coordinate in surface-relative coordinates"/> ++ </event> ++ ++ <event name="leave"> ++ <description summary="leave event"> ++ Notification that this seat's pointer is no longer focused on ++ a certain surface. ++ ++ The leave notification is sent before the enter notification ++ for the new focus. ++ </description> ++ <arg name="serial" type="uint"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ </event> ++ ++ <event name="motion"> ++ <description summary="pointer motion event"> ++ Notification of pointer location change. The arguments ++ surface_x and surface_y are the location relative to the ++ focused surface. ++ </description> ++ ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="surface_x" type="fixed" summary="x coordinate in surface-relative coordinates"/> ++ <arg name="surface_y" type="fixed" summary="y coordinate in surface-relative coordinates"/> ++ </event> ++ ++ <enum name="button_state"> ++ <description summary="physical button state"> ++ Describes the physical state of a button which provoked the button ++ event. ++ </description> ++ <entry name="released" value="0" summary="The button is not pressed"/> ++ <entry name="pressed" value="1" summary="The button is pressed"/> ++ </enum> ++ ++ <event name="button"> ++ <description summary="pointer button event"> ++ Mouse button click and release notifications. ++ ++ The location of the click is given by the last motion or ++ enter event. ++ The time argument is a timestamp with millisecond ++ granularity, with an undefined base. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="button" type="uint"/> ++ <arg name="state" type="uint"/> ++ </event> ++ ++ <enum name="axis"> ++ <description summary="axis types"> ++ Describes the axis types of scroll events. ++ </description> ++ <entry name="vertical_scroll" value="0"/> ++ <entry name="horizontal_scroll" value="1"/> ++ </enum> ++ ++ <event name="axis"> ++ <description summary="axis event"> ++ Scroll and other axis notifications. ++ ++ For scroll events (vertical and horizontal scroll axes), the ++ value parameter is the length of a vector along the specified ++ axis in a coordinate space identical to those of motion events, ++ representing a relative movement along the specified axis. ++ ++ For devices that support movements non-parallel to axes multiple ++ axis events will be emitted. ++ ++ When applicable, for example for touch pads, the server can ++ choose to emit scroll events where the motion vector is ++ equivalent to a motion event vector. ++ ++ When applicable, clients can transform its view relative to the ++ scroll distance. ++ </description> ++ ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="axis" type="uint"/> ++ <arg name="value" type="fixed"/> ++ </event> ++ ++ <!-- Version 3 additions --> ++ ++ <request name="release" type="destructor" since="3"> ++ <description summary="release the pointer object"/> ++ </request> ++ ++ </interface> ++ ++ <interface name="wl_keyboard" version="4"> ++ <description summary="keyboard input device"> ++ The wl_keyboard interface represents one or more keyboards ++ associated with a seat. ++ </description> ++ ++ <enum name="keymap_format"> ++ <description summary="keyboard mapping format"> ++ This specifies the format of the keymap provided to the ++ client with the wl_keyboard.keymap event. ++ </description> ++ <entry name="no_keymap" value="0" ++ summary="no keymap; client must understand how to interpret the raw keycode"/> ++ <entry name="xkb_v1" value="1" ++ summary="libxkbcommon compatible; to determine the xkb keycode, clients must add 8 to the key event keycode"/> ++ </enum> ++ ++ <event name="keymap"> ++ <description summary="keyboard mapping"> ++ This event provides a file descriptor to the client which can be ++ memory-mapped to provide a keyboard mapping description. ++ </description> ++ <arg name="format" type="uint"/> ++ <arg name="fd" type="fd"/> ++ <arg name="size" type="uint"/> ++ </event> ++ ++ <event name="enter"> ++ <description summary="enter event"> ++ Notification that this seat's keyboard focus is on a certain ++ surface. ++ </description> ++ <arg name="serial" type="uint"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ <arg name="keys" type="array" summary="the currently pressed keys"/> ++ </event> ++ ++ <event name="leave"> ++ <description summary="leave event"> ++ Notification that this seat's keyboard focus is no longer on ++ a certain surface. ++ ++ The leave notification is sent before the enter notification ++ for the new focus. ++ </description> ++ <arg name="serial" type="uint"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ </event> ++ ++ <enum name="key_state"> ++ <description summary="physical key state"> ++ Describes the physical state of a key which provoked the key event. ++ </description> ++ <entry name="released" value="0" summary="key is not pressed"/> ++ <entry name="pressed" value="1" summary="key is pressed"/> ++ </enum> ++ ++ <event name="key"> ++ <description summary="key event"> ++ A key was pressed or released. ++ The time argument is a timestamp with millisecond ++ granularity, with an undefined base. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="key" type="uint"/> ++ <arg name="state" type="uint"/> ++ </event> ++ ++ <event name="modifiers"> ++ <description summary="modifier and group state"> ++ Notifies clients that the modifier and/or group state has ++ changed, and it should update its local state. ++ </description> ++ ++ <arg name="serial" type="uint"/> ++ <arg name="mods_depressed" type="uint"/> ++ <arg name="mods_latched" type="uint"/> ++ <arg name="mods_locked" type="uint"/> ++ <arg name="group" type="uint"/> ++ </event> ++ ++ <!-- Version 3 additions --> ++ ++ <request name="release" type="destructor" since="3"> ++ <description summary="release the keyboard object"/> ++ </request> ++ ++ <!-- Version 4 additions --> ++ ++ <event name="repeat_info" since="4"> ++ <description summary="repeat rate and delay"> ++ Informs the client about the keyboard's repeat rate and delay. ++ ++ This event is sent as soon as the wl_keyboard object has been created, ++ and is guaranteed to be received by the client before any key press ++ event. ++ ++ Negative values for either rate or delay are illegal. A rate of zero ++ will disable any repeating (regardless of the value of delay). ++ ++ This event can be sent later on as well with a new value if necessary, ++ so clients should continue listening for the event past the creation ++ of wl_keyboard. ++ </description> ++ ++ <arg name="rate" type="int" ++ summary="the rate of repeating keys in characters per second"/> ++ <arg name="delay" type="int" ++ summary="delay in milliseconds since key down until repeating starts"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_touch" version="3"> ++ <description summary="touchscreen input device"> ++ The wl_touch interface represents a touchscreen ++ associated with a seat. ++ ++ Touch interactions can consist of one or more contacts. ++ For each contact, a series of events is generated, starting ++ with a down event, followed by zero or more motion events, ++ and ending with an up event. Events relating to the same ++ contact point can be identified by the ID of the sequence. ++ </description> ++ ++ <event name="down"> ++ <description summary="touch down event and beginning of a touch sequence"> ++ A new touch point has appeared on the surface. This touch point is ++ assigned a unique @id. Future events from this touchpoint reference ++ this ID. The ID ceases to be valid after a touch up event and may be ++ re-used in the future. ++ </description> ++ <arg name="serial" type="uint"/> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="surface" type="object" interface="wl_surface"/> ++ <arg name="id" type="int" summary="the unique ID of this touch point"/> ++ <arg name="x" type="fixed" summary="x coordinate in surface-relative coordinates"/> ++ <arg name="y" type="fixed" summary="y coordinate in surface-relative coordinates"/> ++ </event> ++ ++ <event name="up"> ++ <description summary="end of a touch event sequence"> ++ The touch point has disappeared. No further events will be sent for ++ this touchpoint and the touch point's ID is released and may be ++ re-used in a future touch down event. ++ </description> ++ <arg name="serial" type="uint"/> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="id" type="int" summary="the unique ID of this touch point"/> ++ </event> ++ ++ <event name="motion"> ++ <description summary="update of touch point coordinates"> ++ A touchpoint has changed coordinates. ++ </description> ++ <arg name="time" type="uint" summary="timestamp with millisecond granularity"/> ++ <arg name="id" type="int" summary="the unique ID of this touch point"/> ++ <arg name="x" type="fixed" summary="x coordinate in surface-relative coordinates"/> ++ <arg name="y" type="fixed" summary="y coordinate in surface-relative coordinates"/> ++ </event> ++ ++ <event name="frame"> ++ <description summary="end of touch frame event"> ++ Indicates the end of a contact point list. ++ </description> ++ </event> ++ ++ <event name="cancel"> ++ <description summary="touch session cancelled"> ++ Sent if the compositor decides the touch stream is a global ++ gesture. No further events are sent to the clients from that ++ particular gesture. Touch cancellation applies to all touch points ++ currently active on this client's surface. The client is ++ responsible for finalizing the touch points, future touch points on ++ this surface may re-use the touch point ID. ++ </description> ++ </event> ++ ++ <!-- Version 3 additions --> ++ ++ <request name="release" type="destructor" since="3"> ++ <description summary="release the touch object"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_output" version="3"> ++ <description summary="compositor output region"> ++ An output describes part of the compositor geometry. The ++ compositor works in the 'compositor coordinate system' and an ++ output corresponds to rectangular area in that space that is ++ actually visible. This typically corresponds to a monitor that ++ displays part of the compositor space. This object is published ++ as global during start up, or when a monitor is hotplugged. ++ </description> ++ ++ <enum name="subpixel"> ++ <description summary="subpixel geometry information"> ++ This enumeration describes how the physical ++ pixels on an output are layed out. ++ </description> ++ <entry name="unknown" value="0"/> ++ <entry name="none" value="1"/> ++ <entry name="horizontal_rgb" value="2"/> ++ <entry name="horizontal_bgr" value="3"/> ++ <entry name="vertical_rgb" value="4"/> ++ <entry name="vertical_bgr" value="5"/> ++ </enum> ++ ++ <enum name="transform"> ++ <description summary="transform from framebuffer to output"> ++ This describes the transform that a compositor will apply to a ++ surface to compensate for the rotation or mirroring of an ++ output device. ++ ++ The flipped values correspond to an initial flip around a ++ vertical axis followed by rotation. ++ ++ The purpose is mainly to allow clients render accordingly and ++ tell the compositor, so that for fullscreen surfaces, the ++ compositor will still be able to scan out directly from client ++ surfaces. ++ </description> ++ ++ <entry name="normal" value="0"/> ++ <entry name="90" value="1"/> ++ <entry name="180" value="2"/> ++ <entry name="270" value="3"/> ++ <entry name="flipped" value="4"/> ++ <entry name="flipped_90" value="5"/> ++ <entry name="flipped_180" value="6"/> ++ <entry name="flipped_270" value="7"/> ++ </enum> ++ ++ <event name="geometry"> ++ <description summary="properties of the output"> ++ The geometry event describes geometric properties of the output. ++ The event is sent when binding to the output object and whenever ++ any of the properties change. ++ </description> ++ <arg name="x" type="int" ++ summary="x position within the global compositor space"/> ++ <arg name="y" type="int" ++ summary="y position within the global compositor space"/> ++ <arg name="physical_width" type="int" ++ summary="width in millimeters of the output"/> ++ <arg name="physical_height" type="int" ++ summary="height in millimeters of the output"/> ++ <arg name="subpixel" type="int" ++ summary="subpixel orientation of the output"/> ++ <arg name="make" type="string" ++ summary="textual description of the manufacturer"/> ++ <arg name="model" type="string" ++ summary="textual description of the model"/> ++ <arg name="transform" type="int" ++ summary="transform that maps framebuffer to output"/> ++ </event> ++ ++ <enum name="mode"> ++ <description summary="mode information"> ++ These flags describe properties of an output mode. ++ They are used in the flags bitfield of the mode event. ++ </description> ++ <entry name="current" value="0x1" ++ summary="indicates this is the current mode"/> ++ <entry name="preferred" value="0x2" ++ summary="indicates this is the preferred mode"/> ++ </enum> ++ ++ <event name="mode"> ++ <description summary="advertise available modes for the output"> ++ The mode event describes an available mode for the output. ++ ++ The event is sent when binding to the output object and there ++ will always be one mode, the current mode. The event is sent ++ again if an output changes mode, for the mode that is now ++ current. In other words, the current mode is always the last ++ mode that was received with the current flag set. ++ ++ The size of a mode is given in physical hardware units of ++ the output device. This is not necessarily the same as ++ the output size in the global compositor space. For instance, ++ the output may be scaled, as described in wl_output.scale, ++ or transformed , as described in wl_output.transform. ++ </description> ++ <arg name="flags" type="uint" summary="bitfield of mode flags"/> ++ <arg name="width" type="int" summary="width of the mode in hardware units"/> ++ <arg name="height" type="int" summary="height of the mode in hardware units"/> ++ <arg name="refresh" type="int" summary="vertical refresh rate in mHz"/> ++ </event> ++ ++ <event name="done" since="2"> ++ <description summary="sent all information about output"> ++ This event is sent after all other properties has been ++ sent after binding to the output object and after any ++ other property changes done after that. This allows ++ changes to the output properties to be seen as ++ atomic, even if they happen via multiple events. ++ </description> ++ </event> ++ ++ <event name="scale" since="2"> ++ <description summary="output scaling properties"> ++ This event contains scaling geometry information ++ that is not in the geometry event. It may be sent after ++ binding the output object or if the output scale changes ++ later. If it is not sent, the client should assume a ++ scale of 1. ++ ++ A scale larger than 1 means that the compositor will ++ automatically scale surface buffers by this amount ++ when rendering. This is used for very high resolution ++ displays where applications rendering at the native ++ resolution would be too small to be legible. ++ ++ It is intended that scaling aware clients track the ++ current output of a surface, and if it is on a scaled ++ output it should use wl_surface.set_buffer_scale with ++ the scale of the output. That way the compositor can ++ avoid scaling the surface, and the client can supply ++ a higher detail image. ++ </description> ++ <arg name="factor" type="int" summary="scaling factor of output"/> ++ </event> ++ ++ <!-- Version 3 of additions --> ++ ++ <event name="name" since="3"> ++ <description summary="name of the output"> ++ In a multiseat configuration this can be used by the client to help ++ identify the name of the output and consequently the name can be used to ++ select the output(s) based on the configuration. ++ </description> ++ <arg name="name" type="string"/> ++ </event> ++ ++ <event name="seatname" since="3"> ++ <description summary="name of the seat the output is constrained to"> ++ In a multiseat configuration this can be used by the client to help ++ identify the seat which the given output is constrained to and consequently ++ select the output(s) based on the client own seat. ++ </description> ++ <arg name="name" type="string"/> ++ </event> ++ </interface> ++ ++ <interface name="wl_region" version="1"> ++ <description summary="region interface"> ++ A region object describes an area. ++ ++ Region objects are used to describe the opaque and input ++ regions of a surface. ++ </description> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="destroy region"> ++ Destroy the region. This will invalidate the object ID. ++ </description> ++ </request> ++ ++ <request name="add"> ++ <description summary="add rectangle to region"> ++ Add the specified rectangle to the region. ++ </description> ++ ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ <arg name="width" type="int"/> ++ <arg name="height" type="int"/> ++ </request> ++ ++ <request name="subtract"> ++ <description summary="subtract rectangle from region"> ++ Subtract the specified rectangle from the region. ++ </description> ++ ++ <arg name="x" type="int"/> ++ <arg name="y" type="int"/> ++ <arg name="width" type="int"/> ++ <arg name="height" type="int"/> ++ </request> ++ ++ </interface> ++ ++ <interface name="wl_subcompositor" version="1"> ++ <description summary="sub-surface compositing"> ++ The global interface exposing sub-surface compositing capabilities. ++ A wl_surface, that has sub-surfaces associated, is called the ++ parent surface. Sub-surfaces can be arbitrarily nested and create ++ a tree of sub-surfaces. ++ ++ The root surface in a tree of sub-surfaces is the main ++ surface. The main surface cannot be a sub-surface, because ++ sub-surfaces must always have a parent. ++ ++ A main surface with its sub-surfaces forms a (compound) window. ++ For window management purposes, this set of wl_surface objects is ++ to be considered as a single window, and it should also behave as ++ such. ++ ++ The aim of sub-surfaces is to offload some of the compositing work ++ within a window from clients to the compositor. A prime example is ++ a video player with decorations and video in separate wl_surface ++ objects. This should allow the compositor to pass YUV video buffer ++ processing to dedicated overlay hardware when possible. ++ </description> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="unbind from the subcompositor interface"> ++ Informs the server that the client will not be using this ++ protocol object anymore. This does not affect any other ++ objects, wl_subsurface objects included. ++ </description> ++ </request> ++ ++ <enum name="error"> ++ <entry name="bad_surface" value="0" ++ summary="the to-be sub-surface is invalid"/> ++ </enum> ++ ++ <request name="get_subsurface"> ++ <description summary="give a surface the role sub-surface"> ++ Create a sub-surface interface for the given surface, and ++ associate it with the given parent surface. This turns a ++ plain wl_surface into a sub-surface. ++ ++ The to-be sub-surface must not already have a dedicated ++ purpose, like any shell surface type, cursor image, drag icon, ++ or sub-surface. Otherwise a protocol error is raised. ++ </description> ++ ++ <arg name="id" type="new_id" interface="wl_subsurface" ++ summary="the new subsurface object id"/> ++ <arg name="surface" type="object" interface="wl_surface" ++ summary="the surface to be turned into a sub-surface"/> ++ <arg name="parent" type="object" interface="wl_surface" ++ summary="the parent surface"/> ++ </request> ++ </interface> ++ ++ <interface name="wl_subsurface" version="1"> ++ <description summary="sub-surface interface to a wl_surface"> ++ An additional interface to a wl_surface object, which has been ++ made a sub-surface. A sub-surface has one parent surface. A ++ sub-surface's size and position are not limited to that of the parent. ++ Particularly, a sub-surface is not automatically clipped to its ++ parent's area. ++ ++ A sub-surface becomes mapped, when a non-NULL wl_buffer is applied ++ and the parent surface is mapped. The order of which one happens ++ first is irrelevant. A sub-surface is hidden if the parent becomes ++ hidden, or if a NULL wl_buffer is applied. These rules apply ++ recursively through the tree of surfaces. ++ ++ The behaviour of wl_surface.commit request on a sub-surface ++ depends on the sub-surface's mode. The possible modes are ++ synchronized and desynchronized, see methods ++ wl_subsurface.set_sync and wl_subsurface.set_desync. Synchronized ++ mode caches the wl_surface state to be applied when the parent's ++ state gets applied, and desynchronized mode applies the pending ++ wl_surface state directly. A sub-surface is initially in the ++ synchronized mode. ++ ++ Sub-surfaces have also other kind of state, which is managed by ++ wl_subsurface requests, as opposed to wl_surface requests. This ++ state includes the sub-surface position relative to the parent ++ surface (wl_subsurface.set_position), and the stacking order of ++ the parent and its sub-surfaces (wl_subsurface.place_above and ++ .place_below). This state is applied when the parent surface's ++ wl_surface state is applied, regardless of the sub-surface's mode. ++ As the exception, set_sync and set_desync are effective immediately. ++ ++ The main surface can be thought to be always in desynchronized mode, ++ since it does not have a parent in the sub-surfaces sense. ++ ++ Even if a sub-surface is in desynchronized mode, it will behave as ++ in synchronized mode, if its parent surface behaves as in ++ synchronized mode. This rule is applied recursively throughout the ++ tree of surfaces. This means, that one can set a sub-surface into ++ synchronized mode, and then assume that all its child and grand-child ++ sub-surfaces are synchronized, too, without explicitly setting them. ++ ++ If the wl_surface associated with the wl_subsurface is destroyed, the ++ wl_subsurface object becomes inert. Note, that destroying either object ++ takes effect immediately. If you need to synchronize the removal ++ of a sub-surface to the parent surface update, unmap the sub-surface ++ first by attaching a NULL wl_buffer, update parent, and then destroy ++ the sub-surface. ++ ++ If the parent wl_surface object is destroyed, the sub-surface is ++ unmapped. ++ </description> ++ ++ <request name="destroy" type="destructor"> ++ <description summary="remove sub-surface interface"> ++ The sub-surface interface is removed from the wl_surface object ++ that was turned into a sub-surface with ++ wl_subcompositor.get_subsurface request. The wl_surface's association ++ to the parent is deleted, and the wl_surface loses its role as ++ a sub-surface. The wl_surface is unmapped. ++ </description> ++ </request> ++ ++ <enum name="error"> ++ <entry name="bad_surface" value="0" ++ summary="wl_surface is not a sibling or the parent"/> ++ </enum> ++ ++ <request name="set_position"> ++ <description summary="reposition the sub-surface"> ++ This schedules a sub-surface position change. ++ The sub-surface will be moved so, that its origin (top-left ++ corner pixel) will be at the location x, y of the parent surface ++ coordinate system. The coordinates are not restricted to the parent ++ surface area. Negative values are allowed. ++ ++ The next wl_surface.commit on the parent surface will reset ++ the sub-surface's position to the scheduled coordinates. ++ ++ If more than one set_position request is invoked by the client before ++ the commit of the parent surface, the position of a new request always ++ replaces the scheduled position from any previous request. ++ ++ The initial position is 0, 0. ++ </description> ++ ++ <arg name="x" type="int" summary="coordinate in the parent surface"/> ++ <arg name="y" type="int" summary="coordinate in the parent surface"/> ++ </request> ++ ++ <request name="place_above"> ++ <description summary="restack the sub-surface"> ++ This sub-surface is taken from the stack, and put back just ++ above the reference surface, changing the z-order of the sub-surfaces. ++ The reference surface must be one of the sibling surfaces, or the ++ parent surface. Using any other surface, including this sub-surface, ++ will cause a protocol error. ++ ++ The z-order is double-buffered. Requests are handled in order and ++ applied immediately to a pending state, then committed to the active ++ state on the next commit of the parent surface. ++ See wl_surface.commit and wl_subcompositor.get_subsurface. ++ ++ A new sub-surface is initially added as the top-most in the stack ++ of its siblings and parent. ++ </description> ++ ++ <arg name="sibling" type="object" interface="wl_surface" ++ summary="the reference surface"/> ++ </request> ++ ++ <request name="place_below"> ++ <description summary="restack the sub-surface"> ++ The sub-surface is placed just below of the reference surface. ++ See wl_subsurface.place_above. ++ </description> ++ ++ <arg name="sibling" type="object" interface="wl_surface" ++ summary="the reference surface"/> ++ </request> ++ ++ <request name="set_sync"> ++ <description summary="set sub-surface to synchronized mode"> ++ Change the commit behaviour of the sub-surface to synchronized ++ mode, also described as the parent dependant mode. ++ ++ In synchronized mode, wl_surface.commit on a sub-surface will ++ accumulate the committed state in a cache, but the state will ++ not be applied and hence will not change the compositor output. ++ The cached state is applied to the sub-surface immediately after ++ the parent surface's state is applied. This ensures atomic ++ updates of the parent and all its synchronized sub-surfaces. ++ Applying the cached state will invalidate the cache, so further ++ parent surface commits do not (re-)apply old state. ++ ++ See wl_subsurface for the recursive effect of this mode. ++ </description> ++ </request> ++ ++ <request name="set_desync"> ++ <description summary="set sub-surface to desynchronized mode"> ++ Change the commit behaviour of the sub-surface to desynchronized ++ mode, also described as independent or freely running mode. ++ ++ In desynchronized mode, wl_surface.commit on a sub-surface will ++ apply the pending state directly, without caching, as happens ++ normally with a wl_surface. Calling wl_surface.commit on the ++ parent surface has no effect on the sub-surface's wl_surface ++ state. This mode allows a sub-surface to be updated on its own. ++ ++ If cached state exists when wl_surface.commit is called in ++ desynchronized mode, the pending state is added to the cached ++ state, and applied as whole. This invalidates the cache. ++ ++ Note: even if a sub-surface is set to desynchronized, a parent ++ sub-surface may override it to behave as synchronized. For details, ++ see wl_subsurface. ++ ++ If a surface's parent surface behaves as desynchronized, then ++ the cached state is applied on set_desync. ++ </description> ++ </request> ++ ++ </interface> ++ ++</protocol> +diff --git a/src/scanner.c b/src/scanner.c +index 72fd3e8..33f5290 100644 +--- a/src/scanner.c ++++ b/src/scanner.c +@@ -406,7 +406,7 @@ start_element(void *data, const char *element_name, const char **atts) + if (since != NULL) { + errno = 0; + version = strtol(since, &end, 0); +- if (errno == EINVAL || end == since || *end != '\0') ++ if (errno != 0 || end == since || *end != '\0') + fail(&ctx->loc, + "invalid integer (%s)\n", since); + } else { +diff --git a/src/wayland-client.c b/src/wayland-client.c +index b0f77b9..dd93b58 100644 +--- a/src/wayland-client.c ++++ b/src/wayland-client.c +@@ -700,6 +700,10 @@ connect_to_socket(const char *name) + const char *runtime_dir; + int name_size, fd; + ++#ifdef HAVE_MULTISEAT ++ runtime_dir = getenv("WAYLAND_CLIENT_DIR"); ++ if (runtime_dir == NULL) ++#endif + runtime_dir = getenv("XDG_RUNTIME_DIR"); + if (!runtime_dir) { + wl_log("error: XDG_RUNTIME_DIR not set in the environment.\n"); +@@ -723,6 +727,9 @@ connect_to_socket(const char *name) + name_size = + snprintf(addr.sun_path, sizeof addr.sun_path, + "%s/%s", runtime_dir, name) + 1; ++#ifdef HAVE_MULTISEAT ++ unsetenv("WAYLAND_CLIENT_DIR"); ++#endif + + assert(name_size > 0); + if (name_size > (int)sizeof addr.sun_path) { +@@ -829,8 +836,9 @@ wl_display_connect(const char *name) + + connection = getenv("WAYLAND_SOCKET"); + if (connection) { ++ errno = 0; + fd = strtol(connection, &end, 0); +- if (*end != '\0') ++ if (errno != 0 || connection == end || *end != '\0') + return NULL; + + flags = fcntl(fd, F_GETFD); +diff --git a/src/wayland-server.c b/src/wayland-server.c +index 674aeca..0120dad 100644 +--- a/src/wayland-server.c ++++ b/src/wayland-server.c +@@ -39,6 +39,10 @@ + #include <fcntl.h> + #include <sys/file.h> + #include <sys/stat.h> ++#ifdef HAVE_MULTISEAT ++#include <sys/types.h> ++#include <grp.h> ++#endif + #include <ffi.h> + + #include "wayland-private.h" +@@ -1080,7 +1084,12 @@ wl_socket_init_for_display_name(struct wl_socket *s, const char *name) + int name_size; + const char *runtime_dir; + +- runtime_dir = getenv("XDG_RUNTIME_DIR"); ++#ifdef HAVE_MULTISEAT ++ runtime_dir = getenv("WAYLAND_SERVER_DIR"); ++ if (runtime_dir == NULL) ++#endif ++ runtime_dir = getenv("XDG_RUNTIME_DIR"); ++ + if (!runtime_dir) { + wl_log("error: XDG_RUNTIME_DIR not set in the environment\n"); + +@@ -1096,6 +1105,13 @@ wl_socket_init_for_display_name(struct wl_socket *s, const char *name) + + s->display_name = (s->addr.sun_path + name_size - 1) - strlen(name); + ++#ifdef HAVE_MULTISEAT ++ if (getenv("WAYLAND_SERVER_DIR")) { ++ unsetenv("WAYLAND_SERVER_DIR"); ++ setenv("WAYLAND_CLIENT_DIR", runtime_dir, 1); ++ } ++#endif ++ + assert(name_size > 0); + if (name_size > (int)sizeof s->addr.sun_path) { + wl_log("error: socket path \"%s/%s\" plus null terminator" +@@ -1114,6 +1130,12 @@ static int + _wl_display_add_socket(struct wl_display *display, struct wl_socket *s) + { + socklen_t size; ++#ifdef HAVE_MULTISEAT ++ const char *socket_mode_str; ++ const char *socket_group_str; ++ const struct group *socket_group; ++ unsigned socket_mode; ++#endif + + s->fd = wl_os_socket_cloexec(PF_LOCAL, SOCK_STREAM, 0); + if (s->fd < 0) { +@@ -1126,11 +1148,35 @@ _wl_display_add_socket(struct wl_display *display, struct wl_socket *s) + return -1; + } + +- if (listen(s->fd, 1) < 0) { ++ if (listen(s->fd, 8) < 0) { + wl_log("listen() failed with error: %m\n"); + return -1; + } + ++#ifdef HAVE_MULTISEAT ++ socket_group_str = getenv("WAYLAND_SERVER_GROUP"); ++ if (socket_group_str != NULL) { ++ socket_group = getgrnam(socket_group_str); ++ if (socket_group != NULL) { ++ if (chown(s->addr.sun_path, ++ -1, socket_group->gr_gid) != 0) ++ wl_log("chown(\"%s\") failed: %s", ++ s->addr.sun_path, ++ strerror(errno)); ++ } ++ } ++ ++ socket_mode_str = getenv("WAYLAND_SERVER_MODE"); ++ if (socket_mode_str != NULL) { ++ if (sscanf(socket_mode_str, "%o", &socket_mode) > 0) ++ if (chmod(s->addr.sun_path, socket_mode) != 0) { ++ wl_log("chmod(\"%s\") failed: %s", ++ s->addr.sun_path, ++ strerror(errno)); ++ } ++ } ++#endif ++ + s->source = wl_event_loop_add_fd(display->loop, s->fd, + WL_EVENT_READABLE, + socket_data, display); +-- +1.8.1.4 + diff --git a/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/wayland_%.bbappend b/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/wayland_%.bbappend index ba19db5be7..e2eafb35bc 100644 --- a/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/wayland_%.bbappend +++ b/meta-tizen/meta-tizen-adaptation/meta/recipes-graphics/wayland/wayland_%.bbappend @@ -1 +1,7 @@ SECTION = "Graphics & UI Framework/Wayland Window System" + +FILESEXTRAPATHS_prepend := "${THISDIR}/files:" + +SRC_URI += "file://0001-Added-APIstosupportmultiseatinwayland.patch" + +EXTRA_OECONF += "--enable-multiseat"
\ No newline at end of file |