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

Synopsis not alphabetical sort for ArgGroups #2294

Open
crotwell opened this issue May 30, 2024 · 1 comment
Open

Synopsis not alphabetical sort for ArgGroups #2294

crotwell opened this issue May 30, 2024 · 1 comment
Labels
theme: arg-group An issue or change related to argument groups type: enhancement ✨

Comments

@crotwell
Copy link
Contributor

Options at the top level are sorted alphabetically in the synopsis, but within ArgGroups they are either in the code order for fields or random for setter functions. For setters this makes the help output potentially different every time the code is recompiled. This is not related to the sort in the usage details, as that seems to always be alphabetical.

For example the synopsis for this class is:
FF [--aa] [--ab] [--ac] ([-p] [-m] [-o] [-n])
but I would expect it to be
FF [--aa] [--ab] [--ac] ([-m] [-n] [-o] [-p])

        class MyValueArgGroup {
            @Option(names = {"-p"}) boolean p;
            @Option(names = {"-m"}) boolean m;
            @Option(names = {"-o"}) boolean o;
            @Option(names = {"-n"}) boolean n;
        }
        @Command(name = "FF")
        class App {
            @Option(names = {"--ab"}) boolean c;
            @Option(names = {"--aa"}) boolean a;
            @Option(names = {"--ac"}) boolean b;
            @ArgGroup(exclusive=false, multiplicity = "1", heading = "value arg%n")
            MyValueArgGroup myAG = new MyValueArgGroup();
        }

And for this class, using setters instead of fields the synopsis varies, with random order for the arg group like:
SS [-abc] ([-z] [-w] [-x] [-y] [-s] [-t] [-u] [-v])
but I would expect it to be
SS [-abc] ([-s] [-t] [-u] [-v] [-w] [-x] [-y] [-z])

        class MySetterArgGroup {
            @Option(names = {"-w"}) public void setW(boolean b){};
            @Option(names = {"-x"}) public void setX(boolean b){};
            @Option(names = {"-y"}) public void setY(boolean b){};
            @Option(names = {"-z"}) public void setZ(boolean b){};
            @Option(names = {"-s"}) public void setS(boolean b){};
            @Option(names = {"-t"}) public void setT(boolean b){};
            @Option(names = {"-u"}) public void setU(boolean b){};
            @Option(names = {"-v"}) public void setV(boolean b){};
        }
        @Command(name = "SS")
        class App {
            @Option(names = {"-b"}) boolean c;
            @Option(names = {"-a"}) boolean a;
            @Option(names = {"-c"}) boolean b;
            @ArgGroup(exclusive=false, multiplicity = "1", heading = "setter arg%n")
            MySetterArgGroup mySAG = new MySetterArgGroup();
        }

I suspect the issue is in the else of ArgGroupSpec.rawSynopsisUnitText() approx line 10672 where the code loops over ArgSpec's from args() which returns a Set. I presume for fields the set is iterated in insertion order, and so matches code order, while for setters the set is random ordered. I think if sort order not is configured, via sortSynopsis=false then the options within the ArgGroup should be sorted alphabetically instead of just in Set order.

Note that a sorter is passed into CommandLine.createDetailedSynopsisOptionsText() at the command level, but is not passed into
CommandLine.createDetailedSynopsisGroupsText(), which might be another way to address this.

Or perhaps checking if the ArgGroup uses setters then set the sort order to be alphabetical?

Note I have also tried setting the order directly on the setter Options within the ArgGroup, but it has no effect, like:

            @Option(names = {"-z"}, order = 8) public void setZ(boolean b){};
            @Option(names = {"-s"}, order = 1) public void setS(boolean b){};
            @Option(names = {"-t"}, order = 2) public void setT(boolean b){};
@remkop remkop added theme: arg-group An issue or change related to argument groups type: enhancement ✨ labels Jun 25, 2024
@mark-christiaens
Copy link

I ran into this varying synopsis too. I just wanted to mention that I've noticed something peculiar. When I debug rawSynopsisUnitText, I see that sortExplicitly is always false. The reason seems to be that args.iterator().next().command() is always null. That surprises me since the debugger confirms that many args do have their commandSpec field set. It's just that assigning to this field always seems to happen after the rawSynopsisUnitText invocation. Might it be that the assignment to the commandSpec field should happen sooner?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
theme: arg-group An issue or change related to argument groups type: enhancement ✨
Projects
None yet
Development

No branches or pull requests

3 participants