Selection callback was put back on action, but no real functional changes on X
side.

Signed-off-by: Tiago Vignatti <[email protected]>
---
 hw/xfree86/xwayland/xserver.xml |   42 +++++++++++++++++++++++++++++++++++++++
 hw/xfree86/xwayland/xwayland.c  |    3 +--
 2 files changed, 43 insertions(+), 2 deletions(-)

diff --git a/hw/xfree86/xwayland/xserver.xml b/hw/xfree86/xwayland/xserver.xml
index a5dbebd..20d39e5 100644
--- a/hw/xfree86/xwayland/xserver.xml
+++ b/hw/xfree86/xwayland/xserver.xml
@@ -75,6 +75,16 @@
       <arg name="xid" type="uint"/>
     </request>
 
+    <request name="set_selection">
+      <description summary="send the selection data">
+       Request for data from another client.  Send the data as the specified
+       mime-type over the passed fd.
+      </description>
+
+      <arg name="mime_type" type="string"/>
+      <arg name="fd" type="fd"/>
+    </request>
+
     <event name="xserver">
       <description summary="send X fd to window manager">
        This is the other tip of the socketpair used for connecting X and
@@ -98,6 +108,14 @@
 
       <arg name="state" type="uint"/>
     </event>
+
+    <event name="selection">
+      <description summary="notifies wm whether a text plain was selected">
+       The selection itself will happen via X then.
+      </description>
+
+      <arg name="has_text_plain" type="uint"/>
+    </event>
   </interface>
 
   <interface name="wm_xwin" version="1">
@@ -129,6 +147,30 @@
       <arg name="height" type="int"/>
       <arg name="flags" type="uint"/>
     </request>
+
+    <request name="set_opaque_override">
+      <description summary="set opaque override region">
+       Textures coming from X windows usually have their X window as RGBx,
+       i.e. 32 bit with an undefined alpha channel for the content part while
+       the decorations are rendered with a well-defined alpha channel. On
+       this case set_opaque_override is needed for marking a rectangle in a
+       texture and force the alpha = 1.0.
+
+       This is different from the wl_surface.set_opaque_region, where that
+       one is meant only as a hint for optimization while this is a necessity
+       for painting XWayland windows right. Therefore X must never use
+       wl_surface.set_opaque_region either.
+      </description>
+
+      <arg name="region" type="object" interface="wl_region"/>
+    </request>
+
+    <request name="set_input_region">
+      <description summary="set window input region">
+      </description>
+
+      <arg name="region" type="object" interface="wl_region" 
allow-null="true"/>
+    </request>
  
     <request name="move">
     </request>
diff --git a/hw/xfree86/xwayland/xwayland.c b/hw/xfree86/xwayland/xwayland.c
index a22ee58..54b92e8 100644
--- a/hw/xfree86/xwayland/xwayland.c
+++ b/hw/xfree86/xwayland/xwayland.c
@@ -318,12 +318,11 @@ xwl_screen_pre_init(ScrnInfoPtr scrninfo, struct 
xwl_screen *xwl_screen,
     noScreenSaverExtension = TRUE;
 
     xdnd_atom = MakeAtom("XdndSelection", 13, 1);
-#if 0
     if (!AddCallback(&SelectionCallback,
                     xwayland_selection_callback, xwl_screen)) {
        return FALSE;
     }
-#endif
+
     xorg_list_init(&xwl_screen->seat_list);
     xorg_list_init(&xwl_screen->damage_window_list);
     xorg_list_init(&xwl_screen->window_list);
-- 
1.7.9.5

_______________________________________________
wayland-devel mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/wayland-devel

Reply via email to