124 lines
3.1 KiB
Diff
124 lines
3.1 KiB
Diff
|
--- gtk+-2.8.13/gdk-pixbuf/gdk-pixbuf-io.c~ 2005-10-03 17:11:49.000000000 +0200
|
||
|
+++ gtk+-2.8.13/gdk-pixbuf/gdk-pixbuf-io.c 2006-03-01 20:33:36.524552192 +0100
|
||
|
@@ -32,6 +32,7 @@
|
||
|
#ifdef HAVE_UNISTD_H
|
||
|
#include <unistd.h>
|
||
|
#endif
|
||
|
+#include <sys/utsname.h>
|
||
|
|
||
|
#include "gdk-pixbuf-private.h"
|
||
|
#include "gdk-pixbuf-io.h"
|
||
|
@@ -276,8 +277,21 @@
|
||
|
gchar *result = g_strdup (g_getenv ("GDK_PIXBUF_MODULE_FILE"));
|
||
|
|
||
|
if (!result)
|
||
|
- result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gdk-pixbuf.loaders", NULL);
|
||
|
+#if defined(__linux__) && defined (__i386__)
|
||
|
+ {
|
||
|
+ struct utsname uts;
|
||
|
|
||
|
+ uname(&uts);
|
||
|
+ result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gdk-pixbuf.loaders.32", NULL);
|
||
|
+ if (strcmp("x86_64", uts.machine) || access(result, R_OK))
|
||
|
+ {
|
||
|
+ g_free(result);
|
||
|
+ result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gdk-pixbuf.loaders", NULL);
|
||
|
+ }
|
||
|
+ }
|
||
|
+#else
|
||
|
+ result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gdk-pixbuf.loaders", NULL);
|
||
|
+#endif
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
--- gtk+-2.8.13/gtk/gtkprivate.h~ 2005-03-22 03:14:55.000000000 +0100
|
||
|
+++ gtk+-2.8.13/gtk/gtkprivate.h 2006-03-01 19:51:42.510740384 +0100
|
||
|
@@ -96,6 +96,13 @@
|
||
|
|
||
|
#endif /* G_OS_WIN32 */
|
||
|
|
||
|
+#if defined(__linux__) && defined (__i386__)
|
||
|
+const gchar *_gtk_get_libdir ();
|
||
|
+
|
||
|
+#undef GTK_LIBDIR
|
||
|
+#define GTK_LIBDIR _gtk_get_libdir ()
|
||
|
+#endif
|
||
|
+
|
||
|
gboolean _gtk_fnmatch (const char *pattern,
|
||
|
const char *string,
|
||
|
gboolean no_leading_period);
|
||
|
--- gtk+-2.8.13/gtk/gtkmain.c~ 2005-12-06 17:14:30.000000000 +0100
|
||
|
+++ gtk+-2.8.13/gtk/gtkmain.c 2006-03-01 20:36:05.175953744 +0100
|
||
|
@@ -42,6 +42,7 @@
|
||
|
#include <unistd.h>
|
||
|
#endif
|
||
|
#include <sys/types.h> /* For uid_t, gid_t */
|
||
|
+#include <sys/utsname.h>
|
||
|
|
||
|
#ifdef G_OS_WIN32
|
||
|
#define STRICT
|
||
|
@@ -336,6 +337,28 @@
|
||
|
|
||
|
#endif /* G_OS_WIN32 */
|
||
|
|
||
|
+#if defined(__linux__) && defined (__i386__)
|
||
|
+const gchar *
|
||
|
+_gtk_get_libdir (void)
|
||
|
+{
|
||
|
+ static char *gtk_libdir = NULL;
|
||
|
+ if (gtk_libdir == NULL)
|
||
|
+ {
|
||
|
+#if defined(__linux__) && defined (__i386__)
|
||
|
+ struct utsname uts;
|
||
|
+
|
||
|
+ uname(&uts);
|
||
|
+ if (!strcmp("x86_64", uts.machine)
|
||
|
+ && !access("/usr/lib32/gtk-2.0", R_OK|X_OK))
|
||
|
+ gtk_libdir = "/usr/lib32";
|
||
|
+ else
|
||
|
+#endif
|
||
|
+ gtk_libdir = "/usr/lib";
|
||
|
+ }
|
||
|
+ return gtk_libdir;
|
||
|
+}
|
||
|
+#endif
|
||
|
+
|
||
|
static gboolean do_setlocale = TRUE;
|
||
|
|
||
|
/**
|
||
|
--- gtk+-2.8.13/gtk/gtkrc.c~ 2005-11-23 15:24:51.000000000 +0100
|
||
|
+++ gtk+-2.8.13/gtk/gtkrc.c 2006-03-01 20:33:25.952159440 +0100
|
||
|
@@ -38,6 +38,10 @@
|
||
|
#include <string.h>
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
+#ifdef HAVE_UNISTD_H
|
||
|
+#include <unistd.h>
|
||
|
+#endif
|
||
|
+#include <sys/utsname.h>
|
||
|
|
||
|
|
||
|
#include <glib.h>
|
||
|
@@ -364,7 +368,21 @@
|
||
|
if (im_module_file)
|
||
|
result = g_strdup (im_module_file);
|
||
|
else
|
||
|
+#if defined(__linux__) && defined (__i386__)
|
||
|
+ {
|
||
|
+ struct utsname uts;
|
||
|
+
|
||
|
+ uname(&uts);
|
||
|
+ result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gtk.immodules.32", NULL);
|
||
|
+ if (strcmp("x86_64", uts.machine) || access(result, R_OK))
|
||
|
+ {
|
||
|
+ g_free(result);
|
||
|
+ result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gtk.immodules", NULL);
|
||
|
+ }
|
||
|
+ }
|
||
|
+#else
|
||
|
result = g_build_filename (GTK_SYSCONFDIR, "gtk-2.0", "gtk.immodules", NULL);
|
||
|
+#endif
|
||
|
}
|
||
|
|
||
|
return result;
|