Usually it's better to submit a patch as an attachment. We'll see On Nov 14, 2012 7:02 PM, "neil klopfenstein" <rebr...@gmail.com> wrote:
> Hi all, > > I use dwm with Xvnc, which apparently is broken when it comes to Xkb (or > maybe that's just my site installation). Anyway, I just installed the code > from the repository and it has a problem which I see has been reported > before: No keypresses work, because XkbKeycodeToKeysym always returns zero. > > I did a little digging around and found a bug: You aren't supposed to use > any Xkb functions without calling XkbQueryExtension first, to initialize > the extension and test for its presence. I wrote this patch which adds the > XkbQueryExtension call, and uses XKeycodeToKeysym if you're one of the poor > souls without Xkb available. > > Attached is the diff of my changes. Please let me know if there's a better > way for me to submit this patch. > > --Neil > > diff -r 0284f00e70d2 dwm.c > --- a/dwm.c Fri Nov 02 12:17:50 2012 +0100 > +++ b/dwm.c Wed Nov 14 20:57:52 2012 -0300 > @@ -280,7 +280,7 @@ > [UnmapNotify] = unmapnotify > }; > static Atom wmatom[WMLast], netatom[NetLast]; > -static Bool running = True; > +static Bool running = True, xkb_present; > static Cursor cursor[CurLast]; > static Display *dpy; > static DC dc; > @@ -1067,7 +1067,10 @@ > XKeyEvent *ev; > > ev = &e->xkey; > - keysym = XkbKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0, 0); > + if (xkb_present) > + keysym = XkbKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0, > 0); > + else > + keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0); > for(i = 0; i < LENGTH(keys); i++) > if(keysym == keys[i].keysym > && CLEANMASK(keys[i].mod) == CLEANMASK(ev->state) > @@ -1577,6 +1580,7 @@ > void > setup(void) { > XSetWindowAttributes wa; > + int xkb_opcode, xkb_event, xkb_error, xkb_major = XkbMajorVersion, > xkb_minor = XkbMinorVersion; > > /* clean up any zombies immediately */ > sigchld(0); > @@ -1629,6 +1633,8 @@ > > |EnterWindowMask|LeaveWindowMask|StructureNotifyMask|PropertyChangeMask; > XChangeWindowAttributes(dpy, root, CWEventMask|CWCursor, &wa); > XSelectInput(dpy, root, wa.event_mask); > + /* init xkb */ > + xkb_present = XkbQueryExtension(dpy, &xkb_opcode, &xkb_event, > &xkb_error, &xkb_major, &xkb_minor); > grabkeys(); > } >