Comments (3)
Hi @roxspring thank you for raising this!
No you haven't overlooked anything, currently the help is the same regardless of which alias was used to invoke it.
Some thoughts:
Without looking at the code (on my phone now, working from memory) one part of the problem is that the parser doesn't keep track of which alias was actually used to trigger the help being displayed.
maincmd help subcmdAlias1
maincmd help subcmdAlias2
maincmd subcmdAlias1 --help
maincmd subcmdAlias2 -h
It may not be easy to build bookkeeping to keep track of this. Such bookkeeping also needs to handle scenarios like nested sub-subcommands and repeatable subcommands.
Secondly, the display part. Currently help is static: it's not designed to change depending on user input (only the error message is, but that isn't part of the usage help message).
There's no parser state available to the logic that constructs the usage help message. I imagine we would have to use a static variable (or something similar) to store the user-specified command name/alias, to make that alias available to the logic that constructs the usage help message. If you can think of a better solution, ideas are welcome!
Finally, the help is designed to be highly customizable. If applications have tests that assert the exact help message, then these tests may break, that's unavoidable.
But other than that, any changes we introduce here should not impact other applications who have customized their help message, those customizations should continue to work as before.
from picocli.
Reading the description for this ticket again it’s clear the alias is for a subcommand. Apologies, I didn’t read carefully.
I edited my previous comment.
from picocli.
It may not be easy to build bookkeeping to keep track of this. Such bookkeeping also needs to handle scenarios like nested sub-subcommands and repeatable subcommands.
Looking at repeatable subcommands gave me the inspiration for #2105 - arguably a bit hacky so feedback welcome!
from picocli.
Related Issues (20)
- Force parameters to follow options HOT 2
- GraalVM native image build with mixinStandardHelpOptions is missing a reflect-config entry HOT 4
- How to add custom classes/records to reflect-config.json? HOT 1
- Multiple converter for Map HOT 4
- [Question] Best way to provide custom description formatting?
- subcommandsRepeatable = true vs HelpCommand HOT 3
- expected behavior of getExecutionResult() with RunAll stategy ? HOT 2
- Clarification about repeatable subcommand HOT 7
- Use picocli without Reflection API HOT 1
- ManPageGenerator fails with Quarkus
- Setter method annotated by @Option with default value not been invoked when reusing it HOT 2
- ITypeConverter for custom generics (type constructors) HOT 4
- Configuring end-of-options position after parameter HOT 2
- How to solve the problem of garbled Chinese output HOT 6
- Contribute a change in docs HOT 2
- picocli-shell-jline3 jpms module HOT 3
- CLI library learning
- PicocliCommands.java:283: error: [Overrides] Varargs doesn't agree for overridden method
- Build is Broken HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from picocli.