1*2b949d04SAndroid Build Coastguard Worker /*
2*2b949d04SAndroid Build Coastguard Worker * Copyright © 2009 Dan Nicholson <[email protected]>
3*2b949d04SAndroid Build Coastguard Worker * Copyright © 2012 Intel Corporation
4*2b949d04SAndroid Build Coastguard Worker * Copyright © 2012 Ran Benita <[email protected]>
5*2b949d04SAndroid Build Coastguard Worker *
6*2b949d04SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
7*2b949d04SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
8*2b949d04SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
9*2b949d04SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10*2b949d04SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
11*2b949d04SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
12*2b949d04SAndroid Build Coastguard Worker *
13*2b949d04SAndroid Build Coastguard Worker * The above copyright notice and this permission notice shall be included in
14*2b949d04SAndroid Build Coastguard Worker * all copies or substantial portions of the Software.
15*2b949d04SAndroid Build Coastguard Worker *
16*2b949d04SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*2b949d04SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*2b949d04SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*2b949d04SAndroid Build Coastguard Worker * AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
20*2b949d04SAndroid Build Coastguard Worker * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
21*2b949d04SAndroid Build Coastguard Worker * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22*2b949d04SAndroid Build Coastguard Worker *
23*2b949d04SAndroid Build Coastguard Worker * Except as contained in this notice, the names of the authors or their
24*2b949d04SAndroid Build Coastguard Worker * institutions shall not be used in advertising or otherwise to promote the
25*2b949d04SAndroid Build Coastguard Worker * sale, use or other dealings in this Software without prior written
26*2b949d04SAndroid Build Coastguard Worker * authorization from the authors.
27*2b949d04SAndroid Build Coastguard Worker *
28*2b949d04SAndroid Build Coastguard Worker * Author: Dan Nicholson <[email protected]>
29*2b949d04SAndroid Build Coastguard Worker * Daniel Stone <[email protected]>
30*2b949d04SAndroid Build Coastguard Worker * Ran Benita <[email protected]>
31*2b949d04SAndroid Build Coastguard Worker */
32*2b949d04SAndroid Build Coastguard Worker
33*2b949d04SAndroid Build Coastguard Worker #include "config.h"
34*2b949d04SAndroid Build Coastguard Worker
35*2b949d04SAndroid Build Coastguard Worker #include <limits.h>
36*2b949d04SAndroid Build Coastguard Worker #include <fcntl.h>
37*2b949d04SAndroid Build Coastguard Worker #include <sys/types.h>
38*2b949d04SAndroid Build Coastguard Worker #include <sys/stat.h>
39*2b949d04SAndroid Build Coastguard Worker #ifdef _MSC_VER
40*2b949d04SAndroid Build Coastguard Worker #include <io.h>
41*2b949d04SAndroid Build Coastguard Worker #include <windows.h>
42*2b949d04SAndroid Build Coastguard Worker #else
43*2b949d04SAndroid Build Coastguard Worker #include <unistd.h>
44*2b949d04SAndroid Build Coastguard Worker #include <termios.h>
45*2b949d04SAndroid Build Coastguard Worker #endif
46*2b949d04SAndroid Build Coastguard Worker
47*2b949d04SAndroid Build Coastguard Worker #include "test.h"
48*2b949d04SAndroid Build Coastguard Worker #include "utils.h"
49*2b949d04SAndroid Build Coastguard Worker
50*2b949d04SAndroid Build Coastguard Worker /*
51*2b949d04SAndroid Build Coastguard Worker * Test a sequence of keysyms, resulting from a sequence of key presses,
52*2b949d04SAndroid Build Coastguard Worker * against the keysyms they're supposed to generate.
53*2b949d04SAndroid Build Coastguard Worker *
54*2b949d04SAndroid Build Coastguard Worker * - Each test runs with a clean state.
55*2b949d04SAndroid Build Coastguard Worker * - Each line in the test is made up of:
56*2b949d04SAndroid Build Coastguard Worker * + A keycode, given as a KEY_* from linux/input.h.
57*2b949d04SAndroid Build Coastguard Worker * + A direction - DOWN for press, UP for release, BOTH for
58*2b949d04SAndroid Build Coastguard Worker * immediate press + release, REPEAT to just get the syms.
59*2b949d04SAndroid Build Coastguard Worker * + A sequence of keysyms that should result from this keypress.
60*2b949d04SAndroid Build Coastguard Worker *
61*2b949d04SAndroid Build Coastguard Worker * The vararg format is:
62*2b949d04SAndroid Build Coastguard Worker * <KEY_*> <DOWN | UP | BOTH> <XKB_KEY_* (zero or more)> <NEXT | FINISH>
63*2b949d04SAndroid Build Coastguard Worker *
64*2b949d04SAndroid Build Coastguard Worker * See below for examples.
65*2b949d04SAndroid Build Coastguard Worker */
66*2b949d04SAndroid Build Coastguard Worker int
test_key_seq_va(struct xkb_keymap * keymap,va_list ap)67*2b949d04SAndroid Build Coastguard Worker test_key_seq_va(struct xkb_keymap *keymap, va_list ap)
68*2b949d04SAndroid Build Coastguard Worker {
69*2b949d04SAndroid Build Coastguard Worker struct xkb_state *state;
70*2b949d04SAndroid Build Coastguard Worker
71*2b949d04SAndroid Build Coastguard Worker xkb_keycode_t kc;
72*2b949d04SAndroid Build Coastguard Worker int op;
73*2b949d04SAndroid Build Coastguard Worker xkb_keysym_t keysym;
74*2b949d04SAndroid Build Coastguard Worker
75*2b949d04SAndroid Build Coastguard Worker const xkb_keysym_t *syms;
76*2b949d04SAndroid Build Coastguard Worker xkb_keysym_t sym;
77*2b949d04SAndroid Build Coastguard Worker unsigned int nsyms, i;
78*2b949d04SAndroid Build Coastguard Worker char ksbuf[64];
79*2b949d04SAndroid Build Coastguard Worker
80*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "----\n");
81*2b949d04SAndroid Build Coastguard Worker
82*2b949d04SAndroid Build Coastguard Worker state = xkb_state_new(keymap);
83*2b949d04SAndroid Build Coastguard Worker assert(state);
84*2b949d04SAndroid Build Coastguard Worker
85*2b949d04SAndroid Build Coastguard Worker for (;;) {
86*2b949d04SAndroid Build Coastguard Worker kc = va_arg(ap, int) + EVDEV_OFFSET;
87*2b949d04SAndroid Build Coastguard Worker op = va_arg(ap, int);
88*2b949d04SAndroid Build Coastguard Worker
89*2b949d04SAndroid Build Coastguard Worker nsyms = xkb_state_key_get_syms(state, kc, &syms);
90*2b949d04SAndroid Build Coastguard Worker if (nsyms == 1) {
91*2b949d04SAndroid Build Coastguard Worker sym = xkb_state_key_get_one_sym(state, kc);
92*2b949d04SAndroid Build Coastguard Worker syms = &sym;
93*2b949d04SAndroid Build Coastguard Worker }
94*2b949d04SAndroid Build Coastguard Worker
95*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "got %u syms for keycode %u: [", nsyms, kc);
96*2b949d04SAndroid Build Coastguard Worker
97*2b949d04SAndroid Build Coastguard Worker if (op == DOWN || op == BOTH)
98*2b949d04SAndroid Build Coastguard Worker xkb_state_update_key(state, kc, XKB_KEY_DOWN);
99*2b949d04SAndroid Build Coastguard Worker if (op == UP || op == BOTH)
100*2b949d04SAndroid Build Coastguard Worker xkb_state_update_key(state, kc, XKB_KEY_UP);
101*2b949d04SAndroid Build Coastguard Worker
102*2b949d04SAndroid Build Coastguard Worker for (i = 0; i < nsyms; i++) {
103*2b949d04SAndroid Build Coastguard Worker keysym = va_arg(ap, int);
104*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(syms[i], ksbuf, sizeof(ksbuf));
105*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "%s%s", (i != 0) ? ", " : "", ksbuf);
106*2b949d04SAndroid Build Coastguard Worker
107*2b949d04SAndroid Build Coastguard Worker if (keysym == FINISH || keysym == NEXT) {
108*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(syms[i], ksbuf, sizeof(ksbuf));
109*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Did not expect keysym: %s.\n", ksbuf);
110*2b949d04SAndroid Build Coastguard Worker goto fail;
111*2b949d04SAndroid Build Coastguard Worker }
112*2b949d04SAndroid Build Coastguard Worker
113*2b949d04SAndroid Build Coastguard Worker if (keysym != syms[i]) {
114*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(keysym, ksbuf, sizeof(ksbuf));
115*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Expected keysym: %s. ", ksbuf);;
116*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(syms[i], ksbuf, sizeof(ksbuf));
117*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Got keysym: %s.\n", ksbuf);;
118*2b949d04SAndroid Build Coastguard Worker goto fail;
119*2b949d04SAndroid Build Coastguard Worker }
120*2b949d04SAndroid Build Coastguard Worker }
121*2b949d04SAndroid Build Coastguard Worker
122*2b949d04SAndroid Build Coastguard Worker if (nsyms == 0) {
123*2b949d04SAndroid Build Coastguard Worker keysym = va_arg(ap, int);
124*2b949d04SAndroid Build Coastguard Worker if (keysym != XKB_KEY_NoSymbol) {
125*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(keysym, ksbuf, sizeof(ksbuf));
126*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Expected %s, but got no keysyms.\n", ksbuf);
127*2b949d04SAndroid Build Coastguard Worker goto fail;
128*2b949d04SAndroid Build Coastguard Worker }
129*2b949d04SAndroid Build Coastguard Worker }
130*2b949d04SAndroid Build Coastguard Worker
131*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "]\n");
132*2b949d04SAndroid Build Coastguard Worker
133*2b949d04SAndroid Build Coastguard Worker keysym = va_arg(ap, int);
134*2b949d04SAndroid Build Coastguard Worker if (keysym == NEXT)
135*2b949d04SAndroid Build Coastguard Worker continue;
136*2b949d04SAndroid Build Coastguard Worker if (keysym == FINISH)
137*2b949d04SAndroid Build Coastguard Worker break;
138*2b949d04SAndroid Build Coastguard Worker
139*2b949d04SAndroid Build Coastguard Worker xkb_keysym_get_name(keysym, ksbuf, sizeof(ksbuf));
140*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Expected keysym: %s. Didn't get it.\n", ksbuf);
141*2b949d04SAndroid Build Coastguard Worker goto fail;
142*2b949d04SAndroid Build Coastguard Worker }
143*2b949d04SAndroid Build Coastguard Worker
144*2b949d04SAndroid Build Coastguard Worker xkb_state_unref(state);
145*2b949d04SAndroid Build Coastguard Worker return 1;
146*2b949d04SAndroid Build Coastguard Worker
147*2b949d04SAndroid Build Coastguard Worker fail:
148*2b949d04SAndroid Build Coastguard Worker xkb_state_unref(state);
149*2b949d04SAndroid Build Coastguard Worker return 0;
150*2b949d04SAndroid Build Coastguard Worker }
151*2b949d04SAndroid Build Coastguard Worker
152*2b949d04SAndroid Build Coastguard Worker int
test_key_seq(struct xkb_keymap * keymap,...)153*2b949d04SAndroid Build Coastguard Worker test_key_seq(struct xkb_keymap *keymap, ...)
154*2b949d04SAndroid Build Coastguard Worker {
155*2b949d04SAndroid Build Coastguard Worker va_list ap;
156*2b949d04SAndroid Build Coastguard Worker int ret;
157*2b949d04SAndroid Build Coastguard Worker
158*2b949d04SAndroid Build Coastguard Worker va_start(ap, keymap);
159*2b949d04SAndroid Build Coastguard Worker ret = test_key_seq_va(keymap, ap);
160*2b949d04SAndroid Build Coastguard Worker va_end(ap);
161*2b949d04SAndroid Build Coastguard Worker
162*2b949d04SAndroid Build Coastguard Worker return ret;
163*2b949d04SAndroid Build Coastguard Worker }
164*2b949d04SAndroid Build Coastguard Worker
165*2b949d04SAndroid Build Coastguard Worker char *
test_get_path(const char * path_rel)166*2b949d04SAndroid Build Coastguard Worker test_get_path(const char *path_rel)
167*2b949d04SAndroid Build Coastguard Worker {
168*2b949d04SAndroid Build Coastguard Worker char *path;
169*2b949d04SAndroid Build Coastguard Worker const char *srcdir;
170*2b949d04SAndroid Build Coastguard Worker
171*2b949d04SAndroid Build Coastguard Worker srcdir = getenv("top_srcdir");
172*2b949d04SAndroid Build Coastguard Worker if (!srcdir)
173*2b949d04SAndroid Build Coastguard Worker srcdir = ".";
174*2b949d04SAndroid Build Coastguard Worker
175*2b949d04SAndroid Build Coastguard Worker if (path_rel[0] == '/')
176*2b949d04SAndroid Build Coastguard Worker return strdup(path_rel);
177*2b949d04SAndroid Build Coastguard Worker
178*2b949d04SAndroid Build Coastguard Worker path = asprintf_safe("%s/test/data%s%s", srcdir,
179*2b949d04SAndroid Build Coastguard Worker path_rel[0] ? "/" : "", path_rel);
180*2b949d04SAndroid Build Coastguard Worker if (!path) {
181*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Failed to allocate path for %s\n", path_rel);
182*2b949d04SAndroid Build Coastguard Worker return NULL;
183*2b949d04SAndroid Build Coastguard Worker }
184*2b949d04SAndroid Build Coastguard Worker return path;
185*2b949d04SAndroid Build Coastguard Worker }
186*2b949d04SAndroid Build Coastguard Worker
187*2b949d04SAndroid Build Coastguard Worker char *
test_read_file(const char * path_rel)188*2b949d04SAndroid Build Coastguard Worker test_read_file(const char *path_rel)
189*2b949d04SAndroid Build Coastguard Worker {
190*2b949d04SAndroid Build Coastguard Worker struct stat info;
191*2b949d04SAndroid Build Coastguard Worker char *ret, *tmp, *path;
192*2b949d04SAndroid Build Coastguard Worker int fd, count, remaining;
193*2b949d04SAndroid Build Coastguard Worker
194*2b949d04SAndroid Build Coastguard Worker path = test_get_path(path_rel);
195*2b949d04SAndroid Build Coastguard Worker if (!path)
196*2b949d04SAndroid Build Coastguard Worker return NULL;
197*2b949d04SAndroid Build Coastguard Worker
198*2b949d04SAndroid Build Coastguard Worker fd = open(path, O_RDONLY);
199*2b949d04SAndroid Build Coastguard Worker free(path);
200*2b949d04SAndroid Build Coastguard Worker if (fd < 0)
201*2b949d04SAndroid Build Coastguard Worker return NULL;
202*2b949d04SAndroid Build Coastguard Worker
203*2b949d04SAndroid Build Coastguard Worker if (fstat(fd, &info) != 0) {
204*2b949d04SAndroid Build Coastguard Worker close(fd);
205*2b949d04SAndroid Build Coastguard Worker return NULL;
206*2b949d04SAndroid Build Coastguard Worker }
207*2b949d04SAndroid Build Coastguard Worker
208*2b949d04SAndroid Build Coastguard Worker ret = malloc(info.st_size + 1);
209*2b949d04SAndroid Build Coastguard Worker if (!ret) {
210*2b949d04SAndroid Build Coastguard Worker close(fd);
211*2b949d04SAndroid Build Coastguard Worker return NULL;
212*2b949d04SAndroid Build Coastguard Worker }
213*2b949d04SAndroid Build Coastguard Worker
214*2b949d04SAndroid Build Coastguard Worker remaining = info.st_size;
215*2b949d04SAndroid Build Coastguard Worker tmp = ret;
216*2b949d04SAndroid Build Coastguard Worker while ((count = read(fd, tmp, remaining))) {
217*2b949d04SAndroid Build Coastguard Worker remaining -= count;
218*2b949d04SAndroid Build Coastguard Worker tmp += count;
219*2b949d04SAndroid Build Coastguard Worker }
220*2b949d04SAndroid Build Coastguard Worker ret[info.st_size] = '\0';
221*2b949d04SAndroid Build Coastguard Worker close(fd);
222*2b949d04SAndroid Build Coastguard Worker
223*2b949d04SAndroid Build Coastguard Worker if (remaining != 0) {
224*2b949d04SAndroid Build Coastguard Worker free(ret);
225*2b949d04SAndroid Build Coastguard Worker return NULL;
226*2b949d04SAndroid Build Coastguard Worker }
227*2b949d04SAndroid Build Coastguard Worker
228*2b949d04SAndroid Build Coastguard Worker return ret;
229*2b949d04SAndroid Build Coastguard Worker }
230*2b949d04SAndroid Build Coastguard Worker
231*2b949d04SAndroid Build Coastguard Worker struct xkb_context *
test_get_context(enum test_context_flags test_flags)232*2b949d04SAndroid Build Coastguard Worker test_get_context(enum test_context_flags test_flags)
233*2b949d04SAndroid Build Coastguard Worker {
234*2b949d04SAndroid Build Coastguard Worker enum xkb_context_flags ctx_flags;
235*2b949d04SAndroid Build Coastguard Worker struct xkb_context *ctx;
236*2b949d04SAndroid Build Coastguard Worker char *path;
237*2b949d04SAndroid Build Coastguard Worker
238*2b949d04SAndroid Build Coastguard Worker ctx_flags = XKB_CONTEXT_NO_DEFAULT_INCLUDES;
239*2b949d04SAndroid Build Coastguard Worker if (test_flags & CONTEXT_ALLOW_ENVIRONMENT_NAMES) {
240*2b949d04SAndroid Build Coastguard Worker unsetenv("XKB_DEFAULT_RULES");
241*2b949d04SAndroid Build Coastguard Worker unsetenv("XKB_DEFAULT_MODEL");
242*2b949d04SAndroid Build Coastguard Worker unsetenv("XKB_DEFAULT_LAYOUT");
243*2b949d04SAndroid Build Coastguard Worker unsetenv("XKB_DEFAULT_VARIANT");
244*2b949d04SAndroid Build Coastguard Worker unsetenv("XKB_DEFAULT_OPTIONS");
245*2b949d04SAndroid Build Coastguard Worker }
246*2b949d04SAndroid Build Coastguard Worker else {
247*2b949d04SAndroid Build Coastguard Worker ctx_flags |= XKB_CONTEXT_NO_ENVIRONMENT_NAMES;
248*2b949d04SAndroid Build Coastguard Worker }
249*2b949d04SAndroid Build Coastguard Worker
250*2b949d04SAndroid Build Coastguard Worker ctx = xkb_context_new(ctx_flags);
251*2b949d04SAndroid Build Coastguard Worker if (!ctx)
252*2b949d04SAndroid Build Coastguard Worker return NULL;
253*2b949d04SAndroid Build Coastguard Worker
254*2b949d04SAndroid Build Coastguard Worker path = test_get_path("");
255*2b949d04SAndroid Build Coastguard Worker if (!path) {
256*2b949d04SAndroid Build Coastguard Worker xkb_context_unref(ctx);
257*2b949d04SAndroid Build Coastguard Worker return NULL;
258*2b949d04SAndroid Build Coastguard Worker }
259*2b949d04SAndroid Build Coastguard Worker
260*2b949d04SAndroid Build Coastguard Worker xkb_context_include_path_append(ctx, path);
261*2b949d04SAndroid Build Coastguard Worker free(path);
262*2b949d04SAndroid Build Coastguard Worker
263*2b949d04SAndroid Build Coastguard Worker return ctx;
264*2b949d04SAndroid Build Coastguard Worker }
265*2b949d04SAndroid Build Coastguard Worker
266*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *
test_compile_file(struct xkb_context * context,const char * path_rel)267*2b949d04SAndroid Build Coastguard Worker test_compile_file(struct xkb_context *context, const char *path_rel)
268*2b949d04SAndroid Build Coastguard Worker {
269*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *keymap;
270*2b949d04SAndroid Build Coastguard Worker FILE *file;
271*2b949d04SAndroid Build Coastguard Worker char *path;
272*2b949d04SAndroid Build Coastguard Worker
273*2b949d04SAndroid Build Coastguard Worker path = test_get_path(path_rel);
274*2b949d04SAndroid Build Coastguard Worker if (!path)
275*2b949d04SAndroid Build Coastguard Worker return NULL;
276*2b949d04SAndroid Build Coastguard Worker
277*2b949d04SAndroid Build Coastguard Worker file = fopen(path, "rb");
278*2b949d04SAndroid Build Coastguard Worker if (!file) {
279*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Failed to open path: %s\n", path);
280*2b949d04SAndroid Build Coastguard Worker free(path);
281*2b949d04SAndroid Build Coastguard Worker return NULL;
282*2b949d04SAndroid Build Coastguard Worker }
283*2b949d04SAndroid Build Coastguard Worker assert(file != NULL);
284*2b949d04SAndroid Build Coastguard Worker
285*2b949d04SAndroid Build Coastguard Worker keymap = xkb_keymap_new_from_file(context, file,
286*2b949d04SAndroid Build Coastguard Worker XKB_KEYMAP_FORMAT_TEXT_V1, 0);
287*2b949d04SAndroid Build Coastguard Worker fclose(file);
288*2b949d04SAndroid Build Coastguard Worker
289*2b949d04SAndroid Build Coastguard Worker if (!keymap) {
290*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Failed to compile path: %s\n", path);
291*2b949d04SAndroid Build Coastguard Worker free(path);
292*2b949d04SAndroid Build Coastguard Worker return NULL;
293*2b949d04SAndroid Build Coastguard Worker }
294*2b949d04SAndroid Build Coastguard Worker
295*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Successfully compiled path: %s\n", path);
296*2b949d04SAndroid Build Coastguard Worker free(path);
297*2b949d04SAndroid Build Coastguard Worker
298*2b949d04SAndroid Build Coastguard Worker return keymap;
299*2b949d04SAndroid Build Coastguard Worker }
300*2b949d04SAndroid Build Coastguard Worker
301*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *
test_compile_string(struct xkb_context * context,const char * string)302*2b949d04SAndroid Build Coastguard Worker test_compile_string(struct xkb_context *context, const char *string)
303*2b949d04SAndroid Build Coastguard Worker {
304*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *keymap;
305*2b949d04SAndroid Build Coastguard Worker
306*2b949d04SAndroid Build Coastguard Worker keymap = xkb_keymap_new_from_string(context, string,
307*2b949d04SAndroid Build Coastguard Worker XKB_KEYMAP_FORMAT_TEXT_V1, 0);
308*2b949d04SAndroid Build Coastguard Worker if (!keymap) {
309*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Failed to compile string\n");
310*2b949d04SAndroid Build Coastguard Worker return NULL;
311*2b949d04SAndroid Build Coastguard Worker }
312*2b949d04SAndroid Build Coastguard Worker
313*2b949d04SAndroid Build Coastguard Worker return keymap;
314*2b949d04SAndroid Build Coastguard Worker }
315*2b949d04SAndroid Build Coastguard Worker
316*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *
test_compile_buffer(struct xkb_context * context,const char * buf,size_t len)317*2b949d04SAndroid Build Coastguard Worker test_compile_buffer(struct xkb_context *context, const char *buf, size_t len)
318*2b949d04SAndroid Build Coastguard Worker {
319*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *keymap;
320*2b949d04SAndroid Build Coastguard Worker
321*2b949d04SAndroid Build Coastguard Worker keymap = xkb_keymap_new_from_buffer(context, buf, len,
322*2b949d04SAndroid Build Coastguard Worker XKB_KEYMAP_FORMAT_TEXT_V1, 0);
323*2b949d04SAndroid Build Coastguard Worker if (!keymap) {
324*2b949d04SAndroid Build Coastguard Worker fprintf(stderr, "Failed to compile keymap from memory buffer\n");
325*2b949d04SAndroid Build Coastguard Worker return NULL;
326*2b949d04SAndroid Build Coastguard Worker }
327*2b949d04SAndroid Build Coastguard Worker
328*2b949d04SAndroid Build Coastguard Worker return keymap;
329*2b949d04SAndroid Build Coastguard Worker }
330*2b949d04SAndroid Build Coastguard Worker
331*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *
test_compile_rules(struct xkb_context * context,const char * rules,const char * model,const char * layout,const char * variant,const char * options)332*2b949d04SAndroid Build Coastguard Worker test_compile_rules(struct xkb_context *context, const char *rules,
333*2b949d04SAndroid Build Coastguard Worker const char *model, const char *layout,
334*2b949d04SAndroid Build Coastguard Worker const char *variant, const char *options)
335*2b949d04SAndroid Build Coastguard Worker {
336*2b949d04SAndroid Build Coastguard Worker struct xkb_keymap *keymap;
337*2b949d04SAndroid Build Coastguard Worker struct xkb_rule_names rmlvo = {
338*2b949d04SAndroid Build Coastguard Worker .rules = isempty(rules) ? NULL : rules,
339*2b949d04SAndroid Build Coastguard Worker .model = isempty(model) ? NULL : model,
340*2b949d04SAndroid Build Coastguard Worker .layout = isempty(layout) ? NULL : layout,
341*2b949d04SAndroid Build Coastguard Worker .variant = isempty(variant) ? NULL : variant,
342*2b949d04SAndroid Build Coastguard Worker .options = isempty(options) ? NULL : options
343*2b949d04SAndroid Build Coastguard Worker };
344*2b949d04SAndroid Build Coastguard Worker
345*2b949d04SAndroid Build Coastguard Worker if (!rules && !model && !layout && !variant && !options)
346*2b949d04SAndroid Build Coastguard Worker keymap = xkb_keymap_new_from_names(context, NULL, 0);
347*2b949d04SAndroid Build Coastguard Worker else
348*2b949d04SAndroid Build Coastguard Worker keymap = xkb_keymap_new_from_names(context, &rmlvo, 0);
349*2b949d04SAndroid Build Coastguard Worker
350*2b949d04SAndroid Build Coastguard Worker if (!keymap) {
351*2b949d04SAndroid Build Coastguard Worker fprintf(stderr,
352*2b949d04SAndroid Build Coastguard Worker "Failed to compile RMLVO: '%s', '%s', '%s', '%s', '%s'\n",
353*2b949d04SAndroid Build Coastguard Worker rules, model, layout, variant, options);
354*2b949d04SAndroid Build Coastguard Worker return NULL;
355*2b949d04SAndroid Build Coastguard Worker }
356*2b949d04SAndroid Build Coastguard Worker
357*2b949d04SAndroid Build Coastguard Worker return keymap;
358*2b949d04SAndroid Build Coastguard Worker }
359