Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

xkbcomp: Some lists are not allowed to be empty #565

Open
wismill opened this issue Dec 19, 2024 · 6 comments
Open

xkbcomp: Some lists are not allowed to be empty #565

wismill opened this issue Dec 19, 2024 · 6 comments
Labels
X11 legacy: compatibility Indicate a need to ensure compatibility with X11

Comments

@wismill
Copy link
Member

wismill commented Dec 19, 2024

(Follow-up of this comment

The following syntax does not parse in xkbcommon, but it does in xkbcomp:

xkb_symbols "x" {
    key <AC12> { };
};

While the usefulness of such statement is debatable, the fact that it does parse in xkbcomp and that tools may generate such keymap entry make it relevant to handle.

There are other places we could allow empty lists as well.

CC @mahkoh who detected this issue

@wismill wismill added the X11 legacy: compatibility Indicate a need to ensure compatibility with X11 label Dec 19, 2024
@mahkoh
Copy link

mahkoh commented Dec 19, 2024

Sorry that's not actually what I meant in that comment. I forgot that xkbcommon doesn't parse empty blocks so my example was a bit too simplified. And, in fact, keys are not affected at all by what I meant.

What I meant is the following:

static bool
UseNewInterpField(enum si_field field, SymInterpInfo *old, SymInterpInfo *new,
                  bool report, enum si_field *collide)
{
    if (!(old->defined & field))
        return true;

but, correctly for keys:

static bool
UseNewKeyField(enum key_field field, enum key_field old, enum key_field new,
               bool clobber, bool report, enum key_field *collide)
{
    if (!(old & field))
        return (new & field);

Example:

        interpret A {
            repeat = true;
        };
        interpret A {
            repeat = true;
        };
        augment interpret A {
            action = SetMods(mods=Mod1);
        };

Output:

	interpret A+AnyOfOrNone(all) {
		repeat= True;
		action= NoAction();
	};

Removing the second interpret produces the correct output:

	interpret A+AnyOfOrNone(all) {
		repeat= True;
		action= SetMods(modifiers=Mod1);
	};

@wismill
Copy link
Member Author

wismill commented Dec 19, 2024

I forgot that xkbcommon doesn't parse empty blocks

@mahkoh Do you have a list of such blocks or is it all of them? I think that the key one is the most relevant (fixed in #567), but I doubt it’s worth to fix them all.

@mahkoh
Copy link

mahkoh commented Dec 19, 2024

I believe this can be determined easily by looking at parser.y. I believe that most lists do not allow empty interiors. E.g.

ActionList      :       ActionList COMMA Action
                        { $$ = ExprAppendActionList($1, $3); }
                |       Action COMMA Action
                        {
                            $$ = ExprCreateActionList($1);
                            $$ = ExprAppendActionList($$, $3);
                        }
                ;

requires at least 2 elements.

VarDeclList     :       VarDeclList VarDecl
                        { $$.head = $1.head; $$.last->common.next = &$2->common; $$.last = $2; }
                |       VarDecl
                        { $$.head = $$.last = $1; }
                ;

requires at least 1 element.

@wismill
Copy link
Member Author

wismill commented Dec 19, 2024

ActionList […] requires at least 2 elements.

@mahkoh Correct: We do not allow e.g. [{NoAction()}], only its canonical form [NoAction()]. I do think it makes sense to allow it.

VarDeclList […] requires at least 1 element.

I am not sure if there is a relevant use case for this, other than xkbcomp compatibility. While it would be easy to allow an empty list, relevant tests should be written too.

What list do you see relevant to allow to be empty, apart of #567?

@mahkoh
Copy link

mahkoh commented Dec 19, 2024

I allow all lists to be empty in my implementation. I believe that is simplest both for the implementation and users.

@wismill
Copy link
Member Author

wismill commented Dec 19, 2024

There is no real use case then.

Implementation-wise it is easier in our code base to work with non-empty lists. I think we allow empty lists in enough relevant places. People hacking the remaining places where empty lists are not supported should be considered experts and will know how to fix it.

We may add support for this, but writing the corresponding tests will be most of the effort, so I am postponing this as very low priority.

@wismill wismill changed the title Empty key entry does not parse xkbcomp: Some lists are not allow to be empty Dec 19, 2024
@wismill wismill removed this from the 1.8.0 milestone Jan 7, 2025
@wismill wismill changed the title xkbcomp: Some lists are not allow to be empty xkbcomp: Some lists are not allowed to be empty Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
X11 legacy: compatibility Indicate a need to ensure compatibility with X11
Projects
None yet
Development

No branches or pull requests

2 participants