From efdb05d193febfc519f9fe9b770925f27f6a6df1 Mon Sep 17 00:00:00 2001 From: Yuichiro Hanada Date: Sat, 27 Jan 2024 23:00:28 +0900 Subject: [PATCH] parser: Do now allow the empty symbol declaration An empty element is allowed in SymbolsBody definition, so the following keymap is gramatically correct. ``` xkb_keymap { ... xkb_symbols "sym" { key {, [Space] }; }; }; ``` However, the current parser crashes with the keymap due to null pointer access. This change fixes it by changing the parser not to allow it. --- src/xkbcomp/parser.y | 1 - test/data/keymaps/empty-symbol-decl.xkb | 10 ++++++++++ test/filecomp.c | 1 + 3 files changed, 11 insertions(+), 1 deletion(-) create mode 100644 test/data/keymaps/empty-symbol-decl.xkb diff --git a/src/xkbcomp/parser.y b/src/xkbcomp/parser.y index 0fd663ac7..0dafedd96 100644 --- a/src/xkbcomp/parser.y +++ b/src/xkbcomp/parser.y @@ -465,7 +465,6 @@ SymbolsBody : SymbolsBody COMMA SymbolsVarDecl { $$.head = $1.head; $$.last->common.next = &$3->common; $$.last = $3; } | SymbolsVarDecl { $$.head = $$.last = $1; } - | { $$.head = $$.last = NULL; } ; SymbolsVarDecl : Lhs EQUALS Expr { $$ = VarCreate($1, $3); } diff --git a/test/data/keymaps/empty-symbol-decl.xkb b/test/data/keymaps/empty-symbol-decl.xkb new file mode 100644 index 000000000..06e5b0c35 --- /dev/null +++ b/test/data/keymaps/empty-symbol-decl.xkb @@ -0,0 +1,10 @@ +xkb_keymap { + xkb_keycodes { include "evdev+aliases(qwerty)" }; + xkb_types { include "complete" }; + xkb_compat { include "complete" }; + xkb_symbols "sym" { + // This syntax caused the crash in parser before, and is not accepted + // anymore. + key { , [Space] }; + }; +}; diff --git a/test/filecomp.c b/test/filecomp.c index e73dc4c36..116ffe803 100644 --- a/test/filecomp.c +++ b/test/filecomp.c @@ -54,6 +54,7 @@ main(void) assert(!test_file(ctx, "keymaps/bad.xkb")); assert(!test_file(ctx, "keymaps/syntax-error.xkb")); assert(!test_file(ctx, "keymaps/syntax-error2.xkb")); + assert(!test_file(ctx, "keymaps/empty-symbol-decl.xkb")); assert(!test_file(ctx, "does not exist")); /* Test response to invalid flags and formats. */