Commit c98265ab authored by Daniel Stone's avatar Daniel Stone Committed by Ulrich Sibiller

makekeys: Scan vendor keysyms as well as core

Since we can't really live without vendor keysyms, scan them all in to generate ks_tables.h, rather than only doing the core ones, and leaving the vendor syms to be manually synchronised with XKeysymDB. Signed-off-by: 's avatarDaniel Stone <daniel@fooishbar.org> Reviewed-by: 's avatarAlan Coopersmith <alan.coopersmith@oracle.com>
parent 70327993
...@@ -51,58 +51,94 @@ static unsigned short offsets[KTNUM]; ...@@ -51,58 +51,94 @@ static unsigned short offsets[KTNUM];
static unsigned short indexes[KTNUM]; static unsigned short indexes[KTNUM];
static KeySym values[KTNUM]; static KeySym values[KTNUM];
static char buf[1024]; static char buf[1024];
static int ksnum = 0;
static int
parse_line(const char *buf, char *key, KeySym *val, char *prefix)
{
int i;
char alias[128];
char *tmp, *tmpa;
/* See if we can catch a straight XK_foo 0x1234-style definition first;
* the trickery around tmp is to account for prefices. */
i = sscanf(buf, "#define %127s 0x%lx", key, val);
if (i == 2 && (tmp = strstr(key, "XK_"))) {
memcpy(prefix, key, tmp - key);
prefix[tmp - key] = '\0';
tmp += 3;
memmove(key, tmp, strlen(tmp) + 1);
return 1;
}
/* Now try to catch alias (XK_foo XK_bar) definitions, and resolve them
* immediately: if the target is in the form XF86XK_foo, we need to
* canonicalise this to XF86foo before we do the lookup. */
i = sscanf(buf, "#define %127s %127s", key, alias);
if (i == 2 && (tmp = strstr(key, "XK_")) && (tmpa = strstr(alias, "XK_"))) {
memcpy(prefix, key, tmp - key);
prefix[tmp - key] = '\0';
tmp += 3;
memmove(key, tmp, strlen(tmp) + 1);
memmove(tmpa, tmpa + 3, strlen(tmpa + 3) + 1);
for (i = ksnum - 1; i >= 0; i--) {
if (strcmp(info[i].name, alias) == 0) {
*val = info[i].val;
return 1;
}
}
fprintf(stderr, "can't find matching definition %s for keysym %s%s\n",
alias, prefix, key);
}
return 0;
}
int int
main(int argc, char *argv[]) main(int argc, char *argv[])
{ {
int ksnum = 0;
int max_rehash; int max_rehash;
Signature sig; Signature sig;
register int i, j, k, z; int i, j, k, l, z;
register char *name; FILE *fptr;
register char c; char *name;
char c;
int first; int first;
int best_max_rehash; int best_max_rehash;
int best_z = 0; int best_z = 0;
int num_found; int num_found;
KeySym val; KeySym val;
char key[128]; char key[128], prefix[128];
char alias[128];
for (l = 1; l < argc; l++) {
while (fgets(buf, sizeof(buf), stdin)) { fptr = fopen(argv[l], "r");
i = sscanf(buf, "#define XK_%127s 0x%lx", key, &info[ksnum].val); if (!fptr) {
if (i != 2) { fprintf(stderr, "couldn't open %s\n", argv[l]);
i = sscanf(buf, "#define XK_%127s XK_%127s", key, alias);
if (i != 2)
continue; continue;
for (i = ksnum - 1; i >= 0; i--) {
if (strcmp(info[i].name, alias) == 0) {
info[ksnum].val = info[i].val;
break;
}
} }
if (i < 0) { /* Didn't find a match */
fprintf(stderr, while (fgets(buf, sizeof(buf), fptr)) {
"can't find matching definition %s for keysym %s\n", if (!parse_line(buf, key, &val, prefix))
alias, key);
continue; continue;
}
} if (val == XK_VoidSymbol)
if (info[ksnum].val == XK_VoidSymbol) val = 0;
info[ksnum].val = 0; if (val > 0x1fffffff) {
if (info[ksnum].val > 0x1fffffff) { fprintf(stderr, "ignoring illegal keysym (%s, %lx)\n", key,
fprintf(stderr, val);
"ignoring illegal keysym (%s), remove it from .h file!\n",
key);
continue; continue;
} }
name = strdup(key);
name = malloc(strlen(prefix) + strlen(key) + 1);
if (!name) { if (!name) {
fprintf(stderr, "makekeys: out of memory!\n"); fprintf(stderr, "makekeys: out of memory!\n");
exit(1); exit(1);
} }
sprintf(name, "%s%s", prefix, key);
info[ksnum].name = name; info[ksnum].name = name;
info[ksnum].val = val;
ksnum++; ksnum++;
if (ksnum == KTNUM) { if (ksnum == KTNUM) {
fprintf(stderr, "makekeys: too many keysyms!\n"); fprintf(stderr, "makekeys: too many keysyms!\n");
...@@ -110,6 +146,9 @@ main(int argc, char *argv[]) ...@@ -110,6 +146,9 @@ main(int argc, char *argv[])
} }
} }
fclose(fptr);
}
printf("/* This file is generated from keysymdef.h. */\n"); printf("/* This file is generated from keysymdef.h. */\n");
printf("/* Do not edit. */\n"); printf("/* Do not edit. */\n");
printf("\n"); printf("\n");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment