Convert interp action from xkb_any_action to xkb_action
authorDaniel Stone <daniel@fooishbar.org>
Wed, 14 Mar 2012 17:06:09 +0000 (17:06 +0000)
committerDaniel Stone <daniel@fooishbar.org>
Wed, 14 Mar 2012 17:06:09 +0000 (17:06 +0000)
Signed-off-by: Daniel Stone <daniel@fooishbar.org>
include/xkbcommon/xkbcommon.h
src/xkbcomp/compat.c

index d023b149a618c8cdf54e8905f4e800e1b8cd1225..2092680cda217e6b5dedb9f5b3b0f143967d8859 100644 (file)
@@ -231,9 +231,9 @@ struct xkb_sym_interpret {
     xkb_keysym_t    sym;
     unsigned char   flags;
     unsigned char   match;
-    uint8_t         mods; /* XXX real or virt? */
+    uint8_t         mods;
     uint32_t        virtual_mod;
-    struct xkb_any_action   act;
+    union xkb_action act;
 };
 
 struct xkb_compat_map {
index fa598972a6b58442f96caa0fad6baf3a14da7285..5483cd73ef6f019182e57db8cdc4dbac61821327 100644 (file)
@@ -117,10 +117,8 @@ InitCompatInfo(CompatInfo * info, struct xkb_desc * xkb)
     info->dflt.interp.flags = 0;
     info->dflt.interp.virtual_mod = XkbNoModifier;
     info->dflt.interp.act.type = XkbSA_NoAction;
-    for (i = 0; i < sizeof info->dflt.interp.act.data; i++)
-    {
-        info->dflt.interp.act.data[i] = 0;
-    }
+    for (i = 0; i < sizeof(info->dflt.interp.act.any.data); i++)
+        info->dflt.interp.act.any.data[i] = 0;
     ClearIndicatorMapInfo(&info->ledDflt);
     info->ledDflt.defs.fileID = info->fileID;
     info->ledDflt.defs.defined = 0;
@@ -144,10 +142,8 @@ ClearCompatInfo(CompatInfo * info, struct xkb_desc * xkb)
     info->dflt.interp.flags = 0;
     info->dflt.interp.virtual_mod = XkbNoModifier;
     info->dflt.interp.act.type = XkbSA_NoAction;
-    for (i = 0; i < sizeof info->dflt.interp.act.data; i++)
-    {
-        info->dflt.interp.act.data[i] = 0;
-    }
+    for (i = 0; i < sizeof(info->dflt.interp.act.any.data); i++)
+        info->dflt.interp.act.any.data[i] = 0;
     ClearIndicatorMapInfo(&info->ledDflt);
     info->nInterps = 0;
     info->interps = (SymInterpInfo *) ClearCommonInfo(&info->interps->defs);
@@ -509,7 +505,7 @@ SetInterpField(SymInterpInfo * si,
     {
         if (arrayNdx != NULL)
             return ReportSINotArray(si, field, info);
-        ok = HandleActionDef(value, xkb, &si->interp.act, si->defs.merge,
+        ok = HandleActionDef(value, xkb, &si->interp.act.any, si->defs.merge,
                              info->act);
         if (ok)
             si->defs.defined |= _SI_Action;