summaryrefslogtreecommitdiff
path: root/gtk/gtklayout.c
diff options
context:
space:
mode:
authorTor Lillqvist <tml@src.gnome.org>1999-03-15 00:03:37 +0000
committerTor Lillqvist <tml@src.gnome.org>1999-03-15 00:03:37 +0000
commitc65508d2723d255a9fcdfa8ac2a5f82b0667a7c6 (patch)
tree57c568358f89e9d1ec3c561bae77f5b76adc6417 /gtk/gtklayout.c
parent044fd2db4700cf34d4a2b06424be0bbe2dce5b78 (diff)
downloadgtk+-c65508d2723d255a9fcdfa8ac2a5f82b0667a7c6.tar.gz
This might seem like a large patch, but it isn't that bad, and nothing
should break on Unix/X11. Win32 merge and general portability stuff: * acconfig.h,configure.in: Check for <sys/time.h>. * gdk/win32: New directory (actually, been there for a while). * gtk/fnmatch.c: Include <glib.h> for G_DIR_SEPARATOR, WIN32 and NATIVE_WIN32, and use these. Always case fold on Win32. No backslashed escapes on native Win32. * gtk/{gtk.def,makefile.msc}: New files. * gtk/Makefile.am: Add above new files. * gtk/{gtkaccelgroup,gtkbindings}.c: Include <string.h> instead of <strings.h>. * gtk/{gtkcalendar,gtkitemfactory,gtkpreview,gtkrc}.c: Include config.h. Protect inclusion of <sys/param.h>, <sys/time.h>, and <unistd.h> appropriately. * gtk/gtkdnd.c: Merge in Win32 version (which doesn't do much). Use ABS() (from <glib.h>) instead of abs(). * gtk/gtkfilesel.c: Moved Win32-specific includes after inclusion of gtk (and thus glib) headers, so that WIN32 will be defined. With MS C, include <direct.h> for mkdir prototype. * gtk/gtkitemfactory.c (gtk_item_factory_callback_marshal): Add some casts, needed by MS C. * gtk/{gtklayout,gtkplug}.c: Merge in Win32 version (which isn't implemented). * gtk/gtkmain.c: Include gdk/gdkx.h for GDK_WINDOWING. Include <X11/Xlocale.h> only on X11 platform, otherwise <locale.h>. Use G_SEARCHPATH_SEPARATOR_S and g_module_build_path. * gtk/gtkmain.h: Mark variables for export/import on Win32. * gtk/gtkrange.c (gtk_range_motion_notify): Set mods also in case the event is not a hint, or its window is not the slider. Needed on Win32, at least. * gtk/gtkrc.c: Include config.h and gdk/gdkx.h. Use <locale.h> unless on X11. Skip \r chars, too. Use G_DIR_SEPARATOR and G_SEARCHPATH_SEPARATOR(_S). Use g_path_is_absolute. On Win32, use a subdirectory of the Windows directory as gtk system configuration directory. * gtk/gtkselection.c: No chunks on Win32. * gtk/gtksocket.c: Not implemented on Win32. * gtk/gtkthemes.c (gtk_theme_engine_get): Use g_module_build_path. * gtk/makeenums.h: Include gdkprivate.h after gdk.h. * gtk/testrgb.c: Use dynamically allocated buffer. Use GTimers.
Diffstat (limited to 'gtk/gtklayout.c')
-rw-r--r--gtk/gtklayout.c25
1 files changed, 22 insertions, 3 deletions
diff --git a/gtk/gtklayout.c b/gtk/gtklayout.c
index 2b55613f2f..34af8ad067 100644
--- a/gtk/gtklayout.c
+++ b/gtk/gtklayout.c
@@ -28,10 +28,11 @@
* GTK+ at ftp://ftp.gtk.org/pub/gtk/.
*/
+#include "gdk/gdkx.h"
+
#include "gtklayout.h"
#include "gtksignal.h"
#include "gtkprivate.h"
-#include "gdk/gdkx.h"
typedef struct _GtkLayoutAdjData GtkLayoutAdjData;
typedef struct _GtkLayoutChild GtkLayoutChild;
@@ -868,6 +869,8 @@ gtk_layout_expose_area (GtkLayout *layout,
}
}
+#if GDK_WINDOWING == GDK_WINDOWING_X11
+
/* This function is used to find events to process while scrolling
*/
@@ -884,6 +887,8 @@ gtk_layout_expose_predicate (Display *display,
return False;
}
+#endif /* X11 */
+
/* This is the main routine to do the scrolling. Scrolling is
* done by "Guffaw" scrolling, as in the Mozilla XFE, with
* a few modifications.
@@ -915,8 +920,9 @@ gtk_layout_adjustment_changed (GtkAdjustment *adjustment,
GtkLayout *layout)
{
GtkWidget *widget;
+#if GDK_WINDOWING == GDK_WINDOWING_X11
XEvent xevent;
-
+#endif
gint dx, dy;
widget = GTK_WIDGET (layout);
@@ -1049,6 +1055,8 @@ gtk_layout_adjustment_changed (GtkAdjustment *adjustment,
*/
gdk_flush();
+
+#if GDK_WINDOWING == GDK_WINDOWING_X11
while (XCheckIfEvent(GDK_WINDOW_XDISPLAY (layout->bin_window),
&xevent,
gtk_layout_expose_predicate,
@@ -1082,6 +1090,9 @@ gtk_layout_adjustment_changed (GtkAdjustment *adjustment,
}
}
}
+#elif GDK_WINDOWING == GDK_WINDOWING_WIN32
+ /* XXX Not implemented */
+#endif
}
/* The main event filter. Actually, we probably don't really need
@@ -1099,6 +1110,8 @@ gtk_layout_filter (GdkXEvent *gdk_xevent,
GdkEvent *event,
gpointer data)
{
+#if GDK_WINDOWING == GDK_WINDOWING_X11
+
XEvent *xevent;
GtkLayout *layout;
@@ -1131,6 +1144,9 @@ gtk_layout_filter (GdkXEvent *gdk_xevent,
}
break;
}
+#elif GDK_WINDOWING == GDK_WINDOWING_WIN32
+ /* XXX Not implemented */
+#endif
return GDK_FILTER_CONTINUE;
}
@@ -1144,6 +1160,7 @@ gtk_layout_main_filter (GdkXEvent *gdk_xevent,
GdkEvent *event,
gpointer data)
{
+#if GDK_WINDOWING == GDK_WINDOWING_X11
XEvent *xevent;
GtkLayout *layout;
@@ -1169,7 +1186,9 @@ gtk_layout_main_filter (GdkXEvent *gdk_xevent,
return GDK_FILTER_REMOVE;
}
-
+#elif GDK_WINDOWING == GDK_WINDOWING_WIN32
+ /* XXX Not implemented */
+#endif
return GDK_FILTER_CONTINUE;
}