Merge remote branch 'whot/for-keith'
This commit is contained in:
commit
816d67de2b
|
@ -701,7 +701,7 @@ XIDeleteDeviceProperty (DeviceIntPtr device, Atom property, Bool fromClient)
|
||||||
int
|
int
|
||||||
XIChangeDeviceProperty (DeviceIntPtr dev, Atom property, Atom type,
|
XIChangeDeviceProperty (DeviceIntPtr dev, Atom property, Atom type,
|
||||||
int format, int mode, unsigned long len,
|
int format, int mode, unsigned long len,
|
||||||
pointer value, Bool sendevent)
|
const pointer value, Bool sendevent)
|
||||||
{
|
{
|
||||||
XIPropertyPtr prop;
|
XIPropertyPtr prop;
|
||||||
int size_in_bytes;
|
int size_in_bytes;
|
||||||
|
|
|
@ -129,7 +129,7 @@ ProcXIQueryPointer(ClientPtr client)
|
||||||
|
|
||||||
if (kbd)
|
if (kbd)
|
||||||
{
|
{
|
||||||
state = &kbd->key->xkbInfo->prev_state;
|
state = &kbd->key->xkbInfo->state;
|
||||||
rep.mods.base_mods = state->base_mods;
|
rep.mods.base_mods = state->base_mods;
|
||||||
rep.mods.latched_mods = state->latched_mods;
|
rep.mods.latched_mods = state->latched_mods;
|
||||||
rep.mods.locked_mods = state->locked_mods;
|
rep.mods.locked_mods = state->locked_mods;
|
||||||
|
|
|
@ -808,7 +808,7 @@ InitInput(int argc, char **argv)
|
||||||
|
|
||||||
GetEventList(&xf86Events);
|
GetEventList(&xf86Events);
|
||||||
|
|
||||||
/* Call the PreInit function for each input device instance. */
|
/* Initialize all configured input devices */
|
||||||
for (pDev = xf86ConfigLayout.inputs; pDev && *pDev; pDev++) {
|
for (pDev = xf86ConfigLayout.inputs; pDev && *pDev; pDev++) {
|
||||||
/* Replace obsolete keyboard driver with kbd */
|
/* Replace obsolete keyboard driver with kbd */
|
||||||
if (!xf86NameCmp((*pDev)->driver, "keyboard")) {
|
if (!xf86NameCmp((*pDev)->driver, "keyboard")) {
|
||||||
|
|
|
@ -69,7 +69,7 @@ extern _X_EXPORT int XIChangeDeviceProperty(
|
||||||
int /* format*/,
|
int /* format*/,
|
||||||
int /* mode*/,
|
int /* mode*/,
|
||||||
unsigned long /* len*/,
|
unsigned long /* len*/,
|
||||||
pointer /* value*/,
|
const pointer /* value*/,
|
||||||
Bool /* sendevent*/
|
Bool /* sendevent*/
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ RRClientKnowsRates (ClientPtr pClient)
|
||||||
static int
|
static int
|
||||||
ProcRRQueryVersion (ClientPtr client)
|
ProcRRQueryVersion (ClientPtr client)
|
||||||
{
|
{
|
||||||
xRRQueryVersionReply rep;
|
xRRQueryVersionReply rep = {0};
|
||||||
register int n;
|
register int n;
|
||||||
REQUEST(xRRQueryVersionReq);
|
REQUEST(xRRQueryVersionReq);
|
||||||
rrClientPriv(client);
|
rrClientPriv(client);
|
||||||
|
|
|
@ -288,7 +288,7 @@ int
|
||||||
ProcRRCreateMode (ClientPtr client)
|
ProcRRCreateMode (ClientPtr client)
|
||||||
{
|
{
|
||||||
REQUEST(xRRCreateModeReq);
|
REQUEST(xRRCreateModeReq);
|
||||||
xRRCreateModeReply rep;
|
xRRCreateModeReply rep = {0};
|
||||||
WindowPtr pWin;
|
WindowPtr pWin;
|
||||||
ScreenPtr pScreen;
|
ScreenPtr pScreen;
|
||||||
rrScrPrivPtr pScrPriv;
|
rrScrPrivPtr pScrPriv;
|
||||||
|
|
|
@ -1045,7 +1045,7 @@ XFixesCursorInit (void)
|
||||||
ScreenPtr pScreen = screenInfo.screens[i];
|
ScreenPtr pScreen = screenInfo.screens[i];
|
||||||
CursorScreenPtr cs;
|
CursorScreenPtr cs;
|
||||||
|
|
||||||
cs = (CursorScreenPtr) malloc(sizeof (CursorScreenRec));
|
cs = (CursorScreenPtr) calloc(1, sizeof (CursorScreenRec));
|
||||||
if (!cs)
|
if (!cs)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
Wrap (cs, pScreen, CloseScreen, CursorCloseScreen);
|
Wrap (cs, pScreen, CloseScreen, CursorCloseScreen);
|
||||||
|
|
|
@ -425,34 +425,78 @@ XkbRF_RulesPtr rules;
|
||||||
return complete;
|
return complete;
|
||||||
}
|
}
|
||||||
|
|
||||||
XkbDescPtr
|
static Bool
|
||||||
XkbCompileKeymap(DeviceIntPtr dev, XkbRMLVOSet *rmlvo)
|
XkbRMLVOtoKcCGST(DeviceIntPtr dev, XkbRMLVOSet *rmlvo, XkbComponentNamesPtr kccgst)
|
||||||
{
|
{
|
||||||
XkbComponentNamesRec kccgst;
|
|
||||||
XkbRF_VarDefsRec mlvo;
|
XkbRF_VarDefsRec mlvo;
|
||||||
XkbDescPtr xkb;
|
|
||||||
char name[PATH_MAX];
|
|
||||||
|
|
||||||
if (!dev || !rmlvo) {
|
|
||||||
LogMessage(X_ERROR, "XKB: No device or RMLVO specified\n");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
mlvo.model = rmlvo->model;
|
mlvo.model = rmlvo->model;
|
||||||
mlvo.layout = rmlvo->layout;
|
mlvo.layout = rmlvo->layout;
|
||||||
mlvo.variant = rmlvo->variant;
|
mlvo.variant = rmlvo->variant;
|
||||||
mlvo.options = rmlvo->options;
|
mlvo.options = rmlvo->options;
|
||||||
|
|
||||||
/* XDNFR already logs for us. */
|
return XkbDDXNamesFromRules(dev, rmlvo->rules, &mlvo, kccgst);
|
||||||
if (!XkbDDXNamesFromRules(dev, rmlvo->rules, &mlvo, &kccgst))
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compile the given RMLVO keymap and return it. Returns the XkbDescPtr on
|
||||||
|
* success or NULL on failure. If the components compiled are not a superset
|
||||||
|
* or equal to need, the compiliation is treated as failure.
|
||||||
|
*/
|
||||||
|
static XkbDescPtr
|
||||||
|
XkbCompileKeymapForDevice(DeviceIntPtr dev, XkbRMLVOSet *rmlvo, int need)
|
||||||
|
{
|
||||||
|
XkbDescPtr xkb;
|
||||||
|
unsigned int provided;
|
||||||
|
XkbComponentNamesRec kccgst;
|
||||||
|
char name[PATH_MAX];
|
||||||
|
|
||||||
|
if (!XkbRMLVOtoKcCGST(dev, rmlvo, &kccgst))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* XDLKBN too, but it might return 0 as well as allocating. */
|
provided = XkbDDXLoadKeymapByNames(dev, &kccgst, XkmAllIndicesMask, need,
|
||||||
if (!XkbDDXLoadKeymapByNames(dev, &kccgst, XkmAllIndicesMask, 0, &xkb, name,
|
&xkb, name, PATH_MAX);
|
||||||
PATH_MAX)) {
|
if ((need & provided) != need) {
|
||||||
if (xkb)
|
if (xkb) {
|
||||||
XkbFreeKeyboard(xkb, 0, TRUE);
|
XkbFreeKeyboard(xkb, 0, TRUE);
|
||||||
return NULL;
|
xkb = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return xkb;
|
||||||
|
}
|
||||||
|
|
||||||
|
XkbDescPtr
|
||||||
|
XkbCompileKeymap(DeviceIntPtr dev, XkbRMLVOSet *rmlvo)
|
||||||
|
{
|
||||||
|
XkbDescPtr xkb;
|
||||||
|
unsigned int need;
|
||||||
|
|
||||||
|
if (!dev || !rmlvo) {
|
||||||
|
LogMessage(X_ERROR, "XKB: No device or RMLVO specified\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* These are the components we really really need */
|
||||||
|
need = XkmSymbolsMask | XkmCompatMapMask | XkmTypesMask |
|
||||||
|
XkmKeyNamesMask | XkmVirtualModsMask;
|
||||||
|
|
||||||
|
|
||||||
|
xkb = XkbCompileKeymapForDevice(dev, rmlvo, need);
|
||||||
|
|
||||||
|
if (!xkb) {
|
||||||
|
XkbRMLVOSet dflts;
|
||||||
|
|
||||||
|
/* we didn't get what we really needed. And that will likely leave
|
||||||
|
* us with a keyboard that doesn't work. Use the defaults instead */
|
||||||
|
LogMessage(X_ERROR, "XKB: Failed to load keymap. Loading default "
|
||||||
|
"keymap instead.\n");
|
||||||
|
|
||||||
|
XkbGetRulesDflts(&dflts);
|
||||||
|
|
||||||
|
xkb = XkbCompileKeymapForDevice(dev, &dflts, 0);
|
||||||
|
|
||||||
|
XkbFreeRMLVOSet(&dflts, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
return xkb;
|
return xkb;
|
||||||
|
|
16
xkb/xkb.c
16
xkb/xkb.c
|
@ -3644,7 +3644,7 @@ register int n;
|
||||||
swapl(&rep->indicators,n);
|
swapl(&rep->indicators,n);
|
||||||
}
|
}
|
||||||
|
|
||||||
start = desc = malloc(length);
|
start = desc = calloc(1, length);
|
||||||
if ( !start )
|
if ( !start )
|
||||||
return BadAlloc;
|
return BadAlloc;
|
||||||
if (xkb->names) {
|
if (xkb->names) {
|
||||||
|
@ -5569,13 +5569,13 @@ ProcXkbGetKbdByName(ClientPtr client)
|
||||||
{
|
{
|
||||||
DeviceIntPtr dev;
|
DeviceIntPtr dev;
|
||||||
DeviceIntPtr tmpd;
|
DeviceIntPtr tmpd;
|
||||||
xkbGetKbdByNameReply rep;
|
xkbGetKbdByNameReply rep = {0};
|
||||||
xkbGetMapReply mrep;
|
xkbGetMapReply mrep = {0};
|
||||||
xkbGetCompatMapReply crep;
|
xkbGetCompatMapReply crep = {0};
|
||||||
xkbGetIndicatorMapReply irep;
|
xkbGetIndicatorMapReply irep = {0};
|
||||||
xkbGetNamesReply nrep;
|
xkbGetNamesReply nrep = {0};
|
||||||
xkbGetGeometryReply grep;
|
xkbGetGeometryReply grep = {0};
|
||||||
XkbComponentNamesRec names;
|
XkbComponentNamesRec names = {0};
|
||||||
XkbDescPtr xkb, new;
|
XkbDescPtr xkb, new;
|
||||||
unsigned char * str;
|
unsigned char * str;
|
||||||
char mapFile[PATH_MAX];
|
char mapFile[PATH_MAX];
|
||||||
|
|
Loading…
Reference in New Issue