Class CommandLine.Help
- java.lang.Object
-
- picocli.CommandLine.Help
-
- Enclosing class:
- CommandLine
public static class CommandLine.Help extends Object
A collection of methods and inner classes that provide fine-grained control over the contents and layout of the usage help message to display to end users when help is requested or invalid input values were specified.Class Diagram of the CommandLine.Help API
Layered API
The
CommandLine.Command
annotation and theCommandLine.Model.UsageMessageSpec
programmatic API equivalent provide the easiest way to configure the usage help message. See the Manual for details.This Help class provides high-level functions to create sections of the usage help message and headings for these sections. Instead of calling the
CommandLine.usage(PrintStream, CommandLine.Help.ColorScheme)
method, application authors may want to create a custom usage help message by reorganizing sections in a different order and/or adding custom sections.Finally, the Help class contains inner classes and interfaces that can be used to create custom help messages.
IOptionRenderer and IParameterRenderer
Renders a field annotated with
CommandLine.Option
orCommandLine.Parameters
to an array ofCommandLine.Help.Ansi.Text
values. By default, these values are- mandatory marker character (if the option/parameter is
required
) - short option name (empty for parameters)
- comma or empty (empty for parameters)
- long option names (the parameter
label
for parameters) - description
Other components rely on this ordering.
Layout
Delegates to the renderers to create
CommandLine.Help.Ansi.Text
values for the annotated fields, and uses aCommandLine.Help.TextTable
to display these values in tabular format. Layout is responsible for deciding which values to display where in the table. By default, Layout shows one option or parameter per table row.TextTable
Responsible for spacing out
CommandLine.Help.Ansi.Text
values according to theCommandLine.Help.Column
definitions the table was created with. Columns have a width, indentation, and an overflow policy that decides what to do if a value is longer than the column's width.Text
Encapsulates rich text with styles and colors in a way that other components like
CommandLine.Help.TextTable
are unaware of the embedded ANSI escape codes.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
CommandLine.Help.Ansi
Provides methods and inner classes to support using ANSI escape codes in usage help messages.static class
CommandLine.Help.ColorScheme
All usage help message are generated with a color scheme that assigns certain styles and colors to common parts of a usage message: the command name, options, positional parameters and option parameters.static class
CommandLine.Help.Column
static interface
CommandLine.Help.IOptionRenderer
When customizing online help forOption
details, a customIOptionRenderer
can be used to create textual representation of an Option in a tabular format: one or more rows, each containing one or more columns.static interface
CommandLine.Help.IParameterRenderer
When customizing online help for positional parameters details, a customIParameterRenderer
can be used to create textual representation of a Parameters field in a tabular format: one or more rows, each containing one or more columns.static interface
CommandLine.Help.IParamLabelRenderer
When customizing online usage help for an option parameter or a positional parameter, a customIParamLabelRenderer
can be used to render the parameter name or label to a String.static class
CommandLine.Help.Layout
Use a Layout to format usage help text for options and parameters in tabular format.static class
CommandLine.Help.TextTable
Responsible for spacing outCommandLine.Help.Ansi.Text
values according to theCommandLine.Help.Column
definitions the table was created with.static class
CommandLine.Help.Visibility
Controls the visibility of certain aspects of the usage help message.
-
Field Summary
Fields Modifier and Type Field Description CommandLine.Model.PositionalParamSpec
AT_FILE_POSITIONAL_PARAM
protected static String
DEFAULT_COMMAND_NAME
Constant String holding the default program name, value defined inCommandLine.Model.CommandSpec.DEFAULT_COMMAND_NAME
.protected static String
DEFAULT_SEPARATOR
Constant String holding the default string that separates options from option parameters, value defined inCommandLine.Model.ParserSpec.DEFAULT_SEPARATOR
.CommandLine.Model.OptionSpec
END_OF_OPTIONS_OPTION
-
Constructor Summary
Constructors Constructor Description Help(Object command)
Constructs a newHelp
instance with a default color scheme, initialized from annotations on the specified class and superclasses.Help(Object command, CommandLine.Help.Ansi ansi)
Constructs a newHelp
instance with a default color scheme, initialized from annotations on the specified class and superclasses.Help(Object command, CommandLine.Help.ColorScheme colorScheme)
Help(CommandLine.Model.CommandSpec commandSpec, CommandLine.Help.ColorScheme colorScheme)
Constructs a newHelp
instance with the specified color scheme, initialized from annotations on the specified class and superclasses.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description String
abbreviatedSynopsis()
Generates a generic synopsis like<command name> [OPTIONS] [PARAM1 [PARAM2]...]
, omitting parts that don't apply to the command (e.g., does not show [OPTIONS] if the command has no options).CommandLine.Help
addAllSubcommands(Map<String,CommandLine> subcommands)
Registers all specified subcommands with this Help.CommandLine.Help
addSubcommand(String commandName, Object command)
Deprecated.useaddAllSubcommands(Map)
insteadprotected List<String>
aliases()
Returns the list of aliases for the command in this Help.Map<String,CommandLine.Help>
allSubcommands()
Returns the map of all subcommandHelp
instances (including hidden commands) for this command Help.CommandLine.Help.Ansi
ansi()
Returns whether ANSI escape codes are enabled or not.String
atFileParameterList()
Returns the section of the usage help message that lists the @-file and its description.int
calcLongOptionColumnWidth(List<CommandLine.Model.OptionSpec> options, List<CommandLine.Model.PositionalParamSpec> positionals, CommandLine.Help.ColorScheme aColorScheme)
Returns the width of the long options column in the usage help message.CommandLine.Help.ColorScheme
colorScheme()
Returns theColorScheme
model that this Help was constructed with.String
commandList()
Returns a 2-column list with the command names and first line of their header or (if absent) description of the commands returned bysubcommands()
.String
commandList(Map<String,CommandLine.Help> subcommands)
Returns a 2-column list with the command names and first line of their header or (if absent) description of the specified command map.String
commandListHeading(Object... params)
Returns the text displayed before the command list; an empty string if there are no commands, otherwise the result ofString.format(commandListHeading, params)
.CommandLine.Help.Ansi.Text
commandNamesText(String separator)
Returns aText
object containing the command name and all aliases, separated with the specified separator.CommandLine.Model.CommandSpec
commandSpec()
Returns theCommandSpec
model that this Help was constructed with.CommandLine.Help.Layout
createDefaultLayout()
Returns aLayout
instance configured with the user preferences captured in this Help instance.CommandLine.Help.Layout
createDefaultLayout(List<CommandLine.Model.OptionSpec> options, List<CommandLine.Model.PositionalParamSpec> positionals, CommandLine.Help.ColorScheme aColorScheme)
Returns aLayout
instance configured with the user preferences captured in this Help instance.CommandLine.Help.IOptionRenderer
createDefaultOptionRenderer()
Comparator<CommandLine.Model.OptionSpec>
createDefaultOptionSort()
Returns a comparator for sorting options, ornull
, depending on the settings for this command.CommandLine.Help.IParameterRenderer
createDefaultParameterRenderer()
Returns a new default ParameterRenderer which converts positional parameters to four columns of text to match the default TextTable column layout.CommandLine.Help.IParamLabelRenderer
createDefaultParamLabelRenderer()
Returns a new default param label renderer that separates option parameters from their option name with the specified separator string, and, unlessCommandLine.Model.ArgSpec.hideParamSyntax()
is true, surrounds optional parameters with'['
and']'
characters and uses ellipses ("...") to indicate that any number of a parameter are allowed.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisCommandText()
Returns a Text object containing a partial detailed synopsis showing only the subcommands, starting with a" "
space.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisEndOfOptionsText()
Returns a Text object containing a partial detailed synopsis showing only the end of options delimiter (if enabled), starting with a" "
space.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisGroupsText(Set<CommandLine.Model.ArgSpec> outparam_groupArgs)
Returns a Text object containing a partial detailed synopsis showing only the options and positional parameters in the specified validating groups, starting with a" "
space.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisOptionsText(Collection<CommandLine.Model.ArgSpec> done, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Returns a Text object containing a partial detailed synopsis showing only the options, starting with a" "
space.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisOptionsText(Collection<CommandLine.Model.ArgSpec> done, List<CommandLine.Model.OptionSpec> optionList, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Returns a Text object containing a partial detailed synopsis showing only the specified options, starting with a" "
space.protected CommandLine.Help.Ansi.Text
createDetailedSynopsisPositionalsText(Collection<CommandLine.Model.ArgSpec> done)
Returns a Text object containing a partial detailed synopsis showing only the positional parameters, starting with a" "
space.String
createHeading(String text, Object... params)
Returns a String that can be used as a help section heading.static CommandLine.Help.IOptionRenderer
createMinimalOptionRenderer()
Returns a new minimal OptionRenderer which convertsOptions
to a single row with two columns of text: an option name and a description.static CommandLine.Help.IParameterRenderer
createMinimalParameterRenderer()
Returns a new minimal ParameterRenderer which converts positional parameters to a single row with two columns of text: an option name and a description.static CommandLine.Help.IParamLabelRenderer
createMinimalParamLabelRenderer()
Returns a value renderer that returns theparamLabel
if defined or the field name otherwise.static Comparator<CommandLine.Model.OptionSpec>
createShortOptionArityAndNameComparator()
static Comparator<CommandLine.Model.OptionSpec>
createShortOptionNameComparator()
SortsOptionSpecs
by their option name in case-insensitive alphabetic order.CommandLine.Help.TextTable
createTextTable(Map<?,?> map)
Returns a 2-columnTextTable
containing data from the specified map: the keys are put in the left column and the map values are in the right column.String
customSynopsis(Object... params)
Returns command custom synopsis as a string.static CommandLine.Help.ColorScheme
defaultColorScheme(CommandLine.Help.Ansi ansi)
Creates and returns a newCommandLine.Help.ColorScheme
initialized with picocli default values: commands are bold, options and parameters use a yellow foreground, and option parameters use italic.String
description(Object... params)
Returns command description text as a string.String
descriptionHeading(Object... params)
Returns the text displayed before the description text; an empty string if there is no description, otherwise the result ofString.format(descriptionHeading, params)
.String
detailedSynopsis(int synopsisHeadingLength, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Generates a detailed synopsis message showing all options and parameters.String
detailedSynopsis(Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Deprecated.usedetailedSynopsis(int, Comparator, boolean)
instead.String
endOfOptionsList()
Returns the section of the usage help message that lists the--
End of Options delimiter and its description.String
exitCodeList()
Returns a 2-column list with exit codes and their description.String
exitCodeListHeading(Object... params)
Returns the text displayed before the exit code list text; the result ofString.format(exitCodeHeading, params)
.String
footer(Object... params)
Returns command footer text as a string.String
footerHeading(Object... params)
Returns the text displayed before the footer text; the result ofString.format(footerHeading, params)
.String
fullSynopsis()
Returns the full usage synopsis of this command.boolean
hasAtFileParameter()
Returns true if the usage help should show the at file parameter in the parameter list, otherwise false.String
header(Object... params)
Returns the command header text as a string.String
headerHeading(Object... params)
Returns the text displayed before the header text; the result ofString.format(headerHeading, params)
.protected String
insertSynopsisCommandName(int synopsisHeadingLength, CommandLine.Help.Ansi.Text optionsAndPositionalsAndCommandsDetails)
Returns the detailed synopsis text by inserting the command name before the specified text with options and positional parameters details.static StringBuilder
join(CommandLine.Help.Ansi ansi, int usageHelpWidth, boolean adjustCJK, String[] values, StringBuilder sb, Object... params)
Formats each of the specified values and appends it to the specified StringBuilder.static StringBuilder
join(CommandLine.Help.Ansi ansi, int usageHelpWidth, String[] values, StringBuilder sb, Object... params)
Deprecated.protected String
makeSynopsisFromParts(int synopsisHeadingLength, CommandLine.Help.Ansi.Text optionText, CommandLine.Help.Ansi.Text groupsText, CommandLine.Help.Ansi.Text endOfOptionsText, CommandLine.Help.Ansi.Text positionalParamText, CommandLine.Help.Ansi.Text commandText)
Concatenates the command name and the specified synopsis parts and returns a fully rendered synopsis String.String
optionList()
Returns a description of all options in this command, including any argument groups.String
optionList(CommandLine.Help.Layout layout, Comparator<CommandLine.Model.OptionSpec> optionSort, CommandLine.Help.IParamLabelRenderer valueLabelRenderer)
Sorts allOptions
with the specifiedcomparator
(if the comparator is non-null
), then adds all non-hidden options to the specified TextTable and returns the result of TextTable.toString().String
optionListExcludingGroups(List<CommandLine.Model.OptionSpec> options)
Returns a description of the specified list of options.String
optionListExcludingGroups(List<CommandLine.Model.OptionSpec> optionList, CommandLine.Help.Layout layout, Comparator<CommandLine.Model.OptionSpec> optionSort, CommandLine.Help.IParamLabelRenderer valueLabelRenderer)
Sorts allOptions
with the specifiedcomparator
(if the comparator is non-null
), then adds the specified options to the specified TextTable and returns the result of TextTable.toString().String
optionListGroupSections()
Returns a rendered section of the usage help message that contains the argument groups that have a non-null
heading.String
optionListHeading(Object... params)
Returns the text displayed before the option list; an empty string if there are no options, otherwise the result ofString.format(optionListHeading, params)
.List<CommandLine.Model.ArgGroupSpec>
optionSectionGroups()
Returns the list ofArgGroupSpec
instances in this command that have a non-null
heading, most deeply nested argument groups first.CommandLine.Help.IParamLabelRenderer
parameterLabelRenderer()
Option and positional parameter value label renderer used for the synopsis line(s) and the option list.String
parameterList()
Returns the rendered positional parameters section of the usage help message for all positional parameters in this command.String
parameterList(List<CommandLine.Model.PositionalParamSpec> positionalParams)
Returns the rendered positional parameters section of the usage help message for the specified positional parameters.String
parameterList(List<CommandLine.Model.PositionalParamSpec> positionalParams, CommandLine.Help.Layout layout, CommandLine.Help.IParamLabelRenderer paramLabelRenderer)
Returns the rendered section of the usage help message that lists the specified parameters with their descriptions.String
parameterList(CommandLine.Help.Layout layout, CommandLine.Help.IParamLabelRenderer paramLabelRenderer)
Returns the rendered section of the usage help message that lists all positional parameters in this command with their descriptions.String
parameterListHeading(Object... params)
Returns the text displayed before the positional parameter list; an empty string if there are no positional parameters, otherwise the result ofString.format(parameterListHeading, params)
.static Comparator<String>
shortestFirst()
Sorts short strings before longer strings.Map<String,CommandLine.Help>
subcommands()
Returns the map of non-hidden subcommandHelp
instances for this command Help.String
synopsis()
Deprecated.usesynopsis(int)
insteadString
synopsis(int synopsisHeadingLength)
Returns a synopsis for the command, reserving the specified space for the synopsis heading.String
synopsisHeading(Object... params)
Returns the text displayed before the synopsis text; the result ofString.format(synopsisHeading, params)
.int
synopsisHeadingLength()
Returns the number of characters the synopsis heading will take on the same line as the synopsis.
-
-
-
Field Detail
-
DEFAULT_COMMAND_NAME
protected static final String DEFAULT_COMMAND_NAME
Constant String holding the default program name, value defined inCommandLine.Model.CommandSpec.DEFAULT_COMMAND_NAME
.- See Also:
- Constant Field Values
-
DEFAULT_SEPARATOR
protected static final String DEFAULT_SEPARATOR
Constant String holding the default string that separates options from option parameters, value defined inCommandLine.Model.ParserSpec.DEFAULT_SEPARATOR
.- See Also:
- Constant Field Values
-
AT_FILE_POSITIONAL_PARAM
public final CommandLine.Model.PositionalParamSpec AT_FILE_POSITIONAL_PARAM
-
END_OF_OPTIONS_OPTION
public final CommandLine.Model.OptionSpec END_OF_OPTIONS_OPTION
-
-
Constructor Detail
-
Help
public Help(Object command)
Constructs a newHelp
instance with a default color scheme, initialized from annotations on the specified class and superclasses.- Parameters:
command
- the annotated object to create usage help for
-
Help
public Help(Object command, CommandLine.Help.Ansi ansi)
Constructs a newHelp
instance with a default color scheme, initialized from annotations on the specified class and superclasses.- Parameters:
command
- the annotated object to create usage help foransi
- whether to emit ANSI escape codes or not
-
Help
@Deprecated public Help(Object command, CommandLine.Help.ColorScheme colorScheme)
Constructs a newHelp
instance with the specified color scheme, initialized from annotations on the specified class and superclasses.- Parameters:
command
- the annotated object to create usage help forcolorScheme
- the color scheme to use
-
Help
public Help(CommandLine.Model.CommandSpec commandSpec, CommandLine.Help.ColorScheme colorScheme)
Constructs a newHelp
instance with the specified color scheme, initialized from annotations on the specified class and superclasses.- Parameters:
commandSpec
- the command model to create usage help forcolorScheme
- the color scheme to use
-
-
Method Detail
-
commandSpec
public CommandLine.Model.CommandSpec commandSpec()
Returns theCommandSpec
model that this Help was constructed with.- Since:
- 3.9
-
colorScheme
public CommandLine.Help.ColorScheme colorScheme()
Returns theColorScheme
model that this Help was constructed with.- Since:
- 3.0
-
subcommands
public Map<String,CommandLine.Help> subcommands()
Returns the map of non-hidden subcommandHelp
instances for this command Help.- Since:
- 3.9
- See Also:
allSubcommands()
-
allSubcommands
public Map<String,CommandLine.Help> allSubcommands()
Returns the map of all subcommandHelp
instances (including hidden commands) for this command Help.- Since:
- 4.4
- See Also:
subcommands()
-
aliases
protected List<String> aliases()
Returns the list of aliases for the command in this Help.- Since:
- 3.9
-
parameterLabelRenderer
public CommandLine.Help.IParamLabelRenderer parameterLabelRenderer()
Option and positional parameter value label renderer used for the synopsis line(s) and the option list. By default initialized to the result ofcreateDefaultParamLabelRenderer()
, which takes a snapshot of theCommandLine.Model.ParserSpec.separator()
at construction time. If the separator is modified after Help construction, you may need to re-initialize this field by callingcreateDefaultParamLabelRenderer()
again.
-
addAllSubcommands
public CommandLine.Help addAllSubcommands(Map<String,CommandLine> subcommands)
Registers all specified subcommands with this Help.- Parameters:
subcommands
- the subcommands of this command- Returns:
- this Help instance (for method chaining)
- See Also:
subcommands()
,allSubcommands()
-
addSubcommand
@Deprecated public CommandLine.Help addSubcommand(String commandName, Object command)
Deprecated.useaddAllSubcommands(Map)
insteadRegisters the specified subcommand as one of the visible commands in this Help. This method does not check whether the specified command is hidden or not.- Parameters:
commandName
- the name of the subcommand to display in the usage messagecommand
- theCommandSpec
or@Command
annotated object to get more information from- Returns:
- this Help instance (for method chaining)
- See Also:
subcommands()
-
fullSynopsis
public String fullSynopsis()
Returns the full usage synopsis of this command. This is equivalent to:this.synopsisHeading() + this.synopsis(this.synopsisHeadingLength())
- Since:
- 4.1
-
synopsis
@Deprecated public String synopsis()
Deprecated.usesynopsis(int)
insteadReturns a synopsis for the command without reserving space for the synopsis heading.- Returns:
- a synopsis
- See Also:
abbreviatedSynopsis()
,detailedSynopsis(Comparator, boolean)
-
synopsis
public String synopsis(int synopsisHeadingLength)
Returns a synopsis for the command, reserving the specified space for the synopsis heading.- Parameters:
synopsisHeadingLength
- the length of the synopsis heading that will be displayed on the same line- Returns:
- a synopsis
- See Also:
abbreviatedSynopsis()
,detailedSynopsis(Comparator, boolean)
,synopsisHeading(java.lang.Object...)
-
abbreviatedSynopsis
public String abbreviatedSynopsis()
Generates a generic synopsis like<command name> [OPTIONS] [PARAM1 [PARAM2]...]
, omitting parts that don't apply to the command (e.g., does not show [OPTIONS] if the command has no options).- Returns:
- a generic synopsis
-
detailedSynopsis
@Deprecated public String detailedSynopsis(Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Deprecated.usedetailedSynopsis(int, Comparator, boolean)
instead.Generates a detailed synopsis message showing all options and parameters. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Parameters:
optionSort
- comparator to sort options ornull
if options should not be sortedclusterBooleanOptions
-true
if boolean short options should be clustered into a single string- Returns:
- a detailed synopsis
-
detailedSynopsis
public String detailedSynopsis(int synopsisHeadingLength, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Generates a detailed synopsis message showing all options and parameters. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Parameters:
synopsisHeadingLength
- the length of the synopsis heading that will be displayed on the same lineoptionSort
- comparator to sort options ornull
if options should not be sortedclusterBooleanOptions
-true
if boolean short options should be clustered into a single string- Returns:
- a detailed synopsis
- Since:
- 3.0
-
makeSynopsisFromParts
protected String makeSynopsisFromParts(int synopsisHeadingLength, CommandLine.Help.Ansi.Text optionText, CommandLine.Help.Ansi.Text groupsText, CommandLine.Help.Ansi.Text endOfOptionsText, CommandLine.Help.Ansi.Text positionalParamText, CommandLine.Help.Ansi.Text commandText)
Concatenates the command name and the specified synopsis parts and returns a fully rendered synopsis String.- Parameters:
synopsisHeadingLength
- length of the synopsis heading string to be displayed on the same line as the first synopsis line. For example, if the synopsis heading is"Usage: "
, this value is 7.optionText
- the Ansi.Text object with the rendered options list (excluding the argument groups)groupsText
- the Ansi.Text object showing the rendered argument groupsendOfOptionsText
- the Ansi.Text object containing the end of options delimiter (if enabled)positionalParamText
- the Ansi.Text object showing the rendered positional parameterscommandText
- the Ansi.Text object showing the subcommands part of the synopsis- Returns:
- a fully rendered synopsis String
- Since:
- 4.4
-
createDetailedSynopsisGroupsText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisGroupsText(Set<CommandLine.Model.ArgSpec> outparam_groupArgs)
Returns a Text object containing a partial detailed synopsis showing only the options and positional parameters in the specified validating groups, starting with a" "
space.- Parameters:
outparam_groupArgs
- all options and positional parameters in the groups this method generates a synopsis for; these options and positional parameters should be excluded from appearing elsewhere in the synopsis- Returns:
- the formatted groups synopsis elements, starting with a
" "
space, or an empty Text if this command has no validating groups - Since:
- 4.0
-
createDetailedSynopsisOptionsText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisOptionsText(Collection<CommandLine.Model.ArgSpec> done, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Returns a Text object containing a partial detailed synopsis showing only the options, starting with a" "
space. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Parameters:
done
- the list of options and positional parameters for which a synopsis was already generated. Options in this set should be excluded.optionSort
- comparator to sort options ornull
if options should not be sortedclusterBooleanOptions
-true
if boolean short options should be clustered into a single string- Returns:
- the formatted options, starting with a
" "
space, or an empty Text if this command has no named options - Since:
- 3.9
-
createDetailedSynopsisOptionsText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisOptionsText(Collection<CommandLine.Model.ArgSpec> done, List<CommandLine.Model.OptionSpec> optionList, Comparator<CommandLine.Model.OptionSpec> optionSort, boolean clusterBooleanOptions)
Returns a Text object containing a partial detailed synopsis showing only the specified options, starting with a" "
space. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Parameters:
done
- the list of options and positional parameters for which a synopsis was already generated. Options in this set should be excluded.optionList
- the list of options to include in the synopsisoptionSort
- comparator to sort options ornull
if options should not be sortedclusterBooleanOptions
-true
if boolean short options should be clustered into a single string- Returns:
- the formatted options, starting with a
" "
space, or an empty Text if this command has no named options - Since:
- 4.4
-
createDetailedSynopsisEndOfOptionsText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisEndOfOptionsText()
Returns a Text object containing a partial detailed synopsis showing only the end of options delimiter (if enabled), starting with a" "
space. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Returns:
- the formatted end of options delimiter, starting with a
" "
space, or an empty Text if the end of options delimiter should not be shown - Since:
- 4.3
-
createDetailedSynopsisPositionalsText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisPositionalsText(Collection<CommandLine.Model.ArgSpec> done)
Returns a Text object containing a partial detailed synopsis showing only the positional parameters, starting with a" "
space. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Parameters:
done
- the list of options and positional parameters for which a synopsis was already generated. Positional parameters in this set should be excluded.- Returns:
- the formatted positional parameters, starting with a
" "
space, or an empty Text if this command has no positional parameters - Since:
- 3.9
-
createDetailedSynopsisCommandText
protected CommandLine.Help.Ansi.Text createDetailedSynopsisCommandText()
Returns a Text object containing a partial detailed synopsis showing only the subcommands, starting with a" "
space. Follows the unix convention of showing optional elements in square brackets ([ ]
).- Returns:
- this implementation returns " " +
CommandLine.Model.UsageMessageSpec.synopsisSubcommandLabel()
if this command has subcommands, an empty Text otherwise. - Since:
- 3.9
-
insertSynopsisCommandName
protected String insertSynopsisCommandName(int synopsisHeadingLength, CommandLine.Help.Ansi.Text optionsAndPositionalsAndCommandsDetails)
Returns the detailed synopsis text by inserting the command name before the specified text with options and positional parameters details.- Parameters:
synopsisHeadingLength
- length of the synopsis heading string to be displayed on the same line as the first synopsis line. For example, if the synopsis heading is"Usage: "
, this value is 7.optionsAndPositionalsAndCommandsDetails
- formatted string with options, positional parameters and subcommands. Follows the unix convention of showing optional options and parameters in square brackets ([ ]
).- Returns:
- the detailed synopsis text, in multiple lines if the length exceeds the usage width
-
synopsisHeadingLength
public int synopsisHeadingLength()
Returns the number of characters the synopsis heading will take on the same line as the synopsis.- Returns:
- the number of characters the synopsis heading will take on the same line as the synopsis.
- See Also:
detailedSynopsis(int, Comparator, boolean)
-
createDefaultOptionSort
public Comparator<CommandLine.Model.OptionSpec> createDefaultOptionSort()
Returns a comparator for sorting options, ornull
, depending on the settings for this command.- Returns:
- if sortOptions is selected,
return a comparator for sorting options based on their short name.
Otherwise, if any of the options has a non-default value for their order attribute,
then return a comparator for sorting options based on the order attribute.
Otherwise, return
null
to indicate that options should not be sorted. - Since:
- 4.4
-
optionList
public String optionList()
Returns a description of all options in this command, including any argument groups.
This implementation sorts options alphabetically, and shows only the non-hidden options in a tabular format using the default renderer and default layout.
- Returns:
- the fully formatted option list, including any argument groups
- See Also:
optionListExcludingGroups(List)
,optionListGroupSections()
-
optionListExcludingGroups
public String optionListExcludingGroups(List<CommandLine.Model.OptionSpec> options)
Returns a description of the specified list of options.
This implementation sorts options alphabetically, and shows only the specified options in a tabular format using the default renderer and createDefaultLayout(List, List, ColorScheme) default layout}.
Argument groups are not rendered by this method.
- Parameters:
options
- the options to display in the returned rendered section of the usage help message- Returns:
- the fully formatted portion of the option list for the specified options only (argument groups are not included)
- Since:
- 4.4
- See Also:
optionListExcludingGroups(List, Layout, Comparator, IParamLabelRenderer)
-
optionList
public String optionList(CommandLine.Help.Layout layout, Comparator<CommandLine.Model.OptionSpec> optionSort, CommandLine.Help.IParamLabelRenderer valueLabelRenderer)
Sorts allOptions
with the specifiedcomparator
(if the comparator is non-null
), then adds all non-hidden options to the specified TextTable and returns the result of TextTable.toString().- Parameters:
layout
- the layout responsible for rendering the option listvalueLabelRenderer
- used for options with a parameter- Returns:
- the fully formatted option list, including any argument groups
- Since:
- 3.0
- See Also:
optionListExcludingGroups(List, Layout, Comparator, IParamLabelRenderer)
,optionListGroupSections()
-
optionListExcludingGroups
public String optionListExcludingGroups(List<CommandLine.Model.OptionSpec> optionList, CommandLine.Help.Layout layout, Comparator<CommandLine.Model.OptionSpec> optionSort, CommandLine.Help.IParamLabelRenderer valueLabelRenderer)
Sorts allOptions
with the specifiedcomparator
(if the comparator is non-null
), then adds the specified options to the specified TextTable and returns the result of TextTable.toString(). Argument groups are not rendered by this method.- Parameters:
optionList
- the options to show (this may be a subset of the options in this command); it is the responsibility of the caller to remove options that should not be displayedlayout
- the layout responsible for rendering the option listvalueLabelRenderer
- used for options with a parameter- Returns:
- the fully formatted portion of the option list for the specified options only (argument groups are not included)
- Since:
- 4.4
-
optionListGroupSections
public String optionListGroupSections()
Returns a rendered section of the usage help message that contains the argument groups that have a non-null
heading. This is usually shown below the "normal" options of the command (that are not in an argument group).- Returns:
- the fully formatted portion of the option list showing the argument groups
- Since:
- 4.4
- See Also:
optionList()
,optionListExcludingGroups(List)
,optionSectionGroups()
-
optionSectionGroups
public List<CommandLine.Model.ArgGroupSpec> optionSectionGroups()
Returns the list ofArgGroupSpec
instances in this command that have a non-null
heading, most deeply nested argument groups first.- Since:
- 4.4
- See Also:
optionListGroupSections()
-
parameterList
public String parameterList()
Returns the rendered positional parameters section of the usage help message for all positional parameters in this command.- Returns:
- the section of the usage help message that lists the parameters
- See Also:
parameterList(List)
-
parameterList
public String parameterList(List<CommandLine.Model.PositionalParamSpec> positionalParams)
Returns the rendered positional parameters section of the usage help message for the specified positional parameters.- Parameters:
positionalParams
- the positional parameters to display in the returned rendered section of the usage help message; the caller is responsible for removing parameters that should not be displayed- Returns:
- the section of the usage help message that lists the parameters
- Since:
- 4.4
- See Also:
parameterList(List, Layout, IParamLabelRenderer)
-
parameterList
public String parameterList(CommandLine.Help.Layout layout, CommandLine.Help.IParamLabelRenderer paramLabelRenderer)
Returns the rendered section of the usage help message that lists all positional parameters in this command with their descriptions.- Parameters:
layout
- the layout to useparamLabelRenderer
- for rendering parameter names- Returns:
- the section of the usage help message that lists the parameters
-
parameterList
public String parameterList(List<CommandLine.Model.PositionalParamSpec> positionalParams, CommandLine.Help.Layout layout, CommandLine.Help.IParamLabelRenderer paramLabelRenderer)
Returns the rendered section of the usage help message that lists the specified parameters with their descriptions.- Parameters:
positionalParams
- the positional parameters to display in the returned rendered section of the usage help message; the caller is responsible for removing parameters that should not be displayedlayout
- the layout to useparamLabelRenderer
- for rendering parameter names- Returns:
- the section of the usage help message that lists the parameters
- Since:
- 4.4
-
hasAtFileParameter
public boolean hasAtFileParameter()
Returns true if the usage help should show the at file parameter in the parameter list, otherwise false.- Since:
- 4.3
-
atFileParameterList
public String atFileParameterList()
Returns the section of the usage help message that lists the @-file and its description.- Returns:
- the section of the usage help message that lists the @-file and its description
- Since:
- 4.2
-
endOfOptionsList
public String endOfOptionsList()
Returns the section of the usage help message that lists the--
End of Options delimiter and its description.- Returns:
- the section of the usage help message that lists the
--
End of Options delimiter and its description. - Since:
- 4.3
-
join
@Deprecated public static StringBuilder join(CommandLine.Help.Ansi ansi, int usageHelpWidth, String[] values, StringBuilder sb, Object... params)
Deprecated.
-
join
public static StringBuilder join(CommandLine.Help.Ansi ansi, int usageHelpWidth, boolean adjustCJK, String[] values, StringBuilder sb, Object... params)
Formats each of the specified values and appends it to the specified StringBuilder.- Parameters:
ansi
- whether the result should contain ANSI escape codes or notusageHelpWidth
- the width of the usage help messageadjustCJK
- true if wide Chinese, Japanese and Korean characters should be counted as double the size of other characters for line-breaking purposesvalues
- the values to format and append to the StringBuildersb
- the StringBuilder to collect the formatted stringsparams
- the parameters to pass to the format method when formatting each value- Returns:
- the specified StringBuilder
- Since:
- 4.0
-
customSynopsis
public String customSynopsis(Object... params)
Returns command custom synopsis as a string. A custom synopsis can be zero or more lines, and can be specified declaratively with theCommandLine.Command.customSynopsis()
annotation attribute or programmatically by setting the Help instance'scustomSynopsis(java.lang.Object...)
field.- Parameters:
params
- Arguments referenced by the format specifiers in the synopsis strings- Returns:
- the custom synopsis lines combined into a single String (which may be empty)
-
description
public String description(Object... params)
Returns command description text as a string. Description text can be zero or more lines, and can be specified declaratively with theCommandLine.Command.description()
annotation attribute or programmatically by setting the Help instance'sdescription(java.lang.Object...)
field.- Parameters:
params
- Arguments referenced by the format specifiers in the description strings- Returns:
- the description lines combined into a single String (which may be empty)
-
header
public String header(Object... params)
Returns the command header text as a string. Header text can be zero or more lines, and can be specified declaratively with theCommandLine.Command.header()
annotation attribute or programmatically by setting the Help instance'sheader(java.lang.Object...)
field.- Parameters:
params
- Arguments referenced by the format specifiers in the header strings- Returns:
- the header lines combined into a single String (which may be empty)
-
footer
public String footer(Object... params)
Returns command footer text as a string. Footer text can be zero or more lines, and can be specified declaratively with theCommandLine.Command.footer()
annotation attribute or programmatically by setting the Help instance'sfooter(java.lang.Object...)
field.- Parameters:
params
- Arguments referenced by the format specifiers in the footer strings- Returns:
- the footer lines combined into a single String (which may be empty)
-
headerHeading
public String headerHeading(Object... params)
Returns the text displayed before the header text; the result ofString.format(headerHeading, params)
.- Parameters:
params
- the parameters to use to format the header heading- Returns:
- the formatted header heading
-
synopsisHeading
public String synopsisHeading(Object... params)
Returns the text displayed before the synopsis text; the result ofString.format(synopsisHeading, params)
.- Parameters:
params
- the parameters to use to format the synopsis heading- Returns:
- the formatted synopsis heading
-
descriptionHeading
public String descriptionHeading(Object... params)
Returns the text displayed before the description text; an empty string if there is no description, otherwise the result ofString.format(descriptionHeading, params)
.- Parameters:
params
- the parameters to use to format the description heading- Returns:
- the formatted description heading
-
parameterListHeading
public String parameterListHeading(Object... params)
Returns the text displayed before the positional parameter list; an empty string if there are no positional parameters, otherwise the result ofString.format(parameterListHeading, params)
.- Parameters:
params
- the parameters to use to format the parameter list heading- Returns:
- the formatted parameter list heading
-
optionListHeading
public String optionListHeading(Object... params)
Returns the text displayed before the option list; an empty string if there are no options, otherwise the result ofString.format(optionListHeading, params)
.- Parameters:
params
- the parameters to use to format the option list heading- Returns:
- the formatted option list heading
-
commandListHeading
public String commandListHeading(Object... params)
Returns the text displayed before the command list; an empty string if there are no commands, otherwise the result ofString.format(commandListHeading, params)
.- Parameters:
params
- the parameters to use to format the command list heading- Returns:
- the formatted command list heading
-
footerHeading
public String footerHeading(Object... params)
Returns the text displayed before the footer text; the result ofString.format(footerHeading, params)
.- Parameters:
params
- the parameters to use to format the footer heading- Returns:
- the formatted footer heading
-
exitCodeListHeading
public String exitCodeListHeading(Object... params)
Returns the text displayed before the exit code list text; the result ofString.format(exitCodeHeading, params)
.- Parameters:
params
- the parameters to use to format the exit code heading- Returns:
- the formatted heading of the exit code section of the usage help message
- Since:
- 4.0
-
exitCodeList
public String exitCodeList()
Returns a 2-column list with exit codes and their description. Descriptions containing"%n"
line separators are broken up into multiple lines.- Returns:
- a usage help section describing the exit codes
- Since:
- 4.0
-
createHeading
public String createHeading(String text, Object... params)
Returns a String that can be used as a help section heading. Embedded%n
format specifiers will be converted to platform-specific line breaks. Long lines will be wrapped on word boundaries to ensure they do not exceed the usage message width. Embedded@|style[,style] ...|@
markup will be converted to Ansi escape codes when Ansi is enabled, and stripped out otherwise.- Parameters:
text
- a printf-style format string that may one or more embedded format specifiersparams
- optional parameters to use when formatting the specified text string- Returns:
- a help section heading String
- Since:
- 4.1
-
createTextTable
public CommandLine.Help.TextTable createTextTable(Map<?,?> map)
Returns a 2-columnTextTable
containing data from the specified map: the keys are put in the left column and the map values are in the right column.The width of the left column is the width of the longest key, plus 3 for spacing between the columns.
All map entries are converted to Strings and any embedded
%n
format specifiers are converted to platform-specific line breaks. Long lines are wrapped on word boundaries to ensure they do not exceed the column width.Embedded
@|style[,style] ...|@
markup will be converted to Ansi escape codes when Ansi is enabled, and stripped out otherwise.- Parameters:
map
- the map to convert to aTextTable
- Returns:
- a 2-column
TextTable
containing data from the specified map - Since:
- 4.1
-
commandList
public String commandList()
Returns a 2-column list with the command names and first line of their header or (if absent) description of the commands returned bysubcommands()
.- Returns:
- a usage help section describing the added commands
- See Also:
commandList(Map)
-
commandList
public String commandList(Map<String,CommandLine.Help> subcommands)
Returns a 2-column list with the command names and first line of their header or (if absent) description of the specified command map.- Returns:
- a usage help section describing the added commands
- Since:
- 4.4
- See Also:
subcommands()
,allSubcommands()
-
commandNamesText
public CommandLine.Help.Ansi.Text commandNamesText(String separator)
Returns aText
object containing the command name and all aliases, separated with the specified separator. Command names will use thecommand style
for the color scheme of this Help.- Since:
- 3.9
-
createDefaultLayout
public CommandLine.Help.Layout createDefaultLayout()
Returns aLayout
instance configured with the user preferences captured in this Help instance.- Returns:
- a Layout
-
createDefaultLayout
public CommandLine.Help.Layout createDefaultLayout(List<CommandLine.Model.OptionSpec> options, List<CommandLine.Model.PositionalParamSpec> positionals, CommandLine.Help.ColorScheme aColorScheme)
Returns aLayout
instance configured with the user preferences captured in this Help instance.- Parameters:
options
- used to calculate the long options column width in the layoutpositionals
- used to calculate the long options column width in the layoutaColorScheme
- used in the layout to create CommandLine.Help.Ansi.Text values- Returns:
- a Layout with the default columns
- Since:
- 4.4
-
calcLongOptionColumnWidth
public int calcLongOptionColumnWidth(List<CommandLine.Model.OptionSpec> options, List<CommandLine.Model.PositionalParamSpec> positionals, CommandLine.Help.ColorScheme aColorScheme)
Returns the width of the long options column in the usage help message.- Parameters:
options
- the options shown in the usage help messagepositionals
- the positional parameters shown in the usage help messageaColorScheme
- the colorscheme used in the layout to create CommandLine.Help.Ansi.Text values- Returns:
- the width of the long options column in the layout
- Since:
- 4.6
-
createDefaultOptionRenderer
public CommandLine.Help.IOptionRenderer createDefaultOptionRenderer()
Returns a new default OptionRenderer which convertsOptions
to five columns of text to match the default TextTable column layout. The first row of values looks like this:- the required option marker
- 2-character short option name (or empty string if no short option exists)
- comma separator (only if both short option and long option exist, empty string otherwise)
- comma-separated string with long option name(s)
- first element of the
CommandLine.Model.ArgSpec.description()
array
Following this, there will be one row for each of the remaining elements of the
CommandLine.Model.ArgSpec.description()
array, and these rows look like{"", "", "", "", option.description()[i]}
.If configured, this option renderer adds an additional row to display the default field value.
- Returns:
- a new default OptionRenderer
-
createMinimalOptionRenderer
public static CommandLine.Help.IOptionRenderer createMinimalOptionRenderer()
Returns a new minimal OptionRenderer which convertsOptions
to a single row with two columns of text: an option name and a description. If multiple names or descriptions exist, the first value is used.- Returns:
- a new minimal OptionRenderer
-
createDefaultParameterRenderer
public CommandLine.Help.IParameterRenderer createDefaultParameterRenderer()
Returns a new default ParameterRenderer which converts positional parameters to four columns of text to match the default TextTable column layout. The first row of values looks like this:- empty string
- empty string
- parameter(s) label as rendered by the
CommandLine.Help.IParamLabelRenderer
- first element of the
CommandLine.Model.ArgSpec.description()
array
Following this, there will be one row for each of the remaining elements of the
CommandLine.Model.ArgSpec.description()
array, and these rows look like{"", "", "", param.description()[i]}
.If configured, this parameter renderer adds an additional row to display the default field value.
- Returns:
- a new default ParameterRenderer
-
createMinimalParameterRenderer
public static CommandLine.Help.IParameterRenderer createMinimalParameterRenderer()
Returns a new minimal ParameterRenderer which converts positional parameters to a single row with two columns of text: an option name and a description. If multiple descriptions exist, the first value is used.- Returns:
- a new minimal ParameterRenderer
-
createMinimalParamLabelRenderer
public static CommandLine.Help.IParamLabelRenderer createMinimalParamLabelRenderer()
Returns a value renderer that returns theparamLabel
if defined or the field name otherwise.- Returns:
- a new minimal ParamLabelRenderer
-
createDefaultParamLabelRenderer
public CommandLine.Help.IParamLabelRenderer createDefaultParamLabelRenderer()
Returns a new default param label renderer that separates option parameters from their option name with the specified separator string, and, unlessCommandLine.Model.ArgSpec.hideParamSyntax()
is true, surrounds optional parameters with'['
and']'
characters and uses ellipses ("...") to indicate that any number of a parameter are allowed.- Returns:
- a new default ParamLabelRenderer
-
createShortOptionNameComparator
public static Comparator<CommandLine.Model.OptionSpec> createShortOptionNameComparator()
SortsOptionSpecs
by their option name in case-insensitive alphabetic order. If an option has multiple names, the shortest name is used for the sorting. Help options follow non-help options.- Returns:
- a comparator that sorts OptionSpecs by their option name in case-insensitive alphabetic order
-
createShortOptionArityAndNameComparator
public static Comparator<CommandLine.Model.OptionSpec> createShortOptionArityAndNameComparator()
- Returns:
- a comparator that sorts OptionSpecs by arity first, then their option name
-
shortestFirst
public static Comparator<String> shortestFirst()
Sorts short strings before longer strings.- Returns:
- a comparators that sorts short strings before longer strings
-
ansi
public CommandLine.Help.Ansi ansi()
Returns whether ANSI escape codes are enabled or not.- Returns:
- whether ANSI escape codes are enabled or not
-
defaultColorScheme
public static CommandLine.Help.ColorScheme defaultColorScheme(CommandLine.Help.Ansi ansi)
Creates and returns a newCommandLine.Help.ColorScheme
initialized with picocli default values: commands are bold, options and parameters use a yellow foreground, and option parameters use italic.- Parameters:
ansi
- whether the usage help message should contain ANSI escape codes or not- Returns:
- a new default color scheme
-
-