303 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			303 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* GDK - The GIMP Drawing Kit
 | 
						|
 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
 | 
						|
 *
 | 
						|
 * 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/>.
 | 
						|
 */
 | 
						|
 | 
						|
/*
 | 
						|
 * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
 | 
						|
 * file for a list of people on the GTK+ Team.  See the ChangeLog
 | 
						|
 * files for a list of changes.  These files are distributed with
 | 
						|
 * GTK+ at ftp://ftp.gtk.org/pub/gtk/. 
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __GDK_WINDOW_IMPL_H__
 | 
						|
#define __GDK_WINDOW_IMPL_H__
 | 
						|
 | 
						|
#include <gdk/gdkwindow.h>
 | 
						|
#include <gdk/gdkproperty.h>
 | 
						|
 | 
						|
G_BEGIN_DECLS
 | 
						|
 | 
						|
#define GDK_TYPE_WINDOW_IMPL           (gdk_window_impl_get_type ())
 | 
						|
#define GDK_WINDOW_IMPL(object)           (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_WINDOW_IMPL, GdkWindowImpl))
 | 
						|
#define GDK_WINDOW_IMPL_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_WINDOW_IMPL, GdkWindowImplClass))
 | 
						|
#define GDK_IS_WINDOW_IMPL(object)        (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_WINDOW_IMPL))
 | 
						|
#define GDK_IS_WINDOW_IMPL_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_WINDOW_IMPL))
 | 
						|
#define GDK_WINDOW_IMPL_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_WINDOW_IMPL, GdkWindowImplClass))
 | 
						|
 | 
						|
typedef struct _GdkWindowImpl       GdkWindowImpl;
 | 
						|
typedef struct _GdkWindowImplClass  GdkWindowImplClass;
 | 
						|
 | 
						|
struct _GdkWindowImpl
 | 
						|
{
 | 
						|
  GObject parent;
 | 
						|
};
 | 
						|
 | 
						|
struct _GdkWindowImplClass
 | 
						|
{
 | 
						|
  GObjectClass parent_class;
 | 
						|
 | 
						|
  cairo_surface_t *
 | 
						|
               (* ref_cairo_surface)    (GdkWindow       *window);
 | 
						|
 | 
						|
  void         (* show)                 (GdkWindow       *window,
 | 
						|
					 gboolean         already_mapped);
 | 
						|
  void         (* hide)                 (GdkWindow       *window);
 | 
						|
  void         (* withdraw)             (GdkWindow       *window);
 | 
						|
  void         (* raise)                (GdkWindow       *window);
 | 
						|
  void         (* lower)                (GdkWindow       *window);
 | 
						|
  void         (* restack_under)        (GdkWindow       *window,
 | 
						|
					 GList           *native_siblings);
 | 
						|
  void         (* restack_toplevel)     (GdkWindow       *window,
 | 
						|
					 GdkWindow       *sibling,
 | 
						|
					 gboolean        above);
 | 
						|
 | 
						|
  void         (* move_resize)          (GdkWindow       *window,
 | 
						|
                                         gboolean         with_move,
 | 
						|
                                         gint             x,
 | 
						|
                                         gint             y,
 | 
						|
                                         gint             width,
 | 
						|
                                         gint             height);
 | 
						|
  void         (* set_background)       (GdkWindow       *window,
 | 
						|
                                         cairo_pattern_t *pattern);
 | 
						|
 | 
						|
  GdkEventMask (* get_events)           (GdkWindow       *window);
 | 
						|
  void         (* set_events)           (GdkWindow       *window,
 | 
						|
                                         GdkEventMask     event_mask);
 | 
						|
  
 | 
						|
  gboolean     (* reparent)             (GdkWindow       *window,
 | 
						|
                                         GdkWindow       *new_parent,
 | 
						|
                                         gint             x,
 | 
						|
                                         gint             y);
 | 
						|
 | 
						|
  void         (* set_device_cursor)    (GdkWindow       *window,
 | 
						|
                                         GdkDevice       *device,
 | 
						|
                                         GdkCursor       *cursor);
 | 
						|
 | 
						|
  void         (* get_geometry)         (GdkWindow       *window,
 | 
						|
                                         gint            *x,
 | 
						|
                                         gint            *y,
 | 
						|
                                         gint            *width,
 | 
						|
                                         gint            *height);
 | 
						|
  gint         (* get_root_coords)      (GdkWindow       *window,
 | 
						|
					 gint             x,
 | 
						|
					 gint             y,
 | 
						|
                                         gint            *root_x,
 | 
						|
                                         gint            *root_y);
 | 
						|
  gboolean     (* get_device_state)     (GdkWindow       *window,
 | 
						|
                                         GdkDevice       *device,
 | 
						|
                                         gint            *x,
 | 
						|
                                         gint            *y,
 | 
						|
                                         GdkModifierType *mask);
 | 
						|
 | 
						|
  cairo_region_t * (* get_shape)        (GdkWindow       *window);
 | 
						|
  cairo_region_t * (* get_input_shape)  (GdkWindow       *window);
 | 
						|
  void         (* shape_combine_region) (GdkWindow       *window,
 | 
						|
                                         const cairo_region_t *shape_region,
 | 
						|
                                         gint             offset_x,
 | 
						|
                                         gint             offset_y);
 | 
						|
  void         (* input_shape_combine_region) (GdkWindow       *window,
 | 
						|
					       const cairo_region_t *shape_region,
 | 
						|
					       gint             offset_x,
 | 
						|
					       gint             offset_y);
 | 
						|
 | 
						|
  gboolean     (* set_static_gravities) (GdkWindow       *window,
 | 
						|
				         gboolean         use_static);
 | 
						|
 | 
						|
  /* Called before processing updates for a window. This gives the windowing
 | 
						|
   * layer a chance to save the region for later use in avoiding duplicate
 | 
						|
   * exposes. The return value indicates whether the function has a saved
 | 
						|
   * the region; if the result is TRUE, then the windowing layer is responsible
 | 
						|
   * for destroying the region later.
 | 
						|
   */
 | 
						|
  gboolean     (* queue_antiexpose)     (GdkWindow       *window,
 | 
						|
					 cairo_region_t  *update_area);
 | 
						|
 | 
						|
  /* Called to move @area inside @window by @dx x @dy pixels. @area is 
 | 
						|
   * guaranteed to be inside @window. If part of @area is not invisible or
 | 
						|
   * invalid, it is this function's job to queue expose events in those 
 | 
						|
   * areas.
 | 
						|
   */
 | 
						|
  void         (* translate)            (GdkWindow       *window,
 | 
						|
					 cairo_region_t  *area,
 | 
						|
					 gint            dx,
 | 
						|
					 gint            dy);
 | 
						|
 | 
						|
/* Called to do the windowing system specific part of gdk_window_destroy(),
 | 
						|
 *
 | 
						|
 * window: The window being destroyed
 | 
						|
 * recursing: If TRUE, then this is being called because a parent
 | 
						|
 *     was destroyed. This generally means that the call to the windowing
 | 
						|
 *     system to destroy the window can be omitted, since it will be
 | 
						|
 *     destroyed as a result of the parent being destroyed.
 | 
						|
 *     Unless @foreign_destroy
 | 
						|
 * foreign_destroy: If TRUE, the window or a parent was destroyed by some
 | 
						|
 *     external agency. The window has already been destroyed and no
 | 
						|
 *     windowing system calls should be made. (This may never happen
 | 
						|
 *     for some windowing systems.)
 | 
						|
 */
 | 
						|
  void         (* destroy)              (GdkWindow       *window,
 | 
						|
					 gboolean         recursing,
 | 
						|
					 gboolean         foreign_destroy);
 | 
						|
 | 
						|
 | 
						|
 /* Called when gdk_window_destroy() is called on a foreign window
 | 
						|
  * or an ancestor of the foreign window. It should generally reparent
 | 
						|
  * the window out of it's current heirarchy, hide it, and then
 | 
						|
  * send a message to the owner requesting that the window be destroyed.
 | 
						|
  */
 | 
						|
  void         (*destroy_foreign)       (GdkWindow       *window);
 | 
						|
 | 
						|
  cairo_surface_t * (* resize_cairo_surface) (GdkWindow       *window,
 | 
						|
                                              cairo_surface_t *surface,
 | 
						|
                                              gint             width,
 | 
						|
                                              gint             height);
 | 
						|
 | 
						|
  /* optional */
 | 
						|
  gboolean     (* beep)                 (GdkWindow       *window);
 | 
						|
 | 
						|
  void         (* focus)                (GdkWindow       *window,
 | 
						|
					 guint32          timestamp);
 | 
						|
  void         (* set_type_hint)        (GdkWindow       *window,
 | 
						|
					 GdkWindowTypeHint hint);
 | 
						|
  GdkWindowTypeHint (* get_type_hint)   (GdkWindow       *window);
 | 
						|
  void         (* set_modal_hint)       (GdkWindow *window,
 | 
						|
					 gboolean   modal);
 | 
						|
  void         (* set_skip_taskbar_hint) (GdkWindow *window,
 | 
						|
					  gboolean   skips_taskbar);
 | 
						|
  void         (* set_skip_pager_hint)  (GdkWindow *window,
 | 
						|
					 gboolean   skips_pager);
 | 
						|
  void         (* set_urgency_hint)     (GdkWindow *window,
 | 
						|
					 gboolean   urgent);
 | 
						|
  void         (* set_geometry_hints)   (GdkWindow         *window,
 | 
						|
					 const GdkGeometry *geometry,
 | 
						|
					 GdkWindowHints     geom_mask);
 | 
						|
  void         (* set_title)            (GdkWindow   *window,
 | 
						|
					 const gchar *title);
 | 
						|
  void         (* set_role)             (GdkWindow   *window,
 | 
						|
					 const gchar *role);
 | 
						|
  void         (* set_startup_id)       (GdkWindow   *window,
 | 
						|
					 const gchar *startup_id);
 | 
						|
  void         (* set_transient_for)    (GdkWindow *window,
 | 
						|
					 GdkWindow *parent);
 | 
						|
  void         (* get_root_origin)      (GdkWindow *window,
 | 
						|
					 gint      *x,
 | 
						|
					 gint      *y);
 | 
						|
  void         (* get_frame_extents)    (GdkWindow    *window,
 | 
						|
					 GdkRectangle *rect);
 | 
						|
  void         (* set_override_redirect) (GdkWindow *window,
 | 
						|
					  gboolean override_redirect);
 | 
						|
  void         (* set_accept_focus)     (GdkWindow *window,
 | 
						|
					 gboolean accept_focus);
 | 
						|
  void         (* set_focus_on_map)     (GdkWindow *window,
 | 
						|
					 gboolean focus_on_map);
 | 
						|
  void         (* set_icon_list)        (GdkWindow *window,
 | 
						|
					 GList     *pixbufs);
 | 
						|
  void         (* set_icon_name)        (GdkWindow   *window,
 | 
						|
					 const gchar *name);
 | 
						|
  void         (* iconify)              (GdkWindow *window);
 | 
						|
  void         (* deiconify)            (GdkWindow *window);
 | 
						|
  void         (* stick)                (GdkWindow *window);
 | 
						|
  void         (* unstick)              (GdkWindow *window);
 | 
						|
  void         (* maximize)             (GdkWindow *window);
 | 
						|
  void         (* unmaximize)           (GdkWindow *window);
 | 
						|
  void         (* fullscreen)           (GdkWindow *window);
 | 
						|
  void         (* unfullscreen)         (GdkWindow *window);
 | 
						|
  void         (* set_keep_above)       (GdkWindow *window,
 | 
						|
					 gboolean   setting);
 | 
						|
  void         (* set_keep_below)       (GdkWindow *window,
 | 
						|
					 gboolean   setting);
 | 
						|
  GdkWindow *  (* get_group)            (GdkWindow *window);
 | 
						|
  void         (* set_group)            (GdkWindow *window,
 | 
						|
					 GdkWindow *leader);
 | 
						|
  void         (* set_decorations)      (GdkWindow      *window,
 | 
						|
					 GdkWMDecoration decorations);
 | 
						|
  gboolean     (* get_decorations)      (GdkWindow       *window,
 | 
						|
					 GdkWMDecoration *decorations);
 | 
						|
  void         (* set_functions)        (GdkWindow    *window,
 | 
						|
					 GdkWMFunction functions);
 | 
						|
  void         (* begin_resize_drag)    (GdkWindow     *window,
 | 
						|
                                         GdkWindowEdge  edge,
 | 
						|
                                         GdkDevice     *device,
 | 
						|
                                         gint           button,
 | 
						|
                                         gint           root_x,
 | 
						|
                                         gint           root_y,
 | 
						|
                                         guint32        timestamp);
 | 
						|
  void         (* begin_move_drag)      (GdkWindow *window,
 | 
						|
                                         GdkDevice     *device,
 | 
						|
                                         gint       button,
 | 
						|
                                         gint       root_x,
 | 
						|
                                         gint       root_y,
 | 
						|
                                         guint32    timestamp);
 | 
						|
  void         (* enable_synchronized_configure) (GdkWindow *window);
 | 
						|
  void         (* configure_finished)   (GdkWindow *window);
 | 
						|
  void         (* set_opacity)          (GdkWindow *window,
 | 
						|
					 gdouble    opacity);
 | 
						|
  void         (* set_composited)       (GdkWindow *window,
 | 
						|
                                         gboolean   composited);
 | 
						|
  void         (* destroy_notify)       (GdkWindow *window);
 | 
						|
  GdkDragProtocol (* get_drag_protocol) (GdkWindow *window,
 | 
						|
                                         GdkWindow **target);
 | 
						|
  void         (* register_dnd)         (GdkWindow *window);
 | 
						|
  GdkDragContext * (*drag_begin)        (GdkWindow *window,
 | 
						|
                                         GdkDevice *device,
 | 
						|
                                         GList     *targets);
 | 
						|
 | 
						|
  void         (*process_updates_recurse) (GdkWindow      *window,
 | 
						|
                                           cairo_region_t *region);
 | 
						|
 | 
						|
  void         (*sync_rendering)          (GdkWindow      *window);
 | 
						|
  gboolean     (*simulate_key)            (GdkWindow      *window,
 | 
						|
                                           gint            x,
 | 
						|
                                           gint            y,
 | 
						|
                                           guint           keyval,
 | 
						|
                                           GdkModifierType modifiers,
 | 
						|
                                           GdkEventType    event_type);
 | 
						|
  gboolean     (*simulate_button)         (GdkWindow      *window,
 | 
						|
                                           gint            x,
 | 
						|
                                           gint            y,
 | 
						|
                                           guint           button,
 | 
						|
                                           GdkModifierType modifiers,
 | 
						|
                                           GdkEventType    event_type);
 | 
						|
 | 
						|
  gboolean     (*get_property)            (GdkWindow      *window,
 | 
						|
                                           GdkAtom         property,
 | 
						|
                                           GdkAtom         type,
 | 
						|
                                           gulong          offset,
 | 
						|
                                           gulong          length,
 | 
						|
                                           gint            pdelete,
 | 
						|
                                           GdkAtom        *actual_type,
 | 
						|
                                           gint           *actual_format,
 | 
						|
                                           gint           *actual_length,
 | 
						|
                                           guchar        **data);
 | 
						|
  void         (*change_property)         (GdkWindow      *window,
 | 
						|
                                           GdkAtom         property,
 | 
						|
                                           GdkAtom         type,
 | 
						|
                                           gint            format,
 | 
						|
                                           GdkPropMode     mode,
 | 
						|
                                           const guchar   *data,
 | 
						|
                                           gint            n_elements);
 | 
						|
  void         (*delete_property)         (GdkWindow      *window,
 | 
						|
                                           GdkAtom         property);
 | 
						|
};
 | 
						|
 | 
						|
/* Interface Functions */
 | 
						|
GType gdk_window_impl_get_type (void) G_GNUC_CONST;
 | 
						|
 | 
						|
 | 
						|
G_END_DECLS
 | 
						|
 | 
						|
#endif /* __GDK_WINDOW_IMPL_H__ */
 |