summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSoeren Sandmann <sandmann@daimi.au.dk>2004-04-18 15:10:59 +0000
committerSøren Sandmann Pedersen <ssp@src.gnome.org>2004-04-18 15:10:59 +0000
commit8340991b7dea294914db32add3edc5fba68223b8 (patch)
treeaf84304807b09f37b40b1f40149a36df170fa3f6
parent79bc80feabe0f093a1b5a1a446346de52e2ae675 (diff)
downloadgtk+-8340991b7dea294914db32add3edc5fba68223b8.tar.gz
Make gdk_keymap_translate_keyboard_state() handle NULL keymaps. (#139715,
Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk> * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make gdk_keymap_translate_keyboard_state() handle NULL keymaps. (#139715, Torsten Schoenfeld).
-rw-r--r--ChangeLog6
-rw-r--r--ChangeLog.pre-2-106
-rw-r--r--ChangeLog.pre-2-46
-rw-r--r--ChangeLog.pre-2-66
-rw-r--r--ChangeLog.pre-2-86
-rw-r--r--gdk/x11/gdkkeys-x11.c55
6 files changed, 53 insertions, 32 deletions
diff --git a/ChangeLog b/ChangeLog
index 0ed78e277a..dbd574a564 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk>
+
+ * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make
+ gdk_keymap_translate_keyboard_state() handle NULL
+ keymaps. (#139715, Torsten Schoenfeld).
+
Sun Apr 18 16:59:21 2004 Soeren Sandmann <sandmann@daimi.au.dk>
* configure.in: Don't erase GDK_EXTRA_CFLAGS. Fixes bug 139586,
diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10
index 0ed78e277a..dbd574a564 100644
--- a/ChangeLog.pre-2-10
+++ b/ChangeLog.pre-2-10
@@ -1,3 +1,9 @@
+Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk>
+
+ * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make
+ gdk_keymap_translate_keyboard_state() handle NULL
+ keymaps. (#139715, Torsten Schoenfeld).
+
Sun Apr 18 16:59:21 2004 Soeren Sandmann <sandmann@daimi.au.dk>
* configure.in: Don't erase GDK_EXTRA_CFLAGS. Fixes bug 139586,
diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4
index 0ed78e277a..dbd574a564 100644
--- a/ChangeLog.pre-2-4
+++ b/ChangeLog.pre-2-4
@@ -1,3 +1,9 @@
+Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk>
+
+ * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make
+ gdk_keymap_translate_keyboard_state() handle NULL
+ keymaps. (#139715, Torsten Schoenfeld).
+
Sun Apr 18 16:59:21 2004 Soeren Sandmann <sandmann@daimi.au.dk>
* configure.in: Don't erase GDK_EXTRA_CFLAGS. Fixes bug 139586,
diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6
index 0ed78e277a..dbd574a564 100644
--- a/ChangeLog.pre-2-6
+++ b/ChangeLog.pre-2-6
@@ -1,3 +1,9 @@
+Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk>
+
+ * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make
+ gdk_keymap_translate_keyboard_state() handle NULL
+ keymaps. (#139715, Torsten Schoenfeld).
+
Sun Apr 18 16:59:21 2004 Soeren Sandmann <sandmann@daimi.au.dk>
* configure.in: Don't erase GDK_EXTRA_CFLAGS. Fixes bug 139586,
diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8
index 0ed78e277a..dbd574a564 100644
--- a/ChangeLog.pre-2-8
+++ b/ChangeLog.pre-2-8
@@ -1,3 +1,9 @@
+Sun Apr 18 17:06:03 2004 Soeren Sandmann <sandmann@daimi.au.dk>
+
+ * gdk/x11/gdkkeys-x11.c (get_effective_keymap): Make
+ gdk_keymap_translate_keyboard_state() handle NULL
+ keymaps. (#139715, Torsten Schoenfeld).
+
Sun Apr 18 16:59:21 2004 Soeren Sandmann <sandmann@daimi.au.dk>
* configure.in: Don't erase GDK_EXTRA_CFLAGS. Fixes bug 139586,
diff --git a/gdk/x11/gdkkeys-x11.c b/gdk/x11/gdkkeys-x11.c
index b369b89beb..2729dd3966 100644
--- a/gdk/x11/gdkkeys-x11.c
+++ b/gdk/x11/gdkkeys-x11.c
@@ -378,6 +378,23 @@ get_keymap (GdkKeymapX11 *keymap_x11)
return keymap_x11->keymap;
}
+#define GET_EFFECTIVE_KEYMAP(keymap) get_effective_keymap ((keymap), G_STRFUNC)
+
+GdkKeymap *
+get_effective_keymap (GdkKeymap *keymap,
+ const char *function)
+{
+ if (!keymap)
+ {
+ GDK_NOTE (MULTIHEAD,
+ g_message ("reverting to default display keymap in %s",
+ function));
+ return gdk_keymap_get_default ();
+ }
+
+ return keymap;
+}
+
#if HAVE_XKB
static PangoDirection
get_direction (GdkKeymapX11 *keymap_x11)
@@ -444,13 +461,7 @@ _gdk_keymap_keys_changed (GdkDisplay *display)
PangoDirection
gdk_keymap_get_direction (GdkKeymap *keymap)
{
- if (!keymap)
- {
- keymap = gdk_keymap_get_for_display (gdk_display_get_default ());
- GDK_NOTE (MULTIHEAD,
- g_message ("_multihead : reverting to default display keymap "
- "in gdk_keymap_get_direction"));
- }
+ keymap = GET_EFFECTIVE_KEYMAP (keymap);
#if HAVE_XKB
if (KEYMAP_USE_XKB (keymap))
@@ -505,14 +516,7 @@ gdk_keymap_get_entries_for_keyval (GdkKeymap *keymap,
g_return_val_if_fail (n_keys != NULL, FALSE);
g_return_val_if_fail (keyval != 0, FALSE);
- if (!keymap)
- {
- keymap = gdk_keymap_get_for_display (gdk_display_get_default ());
- GDK_NOTE (MULTIHEAD,
- g_message ("_multihead : reverting to default display keymap "
- "in gdk_keymap_get_entries_for_keyval\n"));
- }
-
+ keymap = GET_EFFECTIVE_KEYMAP (keymap);
keymap_x11 = GDK_KEYMAP_X11 (keymap);
retval = g_array_new (FALSE, FALSE, sizeof (GdkKeymapKey));
@@ -659,14 +663,7 @@ gdk_keymap_get_entries_for_keycode (GdkKeymap *keymap,
g_return_val_if_fail (keymap == NULL || GDK_IS_KEYMAP (keymap), FALSE);
g_return_val_if_fail (n_entries != NULL, FALSE);
- if (!keymap)
- {
- keymap = gdk_keymap_get_for_display (gdk_display_get_default ());
- GDK_NOTE (MULTIHEAD,
- g_message ("_multihead : reverting to default display keymap "
- "in gdk_keymap_get_entries_for_keycode\n"));
- }
-
+ keymap = GET_EFFECTIVE_KEYMAP (keymap);
keymap_x11 = GDK_KEYMAP_X11 (keymap);
update_keyrange (keymap_x11);
@@ -832,15 +829,8 @@ gdk_keymap_lookup_key (GdkKeymap *keymap,
g_return_val_if_fail (keymap == NULL || GDK_IS_KEYMAP (keymap), 0);
g_return_val_if_fail (key != NULL, 0);
g_return_val_if_fail (key->group < 4, 0);
-
- if (!keymap)
- {
- keymap = gdk_keymap_get_for_display (gdk_display_get_default ());
- GDK_NOTE (MULTIHEAD,
- g_message ("_multihead : reverting to default display keymap "
- "in gdk_keymap_lookup_key\n"));
- }
+ keymap = GET_EFFECTIVE_KEYMAP (keymap);
keymap_x11 = GDK_KEYMAP_X11 (keymap);
#ifdef HAVE_XKB
@@ -1165,7 +1155,8 @@ gdk_keymap_translate_keyboard_state (GdkKeymap *keymap,
g_return_val_if_fail (keymap == NULL || GDK_IS_KEYMAP (keymap), FALSE);
g_return_val_if_fail (group < 4, FALSE);
-
+
+ keymap = GET_EFFECTIVE_KEYMAP (keymap);
keymap_x11 = GDK_KEYMAP_X11 (keymap);
if (keyval)