*
* 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
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the Free
- * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
*/
#ifndef __GDK_PRIVATE_H__
#define __GDK_PRIVATE_H__
#include <X11/Xutil.h>
#include <gdk/gdktypes.h>
-#define DND_PROTOCOL_VERSION 0
-
-#define gdk_window_lookup(xid) ((GdkWindow*) gdk_xid_table_lookup (xid))
-#define gdk_pixmap_lookup(xid) ((GdkPixmap*) gdk_xid_table_lookup (xid))
-#define gdk_font_lookup(xid) ((GdkFont*) gdk_xid_table_lookup (xid))
+#define gdk_window_lookup(xid) ((GdkWindow*) gdk_xid_table_lookup (xid))
+#define gdk_pixmap_lookup(xid) ((GdkPixmap*) gdk_xid_table_lookup (xid))
+#define gdk_font_lookup(xid) ((GdkFont*) gdk_xid_table_lookup (xid))
#ifdef __cplusplus
typedef struct _GdkWindowPrivate GdkWindowPrivate;
typedef struct _GdkWindowPrivate GdkPixmapPrivate;
-typedef struct _GdkImagePrivate GdkImagePrivate;
-typedef struct _GdkGCPrivate GdkGCPrivate;
+typedef struct _GdkImagePrivate GdkImagePrivate;
+typedef struct _GdkGCPrivate GdkGCPrivate;
typedef struct _GdkColormapPrivate GdkColormapPrivate;
+typedef struct _GdkColorInfo GdkColorInfo;
typedef struct _GdkVisualPrivate GdkVisualPrivate;
-typedef struct _GdkFontPrivate GdkFontPrivate;
+typedef struct _GdkFontPrivate GdkFontPrivate;
typedef struct _GdkCursorPrivate GdkCursorPrivate;
+typedef struct _GdkEventFilter GdkEventFilter;
+typedef struct _GdkClientFilter GdkClientFilter;
typedef struct _GdkColorContextPrivate GdkColorContextPrivate;
+typedef struct _GdkRegionPrivate GdkRegionPrivate;
struct _GdkWindowPrivate
guint16 width;
guint16 height;
guint8 resize_count;
- guint8 ref_count;
guint8 window_type;
- guint8 destroyed : 2;
- guint8 dnd_drag_enabled : 1,
- dnd_drag_datashow : 1,
- dnd_drag_destructive_op : 1,
- dnd_drag_accepted : 1,
- dnd_drop_enabled : 1,
- dnd_drop_destructive_op : 1;
- GdkAtom dnd_drag_data_type, *dnd_drag_data_typesavail;
- guint dnd_drag_data_numtypesavail;
- /* We have to turn on MotionMask/EnterWindowMask/LeaveWindowMask
- during drags, then set it back to what it was after */
- glong dnd_drag_savedeventmask, dnd_drag_eventmask;
- GdkAtom *dnd_drop_data_typesavail;
- guint dnd_drop_data_numtypesavail;
- /* need to allow custom drag/drop cursors */
+ guint ref_count;
+ guint destroyed : 2;
gint extension_events;
+
+ GList *filters;
+ GdkColormap *colormap;
+ GList *children;
};
struct _GdkImagePrivate
gpointer x_shm_info;
void (*image_put) (GdkDrawable *window,
- GdkGC *gc,
- GdkImage *image,
- gint xsrc,
- gint ysrc,
- gint xdest,
- gint ydest,
- gint width,
- gint height);
+ GdkGC *gc,
+ GdkImage *image,
+ gint xsrc,
+ gint ysrc,
+ gint xdest,
+ gint ydest,
+ gint width,
+ gint height);
};
struct _GdkGCPrivate
GdkGC gc;
GC xgc;
Display *xdisplay;
+ guint ref_count;
+};
+
+typedef enum {
+ GDK_COLOR_WRITEABLE = 1 << 0
+} GdkColorInfoFlags;
+
+struct _GdkColorInfo
+{
+ GdkColorInfoFlags flags;
+ guint ref_count;
};
struct _GdkColormapPrivate
Display *xdisplay;
GdkVisual *visual;
gint private_val;
- gint next_color;
- gint ref_count;
+
+ GHashTable *hash;
+ GdkColorInfo *info;
+ time_t last_sync_time;
+
+ guint ref_count;
};
struct _GdkVisualPrivate
/* generic pointer point to XFontStruct or XFontSet */
gpointer xfont;
Display *xdisplay;
- gint ref_count;
+ guint ref_count;
};
struct _GdkCursorPrivate
Display *xdisplay;
};
+struct _GdkDndCursorInfo {
+ Cursor gdk_cursor_dragdefault, gdk_cursor_dragok;
+ GdkWindow *drag_pm_default, *drag_pm_ok;
+ GdkPoint default_hotspot, ok_hotspot;
+ GList *xids;
+};
+typedef struct _GdkDndCursorInfo GdkDndCursorInfo;
+
struct _GdkDndGlobals {
- GdkAtom gdk_XdeEnter, gdk_XdeLeave, gdk_XdeRequest;
- GdkAtom gdk_XdeDataAvailable, gdk_XdeDataShow, gdk_XdeCancel;
- GdkAtom gdk_XdeTypelist;
- Cursor gdk_cursor_dragdefault, gdk_cursor_dragok;
- GdkWindow **drag_startwindows;
- guint drag_numwindows;
- guint8 drag_really;
- GdkPoint drag_dropcoords;
+ GdkAtom gdk_XdeEnter, gdk_XdeLeave, gdk_XdeRequest;
+ GdkAtom gdk_XdeDataAvailable, gdk_XdeDataShow, gdk_XdeCancel;
+ GdkAtom gdk_XdeTypelist;
+
+ GdkDndCursorInfo *c;
+ GdkWindow **drag_startwindows;
+ guint drag_numwindows;
+ gboolean drag_really, drag_perhaps, dnd_grabbed;
+ Window dnd_drag_target;
+ GdkPoint drag_dropcoords;
+
+ GdkPoint dnd_drag_start, dnd_drag_oldpos;
+ GdkRectangle dnd_drag_dropzone;
+ GdkWindowPrivate *real_sw;
+ Window dnd_drag_curwin;
+ Time last_drop_time; /* An incredible hack, sosumi miguel */
};
typedef struct _GdkDndGlobals GdkDndGlobals;
+struct _GdkEventFilter {
+ GdkFilterFunc function;
+ gpointer data;
+};
+
+struct _GdkClientFilter {
+ GdkAtom type;
+ GdkFilterFunc function;
+ gpointer data;
+};
#ifdef USE_XIM
+typedef struct _GdkICPrivate GdkICPrivate;
+
struct _GdkICPrivate
{
XIC xic;
- GdkIMStyle style;
+ GdkICAttr *attr;
+ GdkICAttributesType mask;
};
-typedef struct _GdkICPrivate GdkICPrivate;
#endif /* USE_XIM */
-
struct _GdkColorContextPrivate
{
GdkColorContext color_context;
XStandardColormap std_cmap;
};
+struct _GdkRegionPrivate
+{
+ GdkRegion region;
+ Region xregion;
+};
+
+typedef enum {
+ GDK_DEBUG_MISC = 1 << 0,
+ GDK_DEBUG_EVENTS = 1 << 1,
+ GDK_DEBUG_DND = 1 << 2,
+ GDK_DEBUG_COLOR_CONTEXT = 1 << 3,
+ GDK_DEBUG_XIM = 1 << 4
+} GdkDebugFlag;
void gdk_window_init (void);
void gdk_visual_init (void);
+void gdk_dnd_init (void);
void gdk_image_init (void);
void gdk_image_exit (void);
GdkColormap* gdk_colormap_lookup (Colormap xcolormap);
-GdkVisual* gdk_visual_lookup (Visual *xvisual);
+GdkVisual* gdk_visual_lookup (Visual *xvisual);
-void gdk_window_real_destroy (GdkWindow *window);
void gdk_window_add_colormap_windows (GdkWindow *window);
+void gdk_window_destroy_notify (GdkWindow *window);
+
+void gdk_xid_table_insert (XID *xid,
+ gpointer data);
+void gdk_xid_table_remove (XID xid);
+gpointer gdk_xid_table_lookup (XID xid);
+
+gint gdk_send_xevent (Window window, gboolean propagate, glong event_mask,
+ XEvent *event_send);
+
+/* If you pass x = y = -1, it queries the pointer
+ to find out where it currently is.
+ If you pass x = y = -2, it does anything necessary
+ to know that the drag is ending.
+*/
+void gdk_dnd_display_drag_cursor(gint x,
+ gint y,
+ gboolean drag_ok,
+ gboolean change_made);
+
+/* Please see gdkwindow.c for comments on how to use */
+Window gdk_window_xid_at(Window base, gint bx, gint by, gint x, gint y, GList *excludes, gboolean excl_child);
+Window gdk_window_xid_at_coords(gint x, gint y, GList *excludes, gboolean excl_child);
+
+extern gint gdk_debug_level;
+extern gint gdk_show_events;
+extern gint gdk_use_xshm;
+extern gint gdk_stack_trace;
+extern gchar *gdk_display_name;
+extern Display *gdk_display;
+extern gint gdk_screen;
+extern Window gdk_root_window;
+extern Window gdk_leader_window;
+extern GdkWindowPrivate gdk_root_parent;
+extern Atom gdk_wm_delete_window;
+extern Atom gdk_wm_take_focus;
+extern Atom gdk_wm_protocols;
+extern Atom gdk_wm_window_protocols[];
+extern Atom gdk_selection_property;
+extern GdkDndGlobals gdk_dnd;
+extern GdkWindow *selection_owner[];
+extern gchar *gdk_progclass;
+extern gint gdk_error_code;
+extern gint gdk_error_warnings;
+extern gint gdk_null_window_warnings;
+extern GList *gdk_default_filters;
+extern gboolean gdk_using_threads;
+
+/* Threading stuff */
+#ifdef USE_PTHREADS
+extern gint gdk_threads_pipe[2];
+extern gboolean gdk_select_waiting;
+#endif
+
+#ifdef USE_XIM
+/* XIM support */
+gint gdk_im_open (void);
+void gdk_im_close (void);
+void gdk_ic_cleanup (void);
+
+extern GdkICPrivate *gdk_xim_ic; /* currently using IC */
+extern GdkWindow *gdk_xim_window; /* currently using Window */
+#endif /* USE_XIM */
+
+/* Debugging support */
+
+#ifdef G_ENABLE_DEBUG
+
+#define GDK_NOTE(type,action) G_STMT_START { \
+ if (gdk_debug_flags & GDK_DEBUG_##type) \
+ { action; }; } G_STMT_END
+
+#else /* !G_ENABLE_DEBUG */
+
+#define GDK_NOTE(type,action)
+
+#endif /* G_ENABLE_DEBUG */
-void gdk_xid_table_insert (XID *xid,
- gpointer data);
-void gdk_xid_table_remove (XID xid);
-gpointer gdk_xid_table_lookup (XID xid);
-
-
-extern gint gdk_debug_level;
-extern gint gdk_show_events;
-extern gint gdk_use_xshm;
-extern gint gdk_stack_trace;
-extern gchar *gdk_display_name;
-extern Display *gdk_display;
-extern gint gdk_screen;
-extern Window gdk_root_window;
-extern Window gdk_leader_window;
-extern GdkWindowPrivate gdk_root_parent;
-extern Atom gdk_wm_delete_window;
-extern Atom gdk_wm_take_focus;
-extern Atom gdk_wm_protocols;
-extern Atom gdk_wm_window_protocols[];
-extern Atom gdk_selection_property;
-extern GdkDndGlobals gdk_dnd;
-extern GdkWindow *selection_owner[];
-extern gchar *gdk_progname;
-extern gchar *gdk_progclass;
-extern gint gdk_error_code;
-extern gint gdk_error_warnings;
+extern guint gdk_debug_flags;
#ifdef __cplusplus