wok-next rev 6394

Bumped some packages by adding a empty line. Added a patch to lxpanel to fix failure to react to keyboard map changes. Added DEPENDS to BUILD_DEPENDS of gnome-mplayer.
author Christopher Rogers <slaxemulator@gmail.com>
date Fri Sep 24 04:32:19 2010 +0000 (2010-09-24)
parents 89382e31e2cd
children 36a0e1608714
files cdrdao-utils/receipt cdrdao/receipt gnome-mplayer/receipt grsync/receipt gtk+/receipt lxpanel/receipt lxpanel/stuff/Fix-failure-to-react-to-keyboard-map-changes-initiat.patch
line diff
     1.1 --- a/cdrdao-utils/receipt	Fri Sep 24 02:27:38 2010 +0000
     1.2 +++ b/cdrdao-utils/receipt	Fri Sep 24 04:32:19 2010 +0000
     1.3 @@ -14,6 +14,5 @@
     1.4  {
     1.5  	mkdir -p $fs/usr/bin
     1.6  	cp -a $_pkg/usr/bin/ $fs/usr
     1.7 -	rm $fs/usr/bin/cdrdao	
     1.8 -
     1.9 +	rm $fs/usr/bin/cdrdao
    1.10  }
     2.1 --- a/cdrdao/receipt	Fri Sep 24 02:27:38 2010 +0000
     2.2 +++ b/cdrdao/receipt	Fri Sep 24 04:32:19 2010 +0000
     2.3 @@ -36,5 +36,4 @@
     2.4  	mkdir -p $fs/usr/bin
     2.5  	cp -a $_pkg/usr/bin/cdrdao $fs/usr/bin
     2.6  	cp -a $_pkg/usr/share $fs/usr
     2.7 -
     2.8  }
     3.1 --- a/gnome-mplayer/receipt	Fri Sep 24 02:27:38 2010 +0000
     3.2 +++ b/gnome-mplayer/receipt	Fri Sep 24 04:32:19 2010 +0000
     3.3 @@ -5,8 +5,8 @@
     3.4  CATEGORY="multimedia"
     3.5  SHORT_DESC="simple MPlayer GUI"
     3.6  MAINTAINER="jozee@slitaz.org"
     3.7 -DEPENDS="mplayer dbus-glib libnotify alsa-lib libgpod"
     3.8 -BUILD_DEPENDS="mplayer dbus-dev dbus-glib-dev libnotify libnotify-dev libgpod libgpod-dev pkg-config xorg-libX11-dev libxcb-dev gtk+-dev xorg-libXss-dev"
     3.9 +DEPENDS="mplayer gtk+ dbus-glib libnotify alsa-lib libgpod"
    3.10 +BUILD_DEPENDS="$DEPENDS dbus-dev dbus-glib-dev libnotify-dev libgpod-dev pkg-config xorg-libX11-dev libxcb-dev gtk+-dev xorg-libXss-dev"
    3.11  SUGGESTED="libgpod"
    3.12  TARBALL="$PACKAGE-$VERSION.tar.gz"
    3.13  WEB_SITE="http://gnome-mplayer.googlecode.com/" 
     4.1 --- a/grsync/receipt	Fri Sep 24 02:27:38 2010 +0000
     4.2 +++ b/grsync/receipt	Fri Sep 24 04:32:19 2010 +0000
     4.3 @@ -34,3 +34,4 @@
     4.4      	sed -i s'|#!/bin/bash|#!/bin/sh|' $fs/usr/bin/grsync-batch
     4.5  	chmod +x $fs/usr/bin/*
     4.6  }
     4.7 +
     5.1 --- a/gtk+/receipt	Fri Sep 24 02:27:38 2010 +0000
     5.2 +++ b/gtk+/receipt	Fri Sep 24 04:32:19 2010 +0000
     5.3 @@ -76,3 +76,4 @@
     5.4  		rm -rf $1/usr/lib/gtk-2.0/2.4.0
     5.5  	fi
     5.6  }
     5.7 +
     6.1 --- a/lxpanel/receipt	Fri Sep 24 02:27:38 2010 +0000
     6.2 +++ b/lxpanel/receipt	Fri Sep 24 04:32:19 2010 +0000
     6.3 @@ -19,6 +19,7 @@
     6.4  compile_rules()
     6.5  {
     6.6  	cd $src
     6.7 +	patch -p1 -i ../stuff/Fix-failure-to-react-to-keyboard-map-changes-initiat.patch
     6.8  	./configure \
     6.9  		--prefix=/usr \
    6.10  		--sysconfdir=/etc \
     7.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     7.2 +++ b/lxpanel/stuff/Fix-failure-to-react-to-keyboard-map-changes-initiat.patch	Fri Sep 24 04:32:19 2010 +0000
     7.3 @@ -0,0 +1,555 @@
     7.4 +From 438d9fdbd3e0be04de933705917d508a02b7c04b Mon Sep 17 00:00:00 2001
     7.5 +From: Marty Jack <martyj@linux.local>
     7.6 +Date: Sat, 20 Feb 2010 16:23:57 -0500
     7.7 +Subject: [PATCH 4/5] Fix failure to react to keyboard map changes initiated outside the plugin
     7.8 + - Occurred when setxkbmap was run, or when HAL configured the keyboard at X startup
     7.9 + - Caused by failure to process the NewKeyboard event
    7.10 + - Caused by dropping events due to faulty code to read them
    7.11 + - Cosmetic change, the tooltip now the Xkb Group name rather than Xkb Symbol name
    7.12 +
    7.13 +---
    7.14 + src/plugins/xkb/xkb-plugin.c |   92 +++++++++--------
    7.15 + src/plugins/xkb/xkb.c        |  236 +++++++++++++++++++++--------------------
    7.16 + src/plugins/xkb/xkb.h        |    7 +-
    7.17 + 3 files changed, 173 insertions(+), 162 deletions(-)
    7.18 +
    7.19 +diff --git a/src/plugins/xkb/xkb-plugin.c b/src/plugins/xkb/xkb-plugin.c
    7.20 +index f49a77d..80a14ba 100644
    7.21 +--- a/src/plugins/xkb/xkb-plugin.c
    7.22 ++++ b/src/plugins/xkb/xkb-plugin.c
    7.23 +@@ -1,18 +1,23 @@
    7.24 +-/*
    7.25 +-//====================================================================
    7.26 +-//  xfce4-xkb-plugin - XFCE4 Xkb Layout Indicator panel plugin
    7.27 +-// -------------------------------------------------------------------
    7.28 +-//  Alexander Iliev <sasoiliev@mamul.org>
    7.29 +-//  20-Feb-04
    7.30 +-// -------------------------------------------------------------------
    7.31 +-//  Parts of this code belong to Michael Glickman <wmalms@yahooo.com>
    7.32 +-//  and his program wmxkb.
    7.33 +-//  WARNING: DO NOT BOTHER Michael Glickman WITH QUESTIONS ABOUT THIS
    7.34 +-//           PROGRAM!!! SEND INSTEAD EMAILS TO <sasoiliev@mamul.org>
    7.35 +-//====================================================================
    7.36 +-*/
    7.37 +-
    7.38 +-/* Modified by Hong Jen Yee (PCMan) <pcman.tw@gmail.com> on 2008-04-06 for lxpanel */
    7.39 ++/**
    7.40 ++ * Copyright (c) 2010 LxDE Developers, see the file AUTHORS for details.
    7.41 ++ *
    7.42 ++ * This program is free software; you can redistribute it and/or modify
    7.43 ++ * it under the terms of the GNU General Public License as published by
    7.44 ++ * the Free Software Foundation; either version 2 of the License, or
    7.45 ++ * (at your option) any later version.
    7.46 ++ *
    7.47 ++ * This program is distributed in the hope that it will be useful,
    7.48 ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
    7.49 ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    7.50 ++ * GNU General Public License for more details.
    7.51 ++ *
    7.52 ++ * You should have received a copy of the GNU General Public License
    7.53 ++ * along with this program; if not, write to the Free Software Foundation,
    7.54 ++ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
    7.55 ++ */
    7.56 ++
    7.57 ++/* Originally derived from xfce4-xkb-plugin, Copyright 2004 Alexander Iliev,
    7.58 ++ * which credits Michael Glickman. */
    7.59 + 
    7.60 + #ifdef HAVE_CONFIG_H
    7.61 + #include <config.h>
    7.62 +@@ -49,38 +54,45 @@ void xkb_redraw(XkbPlugin * xkb)
    7.63 +     if (xkb->display_type == IMAGE)
    7.64 +     {
    7.65 +         int size = xkb->plugin->panel->icon_size;
    7.66 +-        char * group_name = (char *) xkb_get_current_group_name_lowercase(xkb);
    7.67 +-        char * filename = g_strdup_printf("%s/%s.png", FLAGSDIR, group_name);
    7.68 +-        GdkPixbuf * unscaled_pixbuf = gdk_pixbuf_new_from_file(filename, NULL);
    7.69 +-        g_free(filename);
    7.70 +-        g_free(group_name);
    7.71 +-
    7.72 +-        if (unscaled_pixbuf != NULL)
    7.73 ++        char * group_name = (char *) xkb_get_current_symbol_name_lowercase(xkb);
    7.74 ++        if (group_name != NULL)
    7.75 +         {
    7.76 +-            /* Loaded successfully. */
    7.77 +-            int width = gdk_pixbuf_get_width(unscaled_pixbuf);
    7.78 +-            int height = gdk_pixbuf_get_height(unscaled_pixbuf);
    7.79 +-            GdkPixbuf * pixbuf = gdk_pixbuf_scale_simple(unscaled_pixbuf, size * width / height, size, GDK_INTERP_BILINEAR);
    7.80 +-            if (pixbuf != NULL)
    7.81 ++            char * filename = g_strdup_printf("%s/%s.png", FLAGSDIR, group_name);
    7.82 ++            GdkPixbuf * unscaled_pixbuf = gdk_pixbuf_new_from_file(filename, NULL);
    7.83 ++            g_free(filename);
    7.84 ++            g_free(group_name);
    7.85 ++
    7.86 ++            if (unscaled_pixbuf != NULL)
    7.87 +             {
    7.88 +-                gtk_image_set_from_pixbuf(GTK_IMAGE(xkb->image), pixbuf);
    7.89 +-                g_object_unref(G_OBJECT(pixbuf));
    7.90 +-                gtk_widget_hide(xkb->label);
    7.91 +-                gtk_widget_show(xkb->image);
    7.92 +-                gtk_widget_set_tooltip_text(xkb->btn, xkb_get_current_group_name(xkb));
    7.93 +-                valid_image = TRUE;
    7.94 ++                /* Loaded successfully. */
    7.95 ++                int width = gdk_pixbuf_get_width(unscaled_pixbuf);
    7.96 ++                int height = gdk_pixbuf_get_height(unscaled_pixbuf);
    7.97 ++                GdkPixbuf * pixbuf = gdk_pixbuf_scale_simple(unscaled_pixbuf, size * width / height, size, GDK_INTERP_BILINEAR);
    7.98 ++                if (pixbuf != NULL)
    7.99 ++                {
   7.100 ++                    gtk_image_set_from_pixbuf(GTK_IMAGE(xkb->image), pixbuf);
   7.101 ++                    g_object_unref(G_OBJECT(pixbuf));
   7.102 ++                    gtk_widget_hide(xkb->label);
   7.103 ++                    gtk_widget_show(xkb->image);
   7.104 ++                    gtk_widget_set_tooltip_text(xkb->btn, xkb_get_current_group_name(xkb));
   7.105 ++                    valid_image = TRUE;
   7.106 ++                }
   7.107 ++                g_object_unref(unscaled_pixbuf);
   7.108 +             }
   7.109 +-            g_object_unref(unscaled_pixbuf);
   7.110 +         }
   7.111 +     }
   7.112 + 
   7.113 +     /* Set the label. */
   7.114 +     if ((xkb->display_type == TEXT) || ( ! valid_image))
   7.115 +     {
   7.116 +-        panel_draw_label_text(xkb->plugin->panel, xkb->label, (char *) xkb_get_current_group_name(xkb), TRUE, TRUE);
   7.117 +-        gtk_widget_hide(xkb->image);
   7.118 +-        gtk_widget_show(xkb->label);
   7.119 +-        gtk_widget_set_tooltip_text(xkb->btn, NULL);
   7.120 ++        char * group_name = (char *) xkb_get_current_symbol_name(xkb);
   7.121 ++        if (group_name != NULL)
   7.122 ++        {
   7.123 ++            panel_draw_label_text(xkb->plugin->panel, xkb->label, (char *) group_name, TRUE, TRUE);
   7.124 ++            gtk_widget_hide(xkb->image);
   7.125 ++            gtk_widget_show(xkb->label);
   7.126 ++            gtk_widget_set_tooltip_text(xkb->btn, xkb_get_current_group_name(xkb));
   7.127 ++        }
   7.128 +     }
   7.129 + }
   7.130 + 
   7.131 +@@ -196,10 +208,6 @@ static int xkb_constructor(Plugin * plugin, char ** fp)
   7.132 +     /* Initialize the XKB interface. */
   7.133 +     xkb_mechanism_constructor(xkb);
   7.134 + 
   7.135 +-    /* Initialize a channel to listen for XKB events. */
   7.136 +-    GIOChannel * channel = g_io_channel_unix_new(xkb_get_connection_number(xkb));
   7.137 +-    xkb->source_id = g_io_add_watch(channel, G_IO_IN | G_IO_PRI, (GIOFunc) xkb_gio_callback, (gpointer) xkb);
   7.138 +-
   7.139 +     /* Connect signals. */
   7.140 +     g_signal_connect(xkb->btn, "button-press-event", G_CALLBACK(xkb_button_press_event), xkb);
   7.141 +     g_signal_connect(xkb->btn, "scroll-event", G_CALLBACK(xkb_scroll_event), xkb);
   7.142 +diff --git a/src/plugins/xkb/xkb.c b/src/plugins/xkb/xkb.c
   7.143 +index 5bb0c39..898a931 100644
   7.144 +--- a/src/plugins/xkb/xkb.c
   7.145 ++++ b/src/plugins/xkb/xkb.c
   7.146 +@@ -1,18 +1,23 @@
   7.147 +-/*
   7.148 +-// ====================================================================
   7.149 +-//  xfce4-xkb-plugin - XFCE4 Xkb Layout Indicator panel plugin
   7.150 +-// -------------------------------------------------------------------
   7.151 +-//  Alexander Iliev <sasoiliev@mamul.org>
   7.152 +-//  20-Feb-04
   7.153 +-// -------------------------------------------------------------------
   7.154 +-//  Parts of this code belong to Michael Glickman <wmalms@yahooo.com>
   7.155 +-//  and his program wmxkb.
   7.156 +-//  WARNING: DO NOT BOTHER Michael Glickman WITH QUESTIONS ABOUT THIS
   7.157 +-//           PROGRAM!!! SEND INSTEAD EMAILS TO <sasoiliev@mamul.org>
   7.158 +-//====================================================================
   7.159 +-*/
   7.160 +-
   7.161 +-/* Modified by Hong Jen Yee (PCMan) <pcman.tw@gmail.com> on 2008-04-06 for lxpanel */
   7.162 ++/**
   7.163 ++ * Copyright (c) 2010 LxDE Developers, see the file AUTHORS for details.
   7.164 ++ *
   7.165 ++ * This program is free software; you can redistribute it and/or modify
   7.166 ++ * it under the terms of the GNU General Public License as published by
   7.167 ++ * the Free Software Foundation; either version 2 of the License, or
   7.168 ++ * (at your option) any later version.
   7.169 ++ *
   7.170 ++ * This program is distributed in the hope that it will be useful,
   7.171 ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   7.172 ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   7.173 ++ * GNU General Public License for more details.
   7.174 ++ *
   7.175 ++ * You should have received a copy of the GNU General Public License
   7.176 ++ * along with this program; if not, write to the Free Software Foundation,
   7.177 ++ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
   7.178 ++ */
   7.179 ++
   7.180 ++/* Originally derived from xfce4-xkb-plugin, Copyright 2004 Alexander Iliev,
   7.181 ++ * which credits Michael Glickman. */
   7.182 + 
   7.183 + #include "xkb.h"
   7.184 + 
   7.185 +@@ -26,9 +31,13 @@
   7.186 + #include <gdk-pixbuf/gdk-pixbuf.h>
   7.187 + #include <glib.h>
   7.188 + 
   7.189 ++/* The X Keyboard Extension: Library Specification
   7.190 ++ * http://www.xfree86.org/current/XKBlib.pdf */
   7.191 ++
   7.192 + static void xkb_enter_locale_by_process(XkbPlugin * xkb);
   7.193 + static void refresh_group_xkb(XkbPlugin * xkb);
   7.194 +-static int do_init_xkb(XkbPlugin * xkb);
   7.195 ++static int initialize_keyboard_description(XkbPlugin * xkb);
   7.196 ++static GdkFilterReturn xkb_event_filter(GdkXEvent * xevent, GdkEvent * event, XkbPlugin * xkb);
   7.197 + 
   7.198 + /* Insert a process and its layout into the hash table. */
   7.199 + static void xkb_enter_locale_by_process(XkbPlugin * xkb)
   7.200 +@@ -56,60 +65,65 @@ int xkb_get_group_count(XkbPlugin * xkb)
   7.201 +   return xkb->group_count;
   7.202 + }
   7.203 + 
   7.204 ++/* Get the current group name. */
   7.205 ++const char * xkb_get_current_group_name(XkbPlugin * xkb) 
   7.206 ++{
   7.207 ++    return xkb->group_names[xkb->current_group_xkb_no];
   7.208 ++}
   7.209 ++
   7.210 + /* Convert a group number to a symbol name. */
   7.211 + const char * xkb_get_symbol_name_by_res_no(XkbPlugin * xkb, int n) 
   7.212 + {
   7.213 +     return xkb->symbol_names[n];
   7.214 + }
   7.215 + 
   7.216 +-/* Get the current group name. */
   7.217 +-const char * xkb_get_current_group_name(XkbPlugin * xkb) 
   7.218 ++/* Get the current symbol name. */
   7.219 ++const char * xkb_get_current_symbol_name(XkbPlugin * xkb) 
   7.220 + {
   7.221 +     return xkb_get_symbol_name_by_res_no(xkb, xkb->current_group_xkb_no);
   7.222 + }
   7.223 + 
   7.224 +-/* Get the current group name converted to lowercase. */
   7.225 +-const char * xkb_get_current_group_name_lowercase(XkbPlugin * xkb) 
   7.226 ++/* Get the current symbol name converted to lowercase. */
   7.227 ++const char * xkb_get_current_symbol_name_lowercase(XkbPlugin * xkb) 
   7.228 + {
   7.229 +-    const char * tmp = xkb_get_current_group_name(xkb);
   7.230 +-    return g_utf8_strdown(tmp, -1);
   7.231 ++    const char * tmp = xkb_get_current_symbol_name(xkb);
   7.232 ++    return ((tmp != NULL) ? g_utf8_strdown(tmp, -1) : NULL);
   7.233 + }
   7.234 + 
   7.235 + /* Refresh current group number from Xkb state. */
   7.236 + static void refresh_group_xkb(XkbPlugin * xkb) 
   7.237 + {
   7.238 +     XkbStateRec xkb_state;
   7.239 +-    XkbGetState(xkb->dsp, xkb->device_id, &xkb_state);
   7.240 ++    XkbGetState(GDK_DISPLAY(), XkbUseCoreKbd, &xkb_state);
   7.241 +     xkb->current_group_xkb_no = xkb_state.group;
   7.242 + }
   7.243 + 
   7.244 +-/* Initialize the Xkb structures. */
   7.245 +-static int do_init_xkb(XkbPlugin * xkb) 
   7.246 ++/* Initialize the keyboard description initially or after a NewKeyboard event. */
   7.247 ++static int initialize_keyboard_description(XkbPlugin * xkb)
   7.248 + {
   7.249 +-    /* Create hash table. */
   7.250 +-    xkb->group_hash_table = g_hash_table_new(g_direct_hash, NULL);
   7.251 +-
   7.252 +-    /* Initialize the Xkb extension. */
   7.253 +-    int major, minor, opcode;
   7.254 +-    Bool status = XkbQueryExtension(xkb->dsp, &opcode,
   7.255 +-        &xkb->base_event_code, &xkb->base_error_code, &major, &minor);
   7.256 +-
   7.257 +-    /* Use the core keyboard. */
   7.258 +-    xkb->device_id = XkbUseCoreKbd;
   7.259 ++    /* Free the strings. */
   7.260 ++    int i;
   7.261 ++    for (i = 0; i < XkbNumKbdGroups; i += 1)
   7.262 ++    {
   7.263 ++        g_free(xkb->group_names[i]);
   7.264 ++        g_free(xkb->symbol_names[i]);
   7.265 ++        xkb->group_names[i] = NULL;
   7.266 ++        xkb->symbol_names[i] = NULL;
   7.267 ++    }
   7.268 + 
   7.269 +     /* Allocate a keyboard description structure. */
   7.270 ++    int status = False;
   7.271 +     XkbDescRec * kbd_desc_ptr = XkbAllocKeyboard();
   7.272 +     if (kbd_desc_ptr == NULL)
   7.273 +     {
   7.274 +         ERR("Failed to get keyboard description\n");
   7.275 +         goto HastaLaVista;
   7.276 +     }
   7.277 +-    kbd_desc_ptr->dpy = xkb->dsp;
   7.278 + 
   7.279 +     /* Fetch information into the keyboard description. */
   7.280 +-    XkbGetControls(xkb->dsp, XkbAllControlsMask, kbd_desc_ptr);
   7.281 +-    XkbGetNames(xkb->dsp, XkbSymbolsNameMask, kbd_desc_ptr);
   7.282 +-    XkbGetNames(xkb->dsp, XkbGroupNamesMask, kbd_desc_ptr);
   7.283 ++    XkbGetControls(GDK_DISPLAY(), XkbAllControlsMask, kbd_desc_ptr);
   7.284 ++    XkbGetNames(GDK_DISPLAY(), XkbSymbolsNameMask, kbd_desc_ptr);
   7.285 ++    XkbGetNames(GDK_DISPLAY(), XkbGroupNamesMask, kbd_desc_ptr);
   7.286 + 
   7.287 +     if (kbd_desc_ptr->names == NULL)
   7.288 +     {
   7.289 +@@ -137,12 +151,11 @@ static int do_init_xkb(XkbPlugin * xkb)
   7.290 + 
   7.291 +     /* Determine the group names.  Trim off text beginning at a '('. */
   7.292 +     const Atom * tmp_group_source = kbd_desc_ptr->names->groups;
   7.293 +-    int i;
   7.294 +     for (i = 0; i < xkb->group_count; i++)
   7.295 +     {
   7.296 +         if (tmp_group_source[i] != None)
   7.297 +         {
   7.298 +-            char * ptr = XGetAtomName(xkb->dsp, tmp_group_source[i]);
   7.299 ++            char * ptr = XGetAtomName(GDK_DISPLAY(), tmp_group_source[i]);
   7.300 +             xkb->group_names[i] = ptr;
   7.301 +             if ((ptr != NULL) && ((ptr = strchr(ptr, '('))) != NULL)
   7.302 +                 *ptr = '\0';
   7.303 +@@ -153,7 +166,7 @@ static int do_init_xkb(XkbPlugin * xkb)
   7.304 +     Atom sym_name_atom = kbd_desc_ptr->names->symbols;
   7.305 +     char * sym_name;
   7.306 +     if ((sym_name_atom == None)
   7.307 +-    || ((sym_name = XGetAtomName(xkb->dsp, sym_name_atom)) == NULL))
   7.308 ++    || ((sym_name = XGetAtomName(GDK_DISPLAY(), sym_name_atom)) == NULL))
   7.309 +         goto HastaLaVista;
   7.310 + 
   7.311 +     /* Parse and store symbol names. */
   7.312 +@@ -190,83 +203,106 @@ static int do_init_xkb(XkbPlugin * xkb)
   7.313 +     {
   7.314 +         xkb->group_count = 2;
   7.315 +         xkb->symbol_names[1] = xkb->symbol_names[0];
   7.316 +-        xkb->symbol_names[0] = strdup("us");
   7.317 +-        xkb->group_names[0] = strdup("US/ASCII");
   7.318 +-        xkb->group_names[1] = strdup("Japanese");
   7.319 ++        xkb->symbol_names[0] = g_strdup("us");
   7.320 ++        xkb->group_names[0] = g_strdup("US/ASCII");
   7.321 ++        xkb->group_names[1] = g_strdup("Japanese");
   7.322 +     }
   7.323 +     else if (count < xkb->group_count)
   7.324 +     {
   7.325 +         /* Ensure that the names are fully initialized. */
   7.326 +         int j = count, k = xkb->group_count;
   7.327 +         while(--j >= 0) xkb->symbol_names[--k] = xkb->symbol_names[j];
   7.328 +-        while(--k >= 0) xkb->symbol_names[k] = strdup("en_US");
   7.329 ++        while(--k >= 0) xkb->symbol_names[k] = g_strdup("en_US");
   7.330 +     }
   7.331 + 
   7.332 +-    /* Enxure that the names are fully initialized. */
   7.333 ++    /* Ensure that the names are fully initialized. */
   7.334 +     for (i = 0; i < xkb->group_count; i++)
   7.335 +     {
   7.336 +         if (xkb->symbol_names[i] == NULL)
   7.337 +         {
   7.338 +             ERR("\nGroup Symbol %i is undefined, set to 'U/A' !\n", i+1);
   7.339 +-            xkb->symbol_names[i] = strdup("U/A");
   7.340 ++            xkb->symbol_names[i] = g_strdup("U/A");
   7.341 +         }
   7.342 +     }
   7.343 + 
   7.344 ++    /* Create or recreate hash table.
   7.345 ++     * The layout that was associated to the windows may or may not be at the same group number,
   7.346 ++     * and worse, may no longer exist, which there is no meaningful way to deal with. */
   7.347 ++    if (xkb->group_hash_table != NULL)
   7.348 ++        g_hash_table_destroy(xkb->group_hash_table);
   7.349 ++    xkb->group_hash_table = g_hash_table_new(g_direct_hash, NULL);
   7.350 ++
   7.351 +     status = True;
   7.352 + 
   7.353 + HastaLaVista:
   7.354 +     if (kbd_desc_ptr != NULL)
   7.355 +         XkbFreeKeyboard(kbd_desc_ptr, 0, True);
   7.356 ++
   7.357 +     return status;
   7.358 + }
   7.359 + 
   7.360 ++/* GDK event filter that receives events from all windows and the Xkb extension. */
   7.361 ++static GdkFilterReturn xkb_event_filter(GdkXEvent * xevent, GdkEvent * event, XkbPlugin * xkb)
   7.362 ++{
   7.363 ++    XEvent * ev = (XEvent *) xevent;
   7.364 ++
   7.365 ++    if (ev->xany.type == xkb->base_event_code + XkbEventCode)
   7.366 ++    {
   7.367 ++        /* Xkb event. */
   7.368 ++        XkbEvent * xkbev = (XkbEvent *) ev;
   7.369 ++        if (xkbev->any.xkb_type == XkbNewKeyboardNotify)
   7.370 ++        {
   7.371 ++            initialize_keyboard_description(xkb);
   7.372 ++            refresh_group_xkb(xkb);
   7.373 ++            xkb_redraw(xkb);
   7.374 ++            xkb_enter_locale_by_process(xkb);
   7.375 ++        }
   7.376 ++        else if (xkbev->any.xkb_type == XkbStateNotify)
   7.377 ++        {
   7.378 ++            if (xkbev->state.group != xkb->current_group_xkb_no)
   7.379 ++            {
   7.380 ++                /* Switch to the new group and redraw the display. */
   7.381 ++                xkb->current_group_xkb_no = xkbev->state.group;
   7.382 ++                refresh_group_xkb(xkb);
   7.383 ++                xkb_redraw(xkb);
   7.384 ++                xkb_enter_locale_by_process(xkb);
   7.385 ++            }
   7.386 ++        }
   7.387 ++    }
   7.388 ++    return GDK_FILTER_CONTINUE;
   7.389 ++}
   7.390 ++
   7.391 + /* Initialize the Xkb interface. */
   7.392 + void xkb_mechanism_constructor(XkbPlugin * xkb)
   7.393 + {
   7.394 +-    /* Enable the Xkb extension on all clients. */
   7.395 +-    XkbIgnoreExtension(False);
   7.396 +-
   7.397 +-    /* Open the display. */
   7.398 +-    int major = XkbMajorVersion;
   7.399 +-    int minor = XkbMinorVersion;
   7.400 +-    char * display_name = "";
   7.401 +-    int event_code;
   7.402 +-    int error_rtrn;
   7.403 +-    int reason_rtrn;
   7.404 +-    xkb->dsp = XkbOpenDisplay(display_name, &event_code, &error_rtrn, &major, &minor, &reason_rtrn);
   7.405 +-
   7.406 +-    switch (reason_rtrn)
   7.407 ++    /* Initialize Xkb extension. */
   7.408 ++    int opcode;
   7.409 ++    int maj = XkbMajorVersion;
   7.410 ++    int min = XkbMinorVersion;
   7.411 ++    if ((XkbLibraryVersion(&maj, &min))
   7.412 ++    && (XkbQueryExtension(GDK_DISPLAY(), &opcode, &xkb->base_event_code, &xkb->base_error_code, &maj, &min)))
   7.413 +     {
   7.414 +-        case XkbOD_BadLibraryVersion:
   7.415 +-            ERR("Bad XKB library version.\n");
   7.416 +-            return;
   7.417 +-        case XkbOD_ConnectionRefused:
   7.418 +-            ERR("Connection to X server refused.\n");
   7.419 +-            return;
   7.420 +-        case XkbOD_BadServerVersion:
   7.421 +-            ERR("Bad X server version.\n");
   7.422 +-            return;
   7.423 +-        case XkbOD_NonXkbServer:
   7.424 +-            ERR("XKB not present.\n");
   7.425 +-            return;
   7.426 +-        case XkbOD_Success:
   7.427 +-            break;
   7.428 +-    }
   7.429 ++        /* Read the keyboard description. */
   7.430 ++        initialize_keyboard_description(xkb);
   7.431 + 
   7.432 +-    /* Initialize our mechanism. */
   7.433 +-    if (do_init_xkb(xkb) != True)
   7.434 +-        return;
   7.435 ++        /* Establish GDK event filter. */
   7.436 ++        gdk_window_add_filter(NULL, (GdkFilterFunc) xkb_event_filter, (gpointer) xkb);
   7.437 + 
   7.438 +-    /* Specify events we will receive. */
   7.439 +-    XkbSelectEventDetails(xkb->dsp, xkb->device_id, XkbStateNotify, XkbAllStateComponentsMask, XkbGroupStateMask);
   7.440 ++        /* Specify events we will receive. */
   7.441 ++        XkbSelectEvents(GDK_DISPLAY(), XkbUseCoreKbd, XkbNewKeyboardNotifyMask, XkbNewKeyboardNotifyMask);
   7.442 ++        XkbSelectEventDetails(GDK_DISPLAY(), XkbUseCoreKbd, XkbStateNotify, XkbAllStateComponentsMask, XkbGroupStateMask);
   7.443 + 
   7.444 +-    /* Get current state. */
   7.445 +-    refresh_group_xkb(xkb);
   7.446 ++        /* Get current state. */
   7.447 ++        refresh_group_xkb(xkb);
   7.448 ++    }
   7.449 + }
   7.450 + 
   7.451 + /* Deallocate resources associated with Xkb interface. */
   7.452 + void xkb_mechanism_destructor(XkbPlugin * xkb) 
   7.453 + {
   7.454 ++    /* Remove event filter. */
   7.455 ++    gdk_window_remove_filter(NULL, (GdkFilterFunc) xkb_event_filter, xkb);
   7.456 ++
   7.457 +     /* Free group and symbol name memory. */
   7.458 +     int i;
   7.459 +     for (i = 0; i < xkb->group_count; i++)
   7.460 +@@ -283,21 +319,11 @@ void xkb_mechanism_destructor(XkbPlugin * xkb)
   7.461 +         }
   7.462 +     }
   7.463 + 
   7.464 +-    /* Close the display. */
   7.465 +-    XCloseDisplay(xkb->dsp);
   7.466 +-    xkb->dsp = NULL;
   7.467 +-
   7.468 +     /* Destroy the hash table. */
   7.469 +     g_hash_table_destroy(xkb->group_hash_table);
   7.470 +     xkb->group_hash_table = NULL;
   7.471 + }
   7.472 + 
   7.473 +-/* Return the connection number for the display. */
   7.474 +-int xkb_get_connection_number(XkbPlugin * xkb)
   7.475 +-{
   7.476 +-    return ConnectionNumber(xkb->dsp);
   7.477 +-}
   7.478 +-
   7.479 + /* Set the layout to the next layout. */
   7.480 + int xkb_change_group(XkbPlugin * xkb, int increment) 
   7.481 + {
   7.482 +@@ -307,33 +333,13 @@ int xkb_change_group(XkbPlugin * xkb, int increment)
   7.483 +     if (next_group >= xkb->group_count) next_group = 0;
   7.484 + 
   7.485 +     /* Execute the change. */
   7.486 +-    XkbLockGroup(xkb->dsp, xkb->device_id, next_group);
   7.487 ++    XkbLockGroup(GDK_DISPLAY(), XkbUseCoreKbd, next_group);
   7.488 +     refresh_group_xkb(xkb);
   7.489 +     xkb_redraw(xkb);
   7.490 +     xkb_enter_locale_by_process(xkb);
   7.491 +     return 1;
   7.492 + }
   7.493 + 
   7.494 +-/* Callback when activity detected on the Xkb channel. */
   7.495 +-gboolean xkb_gio_callback(GIOChannel * source, GIOCondition condition, gpointer data) 
   7.496 +-{
   7.497 +-    XkbPlugin * xkb = (XkbPlugin *) data;
   7.498 +-
   7.499 +-    XkbEvent evnt;
   7.500 +-    XNextEvent(xkb->dsp, &evnt.core);
   7.501 +-    if ((evnt.type == xkb->base_event_code)
   7.502 +-    && (evnt.any.xkb_type == XkbStateNotify)
   7.503 +-    && (evnt.state.group != xkb->current_group_xkb_no))
   7.504 +-    {
   7.505 +-        /* Switch to the new group and redraw the display. */
   7.506 +-        xkb->current_group_xkb_no = evnt.state.group;
   7.507 +-        refresh_group_xkb(xkb);
   7.508 +-        xkb_redraw(xkb);
   7.509 +-        xkb_enter_locale_by_process(xkb);
   7.510 +-    }
   7.511 +-    return TRUE;
   7.512 +-}
   7.513 +-
   7.514 + /* React to change of focus by switching to the application's layout or the default layout. */
   7.515 + void xkb_active_window_changed(XkbPlugin * xkb, gint pid)
   7.516 + {
   7.517 +@@ -345,7 +351,7 @@ void xkb_active_window_changed(XkbPlugin * xkb, gint pid)
   7.518 + 
   7.519 +     if (new_group_xkb_no < xkb->group_count)
   7.520 +     {
   7.521 +-        XkbLockGroup(xkb->dsp, xkb->device_id, new_group_xkb_no);
   7.522 ++        XkbLockGroup(GDK_DISPLAY(), XkbUseCoreKbd, new_group_xkb_no);
   7.523 +         refresh_group_xkb(xkb);
   7.524 +     }
   7.525 + }
   7.526 +diff --git a/src/plugins/xkb/xkb.h b/src/plugins/xkb/xkb.h
   7.527 +index 9265198..20c7ed3 100644
   7.528 +--- a/src/plugins/xkb/xkb.h
   7.529 ++++ b/src/plugins/xkb/xkb.h
   7.530 +@@ -49,10 +49,8 @@ typedef struct {
   7.531 +     GtkWidget * per_app_default_layout_menu;	/* Combo box of all available layouts */
   7.532 + 
   7.533 +     /* Mechanism. */
   7.534 +-    Display * dsp;				/* Handle to X display */
   7.535 +     int base_event_code;			/* Result of initializing Xkb extension */
   7.536 +     int base_error_code;
   7.537 +-    int device_id;				/* Keyboard device ID (always "core keyboard") */
   7.538 +     int current_group_xkb_no;			/* Current layout */
   7.539 +     int group_count;				/* Count of groups as returned by Xkb */
   7.540 +     char * group_names[XkbNumKbdGroups];	/* Group names as returned by Xkb */
   7.541 +@@ -67,12 +65,11 @@ extern int xkb_get_current_group_xkb_no(XkbPlugin * xkb);
   7.542 + extern int xkb_get_group_count(XkbPlugin * xkb);
   7.543 + extern const char * xkb_get_symbol_name_by_res_no(XkbPlugin * xkb, int group_res_no);
   7.544 + extern const char * xkb_get_current_group_name(XkbPlugin * xkb);
   7.545 +-extern const char * xkb_get_current_group_name_lowercase(XkbPlugin * xkb);
   7.546 ++extern const char * xkb_get_current_symbol_name(XkbPlugin * xkb);
   7.547 ++extern const char * xkb_get_current_symbol_name_lowercase(XkbPlugin * xkb);
   7.548 + extern void xkb_mechanism_constructor(XkbPlugin * xkb);
   7.549 + extern void xkb_mechanism_destructor(XkbPlugin * xkb);
   7.550 +-extern int xkb_get_connection_number(XkbPlugin * xkb);
   7.551 + extern int xkb_change_group(XkbPlugin * xkb, int increment);
   7.552 +-extern gboolean xkb_gio_callback(GIOChannel * source, GIOCondition condition, gpointer data);
   7.553 + extern void xkb_active_window_changed(XkbPlugin * xkb, GPid pid);
   7.554 + 
   7.555 + #endif
   7.556 +-- 
   7.557 +1.7.0
   7.558 +