summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRan Benita <ran234@gmail.com>2014-10-17 00:13:48 +0300
committerRan Benita <ran234@gmail.com>2014-10-17 01:17:14 +0300
commita4c667adf285d8cfcfdea29cbf845abd4b180467 (patch)
treec7b421134859d2f35b0b3edd334d12f4216617e1
parent2e5530ad20bb517d0e02aa749650bbf816e3037a (diff)
downloadxorg-lib-libxkbcommon-a4c667adf285d8cfcfdea29cbf845abd4b180467.tar.gz
symbols: don't warn about conflicting syms if they are the same
Signed-off-by: Ran Benita <ran234@gmail.com>
-rw-r--r--src/xkbcomp/symbols.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/src/xkbcomp/symbols.c b/src/xkbcomp/symbols.c
index 1e70b84..bff7fb3 100644
--- a/src/xkbcomp/symbols.c
+++ b/src/xkbcomp/symbols.c
@@ -218,6 +218,19 @@ KeyInfoText(SymbolsInfo *info, KeyInfo *keyi)
}
static bool
+LevelsSameSyms(const struct xkb_level *a, const struct xkb_level *b)
+{
+ if (a->num_syms != b->num_syms)
+ return false;
+ if (a->num_syms <= 1)
+ return a->u.sym == b->u.sym;
+ else
+ return memcmp(a->u.syms, b->u.syms,
+ sizeof(*a->u.syms) * a->num_syms) == 0;
+
+}
+
+static bool
MergeGroups(SymbolsInfo *info, GroupInfo *into, GroupInfo *from, bool clobber,
bool report, xkb_layout_index_t group, xkb_atom_t key_name)
{
@@ -299,7 +312,7 @@ MergeGroups(SymbolsInfo *info, GroupInfo *into, GroupInfo *from, bool clobber,
intoLevel->u.sym = fromLevel->u.sym;
fromLevel->num_syms = 0;
}
- else {
+ else if (!LevelsSameSyms(fromLevel, intoLevel)) {
if (report)
log_warn(info->ctx,
"Multiple symbols for level %d/group %u on key %s; "