xkb: break up XkbCopyKeymap into bite-sized chunks.
This commit is contained in:
parent
3c6a9c531f
commit
6c1bb64c6f
243
xkb/xkbUtils.c
243
xkb/xkbUtils.c
|
@ -23,6 +23,30 @@ OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH
|
||||||
THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
/*
|
||||||
|
|
||||||
|
Copyright © 2008 Red Hat Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
copy of this software and associated documentation files (the "Software"),
|
||||||
|
to deal in the Software without restriction, including without limitation
|
||||||
|
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
Software is furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice (including the next
|
||||||
|
paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_DIX_CONFIG_H
|
#ifdef HAVE_DIX_CONFIG_H
|
||||||
#include <dix-config.h>
|
#include <dix-config.h>
|
||||||
|
@ -909,44 +933,12 @@ XkbConvertCase(register KeySym sym, KeySym *lower, KeySym *upper)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Bool
|
||||||
/**
|
_XkbCopyClientMap(XkbDescPtr src, XkbDescPtr dst)
|
||||||
* Copy an XKB map from src to dst, reallocating when necessary: if some
|
|
||||||
* map components are present in one, but not in the other, the destination
|
|
||||||
* components will be allocated or freed as necessary.
|
|
||||||
*
|
|
||||||
* Basic map consistency is assumed on both sides, so maps with random
|
|
||||||
* uninitialised data (e.g. names->radio_grous == NULL, names->num_rg == 19)
|
|
||||||
* _will_ cause failures. You've been warned.
|
|
||||||
*
|
|
||||||
* Returns TRUE on success, or FALSE on failure. If this function fails,
|
|
||||||
* dst may be in an inconsistent state: all its pointers are guaranteed
|
|
||||||
* to remain valid, but part of the map may be from src and part from dst.
|
|
||||||
*
|
|
||||||
* FIXME: This function wants to be broken up into multiple functions.
|
|
||||||
*/
|
|
||||||
Bool
|
|
||||||
XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
|
||||||
{
|
{
|
||||||
int i = 0, j = 0, k = 0;
|
|
||||||
void *tmp = NULL;
|
void *tmp = NULL;
|
||||||
XkbColorPtr scolor = NULL, dcolor = NULL;
|
int i;
|
||||||
XkbDoodadPtr sdoodad = NULL, ddoodad = NULL;
|
|
||||||
XkbKeyTypePtr stype = NULL, dtype = NULL;
|
XkbKeyTypePtr stype = NULL, dtype = NULL;
|
||||||
XkbOutlinePtr soutline = NULL, doutline = NULL;
|
|
||||||
XkbPropertyPtr sprop = NULL, dprop = NULL;
|
|
||||||
XkbRowPtr srow = NULL, drow = NULL;
|
|
||||||
XkbSectionPtr ssection = NULL, dsection = NULL;
|
|
||||||
XkbShapePtr sshape = NULL, dshape = NULL;
|
|
||||||
DeviceIntPtr pDev = NULL, tmpDev = NULL;
|
|
||||||
xkbMapNotify mn;
|
|
||||||
xkbNewKeyboardNotify nkn;
|
|
||||||
|
|
||||||
if (src == dst)
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
if (!src || !dst)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
/* client map */
|
/* client map */
|
||||||
if (src->map) {
|
if (src->map) {
|
||||||
|
@ -1195,6 +1187,14 @@ XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
XkbFreeClientMap(dst, XkbAllClientInfoMask, True);
|
XkbFreeClientMap(dst, XkbAllClientInfoMask, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Bool
|
||||||
|
_XkbCopyServerMap(XkbDescPtr src, XkbDescPtr dst)
|
||||||
|
{
|
||||||
|
void *tmp = NULL;
|
||||||
|
|
||||||
/* server map */
|
/* server map */
|
||||||
if (src->server) {
|
if (src->server) {
|
||||||
if (!dst->server) {
|
if (!dst->server) {
|
||||||
|
@ -1323,37 +1323,13 @@ XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
XkbFreeServerMap(dst, XkbAllServerInfoMask, True);
|
XkbFreeServerMap(dst, XkbAllServerInfoMask, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* indicators */
|
return TRUE;
|
||||||
if (src->indicators) {
|
}
|
||||||
if (!dst->indicators) {
|
|
||||||
dst->indicators = xalloc(sizeof(XkbIndicatorRec));
|
|
||||||
if (!dst->indicators)
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
memcpy(dst->indicators, src->indicators, sizeof(XkbIndicatorRec));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (dst->indicators) {
|
|
||||||
xfree(dst->indicators);
|
|
||||||
dst->indicators = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* controls */
|
static Bool
|
||||||
if (src->ctrls) {
|
_XkbCopyNames(XkbDescPtr src, XkbDescPtr dst)
|
||||||
if (!dst->ctrls) {
|
{
|
||||||
dst->ctrls = xalloc(sizeof(XkbControlsRec));
|
void *tmp = NULL;
|
||||||
if (!dst->ctrls)
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
memcpy(dst->ctrls, src->ctrls, sizeof(XkbControlsRec));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (dst->ctrls) {
|
|
||||||
xfree(dst->ctrls);
|
|
||||||
dst->ctrls = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* names */
|
/* names */
|
||||||
if (src->names) {
|
if (src->names) {
|
||||||
|
@ -1448,6 +1424,14 @@ XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
XkbFreeNames(dst, XkbAllNamesMask, True);
|
XkbFreeNames(dst, XkbAllNamesMask, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Bool
|
||||||
|
_XkbCopyCompat(XkbDescPtr src, XkbDescPtr dst)
|
||||||
|
{
|
||||||
|
void *tmp = NULL;
|
||||||
|
|
||||||
/* compat */
|
/* compat */
|
||||||
if (src->compat) {
|
if (src->compat) {
|
||||||
if (!dst->compat) {
|
if (!dst->compat) {
|
||||||
|
@ -1492,6 +1476,22 @@ XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
XkbFreeCompatMap(dst, XkbAllCompatMask, True);
|
XkbFreeCompatMap(dst, XkbAllCompatMask, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Bool
|
||||||
|
_XkbCopyGeom(XkbDescPtr src, XkbDescPtr dst)
|
||||||
|
{
|
||||||
|
void *tmp = NULL;
|
||||||
|
int i = 0, j = 0, k = 0;
|
||||||
|
XkbColorPtr scolor = NULL, dcolor = NULL;
|
||||||
|
XkbDoodadPtr sdoodad = NULL, ddoodad = NULL;
|
||||||
|
XkbOutlinePtr soutline = NULL, doutline = NULL;
|
||||||
|
XkbPropertyPtr sprop = NULL, dprop = NULL;
|
||||||
|
XkbRowPtr srow = NULL, drow = NULL;
|
||||||
|
XkbSectionPtr ssection = NULL, dsection = NULL;
|
||||||
|
XkbShapePtr sshape = NULL, dshape = NULL;
|
||||||
|
|
||||||
/* geometry */
|
/* geometry */
|
||||||
if (src->geom) {
|
if (src->geom) {
|
||||||
if (!dst->geom) {
|
if (!dst->geom) {
|
||||||
|
@ -2014,20 +2014,111 @@ XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (tmpDev = inputInfo.devices; tmpDev && !pDev;
|
return TRUE;
|
||||||
tmpDev = tmpDev->next) {
|
}
|
||||||
if (tmpDev->key && tmpDev->key->xkbInfo &&
|
|
||||||
tmpDev->key->xkbInfo->desc == dst) {
|
static Bool
|
||||||
pDev = tmpDev;
|
_XkbCopyIndicators(XkbDescPtr src, XkbDescPtr dst)
|
||||||
break;
|
{
|
||||||
|
/* indicators */
|
||||||
|
if (src->indicators) {
|
||||||
|
if (!dst->indicators) {
|
||||||
|
dst->indicators = xalloc(sizeof(XkbIndicatorRec));
|
||||||
|
if (!dst->indicators)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
memcpy(dst->indicators, src->indicators, sizeof(XkbIndicatorRec));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (dst->indicators) {
|
||||||
|
xfree(dst->indicators);
|
||||||
|
dst->indicators = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (tmpDev = inputInfo.off_devices; tmpDev && !pDev;
|
return TRUE;
|
||||||
tmpDev = tmpDev->next) {
|
}
|
||||||
if (tmpDev->key && tmpDev->key->xkbInfo &&
|
|
||||||
|
static Bool
|
||||||
|
_XkbCopyControls(XkbDescPtr src, XkbDescPtr dst)
|
||||||
|
{
|
||||||
|
/* controls */
|
||||||
|
if (src->ctrls) {
|
||||||
|
if (!dst->ctrls) {
|
||||||
|
dst->ctrls = xalloc(sizeof(XkbControlsRec));
|
||||||
|
if (!dst->ctrls)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
memcpy(dst->ctrls, src->ctrls, sizeof(XkbControlsRec));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (dst->ctrls) {
|
||||||
|
xfree(dst->ctrls);
|
||||||
|
dst->ctrls = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy an XKB map from src to dst, reallocating when necessary: if some
|
||||||
|
* map components are present in one, but not in the other, the destination
|
||||||
|
* components will be allocated or freed as necessary.
|
||||||
|
*
|
||||||
|
* Basic map consistency is assumed on both sides, so maps with random
|
||||||
|
* uninitialised data (e.g. names->radio_grous == NULL, names->num_rg == 19)
|
||||||
|
* _will_ cause failures. You've been warned.
|
||||||
|
*
|
||||||
|
* Returns TRUE on success, or FALSE on failure. If this function fails,
|
||||||
|
* dst may be in an inconsistent state: all its pointers are guaranteed
|
||||||
|
* to remain valid, but part of the map may be from src and part from dst.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
Bool
|
||||||
|
XkbCopyKeymap(XkbDescPtr src, XkbDescPtr dst, Bool sendNotifies)
|
||||||
|
{
|
||||||
|
DeviceIntPtr pDev = NULL, tmpDev = NULL;
|
||||||
|
xkbMapNotify mn;
|
||||||
|
xkbNewKeyboardNotify nkn;
|
||||||
|
|
||||||
|
if (!src || !dst || src == dst)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (!_XkbCopyClientMap(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyServerMap(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyIndicators(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyControls(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyNames(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyCompat(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
if (!_XkbCopyGeom(src, dst))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (inputInfo.keyboard->key->xkbInfo &&
|
||||||
|
inputInfo.keyboard->key->xkbInfo->desc == dst) {
|
||||||
|
pDev = inputInfo.keyboard;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
for (tmpDev = inputInfo.devices; tmpDev && !pDev;
|
||||||
|
tmpDev = tmpDev->next) {
|
||||||
|
if (tmpDev->key && tmpDev->key->xkbInfo &&
|
||||||
tmpDev->key->xkbInfo->desc == dst) {
|
tmpDev->key->xkbInfo->desc == dst) {
|
||||||
pDev = tmpDev;
|
pDev = tmpDev;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (tmpDev = inputInfo.off_devices; tmpDev && !pDev;
|
||||||
|
tmpDev = tmpDev->next) {
|
||||||
|
if (tmpDev->key && tmpDev->key->xkbInfo &&
|
||||||
|
tmpDev->key->xkbInfo->desc == dst) {
|
||||||
|
pDev = tmpDev;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue