[gtk+] Document handle-related Wayland api



commit bdbe2de57d206f3d1cbb5774f8a97bfc40571388
Author: Matthias Clasen <mclasen redhat com>
Date:   Mon Aug 29 13:12:56 2016 -0400

    Document handle-related Wayland api
    
    In particular, note that this API depends on an unstable
    Wayland protocol and thus may have to change.

 docs/reference/gdk/gdk3-sections.txt |    4 ++
 gdk/wayland/gdkwindow-wayland.c      |   74 ++++++++++++++++++++++++++++++---
 2 files changed, 71 insertions(+), 7 deletions(-)
---
diff --git a/docs/reference/gdk/gdk3-sections.txt b/docs/reference/gdk/gdk3-sections.txt
index 3c44ce6..f26c22d 100644
--- a/docs/reference/gdk/gdk3-sections.txt
+++ b/docs/reference/gdk/gdk3-sections.txt
@@ -1272,6 +1272,10 @@ gdk_wayland_display_get_wl_display
 gdk_wayland_display_get_xdg_shell
 gdk_wayland_window_get_wl_surface
 gdk_wayland_window_set_use_custom_surface
+GdkWaylandWindowExported
+gdk_wayland_window_export_handle
+gdk_wayland_window_unexport_handle
+gdk_wayland_window_set_transient_for_exported
 
 <SUBSECTION Standard>
 GDK_TYPE_WAYLAND_DEVICE
diff --git a/gdk/wayland/gdkwindow-wayland.c b/gdk/wayland/gdkwindow-wayland.c
index e8769f7..98d666d 100644
--- a/gdk/wayland/gdkwindow-wayland.c
+++ b/gdk/wayland/gdkwindow-wayland.c
@@ -3861,15 +3861,53 @@ static const struct zxdg_exported_v1_listener xdg_exported_listener = {
 };
 
 /**
+ * GdkWaylandWindowExported:
+ * @window: the #GdkWindow that is exported
+ * @handle: the handle
+ * @user_data: user data that was passed to gdk_wayland_window_export_handle()
+ *
+ * Callback that gets called when the handle for a window has been
+ * obtained from the Wayland compositor. The handle can be passed
+ * to other processes, for the purpose of marking windows as transient
+ * for out-of-process surfaces.
+ *
+ * Since: 3.22
+ */
+
+/**
  * gdk_wayland_window_export_handle:
+ * @window: the #GdkWindow to obtain a handle for
+ * @callback: callback to call with the handle
+ * @user_data: user data for @callback
+ * @destroy_func: destroy notify for @user_data
+ *
+ * Asynchronously obtains a handle for a surface that can be passed
+ * to other processes. When the handle has been obtained, @callback
+ * will be called.
+ *
+ * It is an error to call this function on a window that is already
+ * exported.
+ *
+ * When the handle is no longer needed, gdk_wayland_window_unexport_handle()
+ * should be called to clean up resources.
+ *
+ * The main purpose for obtaining a handle is to mark a surface
+ * from another window as transient for this one, see
+ * gdk_wayland_window_set_transient_for_exported().
  *
- * Stability: unstable
+ * Note that this API depends on an unstable Wayland protocol,
+ * and thus may require changes in the future.
+ *
+ * Return value: %TRUE if the handle has been requested, %FALSE if
+ *     an error occurred.
+ *
+ * Since: 3.22
  */
 gboolean
-gdk_wayland_window_export_handle (GdkWindow               *window,
-                                  GdkWaylandWindowExported callback,
-                                  gpointer                 user_data,
-                                  GDestroyNotify           destroy_func)
+gdk_wayland_window_export_handle (GdkWindow                *window,
+                                  GdkWaylandWindowExported  callback,
+                                  gpointer                  user_data,
+                                  GDestroyNotify            destroy_func)
 {
   GdkWindowImplWayland *impl;
   GdkWaylandDisplay *display_wayland;
@@ -3904,8 +3942,18 @@ gdk_wayland_window_export_handle (GdkWindow               *window,
 
 /**
  * gdk_wayland_window_unexport_handle:
+ * @window: the #GdkWindow to unexport
+ *
+ * Destroys the handle that was obtained with
+ * gdk_wayland_window_export_handle().
+ *
+ * It is an error to call this function on a window that
+ * does not have a handle.
  *
- * Stability: unstable
+ * Note that this API depends on an unstable Wayland protocol,
+ * and thus may require changes in the future.
+ *
+ * Since: 3.22
  */
 void
 gdk_wayland_window_unexport_handle (GdkWindow *window)
@@ -3947,8 +3995,20 @@ static const struct zxdg_imported_v1_listener xdg_imported_listener = {
 
 /**
  * gdk_wayland_window_set_transient_for_exported:
+ * @window: the #GdkWindow to make as transient
+ * @parent_handle_str: an exported handle for a surface
+ *
+ * Marks @window as transient for the surface to which the given
+ * @parent_handle_str refers. Typically, the handle will originate
+ * from a gdk_wayland_window_export_handle() call in another process.
+ *
+ * Note that this API depends on an unstable Wayland protocol,
+ * and thus may require changes in the future.
+ *
+ * Return value: %TRUE if the window has been marked as transient,
+ *     %FALSE if an error occurred.
  *
- * Stability: unstable
+ * Since: 3.22
  */
 gboolean
 gdk_wayland_window_set_transient_for_exported (GdkWindow *window,


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]