Fix an out-of-bounds access in MyEnhancedXkbTranslateKeyCode

Commits 314b6abbe8 and eb9223c008 were ignoring
the fact that the code where found is set to 1 was modifying
col - which was an ok thing to do when that part of the code
was still breaking out of the loop, but it is no longer doing
that (since 2003 !). Fix things up by storing the final col
value in a separate variable and using that after the loop.

https://bugzilla.gnome.org/show_bug.cgi?id=738886
This commit is contained in:
Matthias Clasen 2014-10-26 21:48:59 -04:00
parent f7813deb26
commit e75310a445

View File

@ -1058,6 +1058,7 @@ MyEnhancedXkbTranslateKeyCode(register XkbDescPtr xkb,
int col,nKeyGroups; int col,nKeyGroups;
unsigned preserve,effectiveGroup; unsigned preserve,effectiveGroup;
KeySym *syms; KeySym *syms;
int found_col = 0;
if (mods_rtrn!=NULL) if (mods_rtrn!=NULL)
*mods_rtrn = 0; *mods_rtrn = 0;
@ -1090,7 +1091,7 @@ MyEnhancedXkbTranslateKeyCode(register XkbDescPtr xkb,
break; break;
} }
} }
col= effectiveGroup*XkbKeyGroupsWidth(xkb,key); found_col = col= effectiveGroup*XkbKeyGroupsWidth(xkb,key);
type = XkbKeyKeyType(xkb,key,effectiveGroup); type = XkbKeyKeyType(xkb,key,effectiveGroup);
preserve= 0; preserve= 0;
@ -1129,7 +1130,7 @@ MyEnhancedXkbTranslateKeyCode(register XkbDescPtr xkb,
} }
if (!found && ((mods&type->mods.mask) == entry->mods.mask)) { if (!found && ((mods&type->mods.mask) == entry->mods.mask)) {
col+= entry->level; found_col= col + entry->level;
if (type->preserve) if (type->preserve)
preserve= type->preserve[i].mask; preserve= type->preserve[i].mask;
@ -1143,7 +1144,7 @@ MyEnhancedXkbTranslateKeyCode(register XkbDescPtr xkb,
} }
if (keysym_rtrn!=NULL) if (keysym_rtrn!=NULL)
*keysym_rtrn= syms[col]; *keysym_rtrn= syms[found_col];
if (mods_rtrn) { if (mods_rtrn) {
/* ---- Begin section modified for GDK ---- */ /* ---- Begin section modified for GDK ---- */
*mods_rtrn &= ~preserve; *mods_rtrn &= ~preserve;
@ -1175,7 +1176,7 @@ MyEnhancedXkbTranslateKeyCode(register XkbDescPtr xkb,
/* ---- End stuff GDK adds to the original Xlib version ---- */ /* ---- End stuff GDK adds to the original Xlib version ---- */
return (syms[col] != NoSymbol); return (syms[found_col] != NoSymbol);
} }
#endif /* HAVE_XKB */ #endif /* HAVE_XKB */