 d3316a37ed
			
		
	
	d3316a37ed
	
	
	
		
			
			This is useful when clients use subsurfaces independently of GDK. For example if a client creates a subsurface that covers a GdkWindow entirely. If this subsurface is opaque, Wayland compositors may not emit callbacks for the surface of the GdkWindow any more. Adding the covering subsurface via this new API ensures the GdkWindow will continue to update in this case.
		
			
				
	
	
		
			101 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* GDK - The GIMP Drawing Kit
 | |
|  * Copyright (C) 2013 Jan Arne Petersen
 | |
|  *
 | |
|  * This library is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This library is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with this library. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #ifndef __GDK_WAYLAND_WINDOW_H__
 | |
| #define __GDK_WAYLAND_WINDOW_H__
 | |
| 
 | |
| #if !defined (__GDKWAYLAND_H_INSIDE__) && !defined (GDK_COMPILATION)
 | |
| #error "Only <gdk/gdkwayland.h> can be included directly."
 | |
| #endif
 | |
| 
 | |
| #include <gdk/gdk.h>
 | |
| 
 | |
| #include <wayland-client.h>
 | |
| 
 | |
| G_BEGIN_DECLS
 | |
| 
 | |
| #ifdef GDK_COMPILATION
 | |
| typedef struct _GdkWaylandWindow GdkWaylandWindow;
 | |
| #else
 | |
| typedef GdkWindow GdkWaylandWindow;
 | |
| #endif
 | |
| typedef struct _GdkWaylandWindowClass GdkWaylandWindowClass;
 | |
| 
 | |
| #define GDK_TYPE_WAYLAND_WINDOW              (gdk_wayland_window_get_type())
 | |
| #define GDK_WAYLAND_WINDOW(object)           (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_WAYLAND_WINDOW, GdkWaylandWindow))
 | |
| #define GDK_WAYLAND_WINDOW_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_WAYLAND_WINDOW, GdkWaylandWindowClass))
 | |
| #define GDK_IS_WAYLAND_WINDOW(object)        (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_WAYLAND_WINDOW))
 | |
| #define GDK_IS_WAYLAND_WINDOW_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_WAYLAND_WINDOW))
 | |
| #define GDK_WAYLAND_WINDOW_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_WAYLAND_WINDOW, GdkWaylandWindowClass))
 | |
| 
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| GType                    gdk_wayland_window_get_type             (void);
 | |
| 
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| struct wl_surface       *gdk_wayland_window_get_wl_surface       (GdkWindow *window);
 | |
| 
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| void                     gdk_wayland_window_set_use_custom_surface (GdkWindow *window);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_10
 | |
| void                     gdk_wayland_window_set_dbus_properties_libgtk_only (GdkWindow  *window,
 | |
| 									     const char *application_id,
 | |
| 									     const char *app_menu_path,
 | |
| 									     const char *menubar_path,
 | |
| 									     const char *window_object_path,
 | |
| 									     const char *application_object_path,
 | |
| 									     const char *unique_bus_name);
 | |
| 
 | |
| typedef void (*GdkWaylandWindowExported) (GdkWindow  *window,
 | |
|                                           const char *handle,
 | |
|                                           gpointer    user_data);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_22
 | |
| gboolean                 gdk_wayland_window_export_handle (GdkWindow               *window,
 | |
|                                                            GdkWaylandWindowExported callback,
 | |
|                                                            gpointer                 user_data,
 | |
|                                                            GDestroyNotify           destroy_func);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_22
 | |
| void                     gdk_wayland_window_unexport_handle (GdkWindow *window);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_22
 | |
| gboolean                 gdk_wayland_window_set_transient_for_exported (GdkWindow *window,
 | |
|                                                                         char      *parent_handle_str);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_24
 | |
| void                     gdk_wayland_window_set_application_id (GdkWindow *window,
 | |
|                                                                 const char *application_id);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_22
 | |
| void gdk_wayland_window_announce_csd                        (GdkWindow *window);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_24
 | |
| void gdk_wayland_window_announce_ssd                        (GdkWindow *window);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_24
 | |
| void gdk_wayland_window_add_frame_callback_surface (GdkWindow         *window,
 | |
|                                                     struct wl_surface *surface);
 | |
| 
 | |
| GDK_AVAILABLE_IN_3_24
 | |
| void gdk_wayland_window_remove_frame_callback_surface (GdkWindow         *window,
 | |
|                                                        struct wl_surface *surface);
 | |
| 
 | |
| G_END_DECLS
 | |
| 
 | |
| #endif /* __GDK_WAYLAND_WINDOW_H__ */
 |