xkbcomp: Don't crash on no-op modmask expressions
If we have an expression of the form 'l1' in an interp section, we unconditionally try to dereference its args, even if it has none. Signed-off-by: Daniel Stone <daniels@collabora.com>master
parent
a8ea7a1d3d
commit
96df3106d4
|
@ -264,7 +264,8 @@ ResolveStateAndPredicate(ExprDef *expr, enum xkb_match_operation *pred_rtrn,
|
|||
*pred_rtrn = MATCH_EXACTLY;
|
||||
if (expr->expr.op == EXPR_ACTION_DECL) {
|
||||
const char *pred_txt = xkb_atom_text(info->ctx, expr->action.name);
|
||||
if (!LookupString(symInterpretMatchMaskNames, pred_txt, pred_rtrn)) {
|
||||
if (!LookupString(symInterpretMatchMaskNames, pred_txt, pred_rtrn) ||
|
||||
!expr->action.args) {
|
||||
log_err(info->ctx,
|
||||
"Illegal modifier predicate \"%s\"; Ignored\n", pred_txt);
|
||||
return false;
|
||||
|
|
Loading…
Reference in New Issue