Class CommandLine.Model.CommandSpec
- Enclosing class:
- CommandLine.Model
CommandSpec
class models a command specification, including the options, positional parameters and subcommands
supported by the command, as well as attributes for the version help message and the usage help message of the command.
Picocli views a command line application as a hierarchy of commands: there is a top-level command (usually the Java
class with the main
method) with optionally a set of command line options, positional parameters and subcommands.
Subcommands themselves can have options, positional parameters and nested sub-subcommands to any level of depth.
The object model has a corresponding hierarchy of CommandSpec
objects, each with a set of CommandLine.Model.OptionSpec
,
CommandLine.Model.PositionalParamSpec
and subcommands associated with it.
This object model is used by the picocli command line interpreter and help message generator.
Picocli can construct a CommandSpec
automatically from classes with @Command
, @Option
and
@Parameters
annotations. Alternatively a CommandSpec
can be constructed programmatically.
- Since:
- 3.0
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
Constant String holding the default program name:"<main class>"
. -
Method Summary
Modifier and TypeMethodDescriptionAdds the specified option spec or positional parameter spec to the list of configured arguments to expect.Adds the specified argument group to the groups in this command.Reflects on the class of the user object and registers any command methods (class methods annotated with@Command
) as subcommands.addMethodSubcommands
(CommandLine.IFactory factory) Reflects on the class of the user object and registers any command methods (class methods annotated with@Command
) as subcommands.addMixin
(String name, CommandLine.Model.CommandSpec mixin) Adds the specified mixinCommandSpec
object to the map of mixins for this command.addMixin
(String name, CommandLine.Model.CommandSpec mixin, CommandLine.Model.IAnnotatedElement annotatedElement) Adds the specified mixinCommandSpec
object to the map of mixins for this command.Adds the specified option spec to the list of configured arguments to expect.Adds the specified{@literal @}ParentCommand
-annotated program element to the list of elements for this command.addPositional
(CommandLine.Model.PositionalParamSpec positional) Adds the specified positional parameter spec to the list of configured arguments to expect.Adds the specified{@literal @}Spec
-annotated program element to the list of elements for this command.addSubcommand
(String name, CommandLine subCommandLine) Adds the specified subcommand with the specified name.addSubcommand
(String name, CommandLine.Model.CommandSpec subcommand) Adds the specified subcommand with the specified name.Adds the specifiedUnmatchedArgsBinding
to the list of model objects to capture unmatched arguments for this command.String[]
aliases()
Returns the alias command names of this subcommand.Sets the alternative names by which this subcommand is recognized on the command line.Returns the argument groups in this command.args()
Returns the list of all options and positional parameters configured for this command.Returns the CommandLine constructed with thisCommandSpec
model.protected CommandLine.Model.CommandSpec
commandLine
(CommandLine commandLine) Sets the CommandLine constructed with thisCommandSpec
model.create()
Creates and returns a newCommandSpec
without any associated user object.Returns the default value provider for this command.defaultValueProvider
(CommandLine.IDefaultValueProvider defaultValueProvider) Sets default value provider for this command.int
Returns exit code signifying that an exception occurred when invoking the Runnable, Callable or Method user object of a command.exitCodeOnExecutionException
(int newValue) Sets exit code signifying that an exception occurred when invoking the Runnable, Callable or Method user object of a command.int
Returns exit code for command line usage error.exitCodeOnInvalidInput
(int newValue) Sets exit code for command line usage error.int
Returns exit code for successful termination.exitCodeOnSuccess
(int newValue) Sets exit code for successful termination.int
Returns exit code for successful termination after printing usage help on user request.exitCodeOnUsageHelp
(int newValue) Sets exit code for successful termination after printing usage help on user request.int
Returns exit code for successful termination after printing version help on user request.exitCodeOnVersionHelp
(int newValue) Sets exit code for successful termination after printing version help on user request.findOption
(char shortName) Returns the option with the specified short name, ornull
if no option with that name is defined for this command.findOption
(String name) Returns the option with the specified name, ornull
if no option with that name is defined for this command.forAnnotatedObject
(Object userObject) Creates and returns a newCommandSpec
initialized from the specified associated user object.forAnnotatedObject
(Object userObject, CommandLine.IFactory factory) Creates and returns a newCommandSpec
initialized from the specified associated user object.forAnnotatedObjectLenient
(Object userObject) Creates and returns a newCommandSpec
initialized from the specified associated user object.forAnnotatedObjectLenient
(Object userObject, CommandLine.IFactory factory) Creates and returns a newCommandSpec
initialized from the specified associated user object.boolean
Returns whether this subcommand is a help command, and required options and positional parameters of the parent command should not be validated.helpCommand
(boolean newValue) Sets whether this is a help command and required parameter checking should be suspended.boolean
Returns whether whether variables should be interpolated in String values.interpolateVariables
(Boolean interpolate) Sets whether whether variables should be interpolated in String values.boolean
Returns whether method commands should be added as subcommands.Returns a map of the mixin names to mixinIAnnotatedElement
objects for this command.mixins()
Returns a map of the mixin names to mixinCommandSpec
objects configured for this command.boolean
Returnstrue
if the standard help options have been mixed in with this command,false
otherwise.mixinStandardHelpOptions
(boolean newValue) Sets whether the standard help options should be mixed in with this command.name()
Returns name of this command.Sets the String to use as the program name in the synopsis line of the help message.names()
Returns theINegatableOptionTransformer
used to create the negative form of negatable options.Sets theINegatableOptionTransformer
used to create the negative form of negatable options.Returns a map of the negated option names to option spec objects configured for this command.options()
Returns the list of options configured for this command.Returns a map of the option names to option spec objects configured for this command.parent()
Returns the parent command of this subcommand, ornull
if this is a top-level command.parent
(CommandLine.Model.CommandSpec parent) Sets the parent command of this subcommand.Returns the list of program elements annotated with{@literal @}ParentCommand
configured for this command.parser()
Returns the parser specification for this command.parser
(CommandLine.Model.ParserSpec settings) Initializes the parser specification for this command from the specified settings and returns this commandSpec.Returns the list of positional parameters configured for this command.Returns a map of the short (single character) option names to option spec objects configured for this command.Returns the String to use as the program name in the synopsis line of the help message: this command'sname
, preceded by the qualified name of the parent command, if any, separated by a space.qualifiedName
(String separator) Returns this command's fully qualified name, which is itsname
, preceded by the qualified name of the parent command, if this command has a parent command.(INCUBATING) Removes the specified option spec or positional parameter spec from the list of configured arguments to expect.Returns the list of required options and positional parameters configured for this command.Returns the resource bundle for this command.resourceBundle
(ResourceBundle bundle) Initializes the resource bundle for this command: sets theUsageMessageSpec.messages
to aMessages
object created from this command spec and the specified bundle, and then sets theArgSpec.messages
of all options and positional parameters in this command to the sameMessages
instance.Returns the resource bundle base name for this command.resourceBundleBaseName
(String resourceBundleBaseName) Initializes the resource bundle for this command: sets theUsageMessageSpec.messages
to aMessages
object created from this command spec and the specified bundle, and then sets theArgSpec.messages
of all options and positional parameters in this command to the sameMessages
instance.setAddMethodSubcommands
(Boolean addMethodSubcommands) Sets whether method commands should be added as subcommands.Returns the list of program elements annotated with{@literal @}Spec
configured for this command.Returns a read-only view of the subcommand map.toString()
Returns a string representation of this command, used in error messages and trace messages.Returns the list ofUnmatchedArgumentsBindings
configured for this command; eachUnmatchedArgsBinding
captures the arguments that could not be matched to any options or positional parameters.void
updateCommandAttributes
(CommandLine.Command cmd, CommandLine.IFactory factory) Updates the following attributes from the specified@Command
annotation: aliases,parser separator
, command name, version, help command, version provider, default provider andusage message spec
.Returns the usage help message specification for this command.Initializes the usageMessage specification for this command from the specified settings and returns this commandSpec.Returns the user object associated with this command.String[]
version()
Returns version information for this command, to print to the console when the user specifies an option to request version help.Sets version information literals for this command, to print to the console when the user specifies an option to request version help.Returns the version provider for this command, to generate theversion()
strings.versionProvider
(CommandLine.IVersionProvider versionProvider) Sets version provider for this command, to generate theversion()
strings.withToString
(String newValue) Sets the string representation of this command, used in error messages and trace messages.wrapWithoutInspection
(Object userObject) Creates and returns a newCommandSpec
with the specified associated user object.
-
Field Details
-
DEFAULT_COMMAND_NAME
Constant String holding the default program name:"<main class>"
.- Since:
- 4.0
- See Also:
-
-
Method Details
-
create
Creates and returns a newCommandSpec
without any associated user object. -
wrapWithoutInspection
Creates and returns a newCommandSpec
with the specified associated user object. The specified user object is not inspected for annotations.- Parameters:
userObject
- the associated user object. May be any object, may benull
.
-
forAnnotatedObject
Creates and returns a newCommandSpec
initialized from the specified associated user object. The specified user object must have at least oneCommandLine.Command
,CommandLine.Option
orCommandLine.Parameters
annotation.- Parameters:
userObject
- the user object annotated withCommandLine.Command
,CommandLine.Option
and/orCommandLine.Parameters
annotations.- Throws:
CommandLine.InitializationException
- if the specified object has no picocli annotations or has invalid annotations
-
forAnnotatedObject
public static CommandLine.Model.CommandSpec forAnnotatedObject(Object userObject, CommandLine.IFactory factory) Creates and returns a newCommandSpec
initialized from the specified associated user object. The specified user object must have at least oneCommandLine.Command
,CommandLine.Option
orCommandLine.Parameters
annotation.- Parameters:
userObject
- the user object annotated withCommandLine.Command
,CommandLine.Option
and/orCommandLine.Parameters
annotations.factory
- the factory used to create instances of subcommands, converters, etc., that are registered declaratively with annotation attributes- Throws:
CommandLine.InitializationException
- if the specified object has no picocli annotations or has invalid annotations
-
forAnnotatedObjectLenient
Creates and returns a newCommandSpec
initialized from the specified associated user object. If the specified user object has noCommandLine.Command
,CommandLine.Option
orCommandLine.Parameters
annotations, an emptyCommandSpec
is returned.- Parameters:
userObject
- the user object annotated withCommandLine.Command
,CommandLine.Option
and/orCommandLine.Parameters
annotations.- Throws:
CommandLine.InitializationException
- if the specified object has invalid annotations
-
forAnnotatedObjectLenient
public static CommandLine.Model.CommandSpec forAnnotatedObjectLenient(Object userObject, CommandLine.IFactory factory) Creates and returns a newCommandSpec
initialized from the specified associated user object. If the specified user object has noCommandLine.Command
,CommandLine.Option
orCommandLine.Parameters
annotations, an emptyCommandSpec
is returned.- Parameters:
userObject
- the user object annotated withCommandLine.Command
,CommandLine.Option
and/orCommandLine.Parameters
annotations.factory
- the factory used to create instances of subcommands, converters, etc., that are registered declaratively with annotation attributes- Throws:
CommandLine.InitializationException
- if the specified object has invalid annotations
-
userObject
Returns the user object associated with this command.- See Also:
-
commandLine
Returns the CommandLine constructed with thisCommandSpec
model. -
commandLine
Sets the CommandLine constructed with thisCommandSpec
model. -
parser
Returns the parser specification for this command. -
parser
Initializes the parser specification for this command from the specified settings and returns this commandSpec. -
usageMessage
Returns the usage help message specification for this command. -
usageMessage
Initializes the usageMessage specification for this command from the specified settings and returns this commandSpec. -
resourceBundleBaseName
Returns the resource bundle base name for this command.- Returns:
- the resource bundle base name from the CommandLine.Model.UsageMessageSpec.messages()
- Since:
- 4.0
-
resourceBundleBaseName
Initializes the resource bundle for this command: sets theUsageMessageSpec.messages
to aMessages
object created from this command spec and the specified bundle, and then sets theArgSpec.messages
of all options and positional parameters in this command to the sameMessages
instance. Subcommands are not modified.This method is preferable to
resourceBundle(ResourceBundle)
for pre-Java 8- Parameters:
resourceBundleBaseName
- the base name of the ResourceBundle to set, may benull
- Returns:
- this commandSpec
- Since:
- 4.0
- See Also:
-
resourceBundle
Returns the resource bundle for this command.- Returns:
- the resource bundle from the CommandLine.Model.UsageMessageSpec.messages()
- Since:
- 3.6
-
resourceBundle
Initializes the resource bundle for this command: sets theUsageMessageSpec.messages
to aMessages
object created from this command spec and the specified bundle, and then sets theArgSpec.messages
of all options and positional parameters in this command to the sameMessages
instance. Subcommands are not modified.- Parameters:
bundle
- the ResourceBundle to set, may benull
- Returns:
- this commandSpec
- Since:
- 3.6
- See Also:
-
subcommands
Returns a read-only view of the subcommand map. -
addSubcommand
public CommandLine.Model.CommandSpec addSubcommand(String name, CommandLine.Model.CommandSpec subcommand) Adds the specified subcommand with the specified name. If the specified subcommand does not have a ResourceBundle set, it is initialized to the ResourceBundle of this command spec.- Parameters:
name
- subcommand name - the preferred subcommand name to register the subcommand under. Ifnull
, the name of the specified subcommand is used; if this is alsonull
, the first alias is used. When this String is encountered in the command line arguments, the subcommand is invoked.subcommand
- describes the subcommand to envoke when the name is encountered on the command line- Returns:
- this
CommandSpec
object for method chaining - Throws:
CommandLine.InitializationException
- if the specified name isnull
, and no alternative name could be found, or if another subcommand was already registered under the same name, or if one of the aliases of the specified subcommand was already used by another subcommand.
-
addSubcommand
Adds the specified subcommand with the specified name. If the specified subcommand does not have a ResourceBundle set, it is initialized to the ResourceBundle of this command spec.- Parameters:
name
- subcommand name - the preferred subcommand name to register the subcommand under. Ifnull
, the name of the specified subcommand is used; if this is alsonull
, the first alias is used. When this String is encountered in the command line arguments, the subcommand is invoked.subCommandLine
- the subcommand to envoke when the name is encountered on the command line- Returns:
- this
CommandSpec
object for method chaining - Throws:
CommandLine.InitializationException
- if the specified name isnull
, and no alternative name could be found, or if another subcommand was already registered under the same name, or if one of the aliases of the specified subcommand was already used by another subcommand.
-
isAddMethodSubcommands
public boolean isAddMethodSubcommands()Returns whether method commands should be added as subcommands. True by default. Used by the annotation processor.- Since:
- 4.0
-
setAddMethodSubcommands
Sets whether method commands should be added as subcommands. True by default. Used by the annotation processor.- Since:
- 4.0
-
interpolateVariables
public boolean interpolateVariables()Returns whether whether variables should be interpolated in String values. True by default.- Since:
- 4.0
-
interpolateVariables
Sets whether whether variables should be interpolated in String values. True by default.- Since:
- 4.0
-
addMethodSubcommands
Reflects on the class of the user object and registers any command methods (class methods annotated with@Command
) as subcommands.- Returns:
- this
CommandLine.Model.CommandSpec
object for method chaining - Since:
- 3.6.0
- See Also:
-
addMethodSubcommands
Reflects on the class of the user object and registers any command methods (class methods annotated with@Command
) as subcommands.- Parameters:
factory
- the factory used to create instances of subcommands, converters, etc., that are registered declaratively with annotation attributes- Returns:
- this
CommandLine.Model.CommandSpec
object for method chaining - Since:
- 3.7.0
- See Also:
-
parent
Returns the parent command of this subcommand, ornull
if this is a top-level command. -
parent
Sets the parent command of this subcommand.- Returns:
- this CommandSpec for method chaining
-
add
Adds the specified option spec or positional parameter spec to the list of configured arguments to expect.- Parameters:
arg
- the option spec or positional parameter spec to add- Returns:
- this CommandSpec for method chaining
-
addOption
Adds the specified option spec to the list of configured arguments to expect. The option's CommandLine.Model.ArgSpec.description() may now return Strings from this CommandSpec's messages. The option parameter's CommandLine.Model.ArgSpec.defaultValueString() may now return Strings from this CommandSpec'sdefaultValueProvider()
IDefaultValueProvider}.- Parameters:
option
- the option spec to add- Returns:
- this CommandSpec for method chaining
- Throws:
CommandLine.DuplicateOptionAnnotationsException
- if any of the names of the specified option is the same as the name of another option
-
addPositional
public CommandLine.Model.CommandSpec addPositional(CommandLine.Model.PositionalParamSpec positional) Adds the specified positional parameter spec to the list of configured arguments to expect. The positional parameter's CommandLine.Model.ArgSpec.description() may now return Strings from this CommandSpec's messages. The positional parameter's CommandLine.Model.ArgSpec.defaultValueString() may now return Strings from this CommandSpec'sdefaultValueProvider()
IDefaultValueProvider}.- Parameters:
positional
- the positional parameter spec to add- Returns:
- this CommandSpec for method chaining
-
remove
(INCUBATING) Removes the specified option spec or positional parameter spec from the list of configured arguments to expect.- Parameters:
arg
- the option spec or positional parameter spec to remove- Returns:
- this CommandSpec for method chaining
- Throws:
UnsupportedOperationException
- if the specified ArgSpec is part of aCommandLine.Model.ArgGroupSpec
NoSuchElementException
- if the specified ArgSpec is not part of thisCommandSpec
- Since:
- 4.0
-
addArgGroup
Adds the specified argument group to the groups in this command.- Parameters:
group
- the group spec to add- Returns:
- this CommandSpec for method chaining
- Throws:
CommandLine.InitializationException
- if the specified group or one of its ancestors has already been added- Since:
- 4.0
-
addMixin
public CommandLine.Model.CommandSpec addMixin(String name, CommandLine.Model.CommandSpec mixin, CommandLine.Model.IAnnotatedElement annotatedElement) Adds the specified mixinCommandSpec
object to the map of mixins for this command.- Parameters:
name
- the name that can be used to later retrieve the mixinmixin
- the mixin whose options and positional parameters and other attributes to add to this commandannotatedElement
- the `@Mixin`-annotated program element- Returns:
- this CommandSpec for method chaining
- Since:
- 4.1
- See Also:
-
addMixin
Adds the specified mixinCommandSpec
object to the map of mixins for this command.- Parameters:
name
- the name that can be used to later retrieve the mixinmixin
- the mixin whose options and positional parameters and other attributes to add to this command- Returns:
- this CommandSpec for method chaining
-
addUnmatchedArgsBinding
public CommandLine.Model.CommandSpec addUnmatchedArgsBinding(CommandLine.Model.UnmatchedArgsBinding spec) Adds the specifiedUnmatchedArgsBinding
to the list of model objects to capture unmatched arguments for this command.- Parameters:
spec
- the unmatched arguments binding to capture unmatched arguments- Returns:
- this CommandSpec for method chaining
-
addSpecElement
Adds the specified{@literal @}Spec
-annotated program element to the list of elements for this command.- Returns:
- this CommandSpec for method chaining
- Since:
- 4.0
-
addParentCommandElement
public CommandLine.Model.CommandSpec addParentCommandElement(CommandLine.Model.IAnnotatedElement spec) Adds the specified{@literal @}ParentCommand
-annotated program element to the list of elements for this command.- Returns:
- this CommandSpec for method chaining
- Since:
- 4.0
-
mixins
Returns a map of the mixin names to mixinCommandSpec
objects configured for this command.- Returns:
- an immutable map of mixins added to this command.
-
mixinAnnotatedElements
Returns a map of the mixin names to mixinIAnnotatedElement
objects for this command.- Returns:
- an immutable map of `@Mixin`-annotated elements added to this command.
- Since:
- 4.1
- See Also:
-
options
Returns the list of options configured for this command.- Returns:
- an immutable list of options that this command recognizes.
-
positionalParameters
Returns the list of positional parameters configured for this command.- Returns:
- an immutable list of positional parameters that this command recognizes.
-
argGroups
Returns the argument groups in this command.- Returns:
- an immutable list of groups of options and positional parameters in this command
- Since:
- 4.0
-
optionsMap
Returns a map of the option names to option spec objects configured for this command.- Returns:
- an immutable map of options that this command recognizes.
-
negatedOptionsMap
Returns a map of the negated option names to option spec objects configured for this command.- Returns:
- an immutable map of negatable options that this command recognizes.
- Since:
- 4.0
-
posixOptionsMap
Returns a map of the short (single character) option names to option spec objects configured for this command.- Returns:
- an immutable map of options that this command recognizes.
-
requiredArgs
Returns the list of required options and positional parameters configured for this command. This does not include options and positional parameters that are part of a group.- Returns:
- an immutable list of the required options and positional parameters for this command.
-
unmatchedArgsBindings
Returns the list ofUnmatchedArgumentsBindings
configured for this command; eachUnmatchedArgsBinding
captures the arguments that could not be matched to any options or positional parameters. -
specElements
Returns the list of program elements annotated with{@literal @}Spec
configured for this command.- Since:
- 4.0
-
parentCommandElements
Returns the list of program elements annotated with{@literal @}ParentCommand
configured for this command.- Since:
- 4.0
-
name
Returns name of this command. Used in the synopsis line of the help message.DEFAULT_COMMAND_NAME
by default, initialized fromCommandLine.Command.name()
if defined.- See Also:
-
aliases
Returns the alias command names of this subcommand.- Since:
- 3.1
-
names
- Since:
- 3.9
-
args
Returns the list of all options and positional parameters configured for this command.- Returns:
- an immutable list of all options and positional parameters for this command.
-
qualifiedName
Returns the String to use as the program name in the synopsis line of the help message: this command'sname
, preceded by the qualified name of the parent command, if any, separated by a space.- Returns:
DEFAULT_COMMAND_NAME
by default, initialized fromCommandLine.Command.name()
and the parent command if defined.- Since:
- 3.0.1
-
qualifiedName
Returns this command's fully qualified name, which is itsname
, preceded by the qualified name of the parent command, if this command has a parent command.- Parameters:
separator
- the string to put between the names of the commands in the hierarchy- Returns:
DEFAULT_COMMAND_NAME
by default, initialized fromCommandLine.Command.name()
and the parent command if any.- Since:
- 3.6
-
version
Returns version information for this command, to print to the console when the user specifies an option to request version help. This is not part of the usage help message.- Returns:
- the version strings generated by the
version provider
if one is set, otherwise the version literals
-
versionProvider
Returns the version provider for this command, to generate theversion()
strings.- Returns:
- the version provider or
null
if the version strings should be returned from the version literals.
-
helpCommand
public boolean helpCommand()Returns whether this subcommand is a help command, and required options and positional parameters of the parent command should not be validated.- Returns:
true
if this subcommand is a help command and picocli should not check for missing required options and positional parameters on the parent command- See Also:
-
exitCodeOnSuccess
public int exitCodeOnSuccess()Returns exit code for successful termination. by default, may be set programmatically or via theexitCodeOnSuccess
annotation.- Since:
- 4.0
- See Also:
-
exitCodeOnUsageHelp
public int exitCodeOnUsageHelp()Returns exit code for successful termination after printing usage help on user request. by default, may be set programmatically or via theexitCodeOnVersionHelp
annotation.- Since:
- 4.0
- See Also:
-
exitCodeOnVersionHelp
public int exitCodeOnVersionHelp()Returns exit code for successful termination after printing version help on user request. by default, may be set programmatically or via theexitCodeOnUsageHelp
annotation.- Since:
- 4.0
- See Also:
-
exitCodeOnInvalidInput
public int exitCodeOnInvalidInput()Returns exit code for command line usage error. by default, may be set programmatically or via theexitCodeOnInvalidInput
annotation.- Since:
- 4.0
- See Also:
-
exitCodeOnExecutionException
public int exitCodeOnExecutionException()Returns exit code signifying that an exception occurred when invoking the Runnable, Callable or Method user object of a command. by default, may be set programmatically or via theexitCodeOnExecutionException
annotation.- Since:
- 4.0
- See Also:
-
negatableOptionTransformer
Returns theINegatableOptionTransformer
used to create the negative form of negatable options.- Since:
- 4.0
- See Also:
-
mixinStandardHelpOptions
public boolean mixinStandardHelpOptions()Returnstrue
if the standard help options have been mixed in with this command,false
otherwise. -
toString
Returns a string representation of this command, used in error messages and trace messages. -
name
Sets the String to use as the program name in the synopsis line of the help message.- Returns:
- this CommandSpec for method chaining
-
aliases
Sets the alternative names by which this subcommand is recognized on the command line.- Returns:
- this CommandSpec for method chaining
- Since:
- 3.1
-
defaultValueProvider
Returns the default value provider for this command.- Returns:
- the default value provider or
null
- Since:
- 3.6
-
defaultValueProvider
public CommandLine.Model.CommandSpec defaultValueProvider(CommandLine.IDefaultValueProvider defaultValueProvider) Sets default value provider for this command.- Parameters:
defaultValueProvider
- the default value provider to use, ornull
.- Returns:
- this CommandSpec for method chaining
- Since:
- 3.6
-
version
Sets version information literals for this command, to print to the console when the user specifies an option to request version help. Only used if noversionProvider
is set.- Returns:
- this CommandSpec for method chaining
-
versionProvider
Sets version provider for this command, to generate theversion()
strings.- Parameters:
versionProvider
- the version provider to use to generate the version strings, ornull
if the version literals should be used.- Returns:
- this CommandSpec for method chaining
-
helpCommand
Sets whether this is a help command and required parameter checking should be suspended.- Returns:
- this CommandSpec for method chaining
- See Also:
-
exitCodeOnSuccess
Sets exit code for successful termination. by default.- Since:
- 4.0
- See Also:
-
exitCodeOnUsageHelp
Sets exit code for successful termination after printing usage help on user request. by default.- Since:
- 4.0
- See Also:
-
exitCodeOnVersionHelp
Sets exit code for successful termination after printing version help on user request. by default.- Since:
- 4.0
- See Also:
-
exitCodeOnInvalidInput
Sets exit code for command line usage error. by default.- Since:
- 4.0
- See Also:
-
exitCodeOnExecutionException
Sets exit code signifying that an exception occurred when invoking the Runnable, Callable or Method user object of a command. by default.- Since:
- 4.0
- See Also:
-
negatableOptionTransformer
public CommandLine.Model.CommandSpec negatableOptionTransformer(CommandLine.INegatableOptionTransformer newValue) Sets theINegatableOptionTransformer
used to create the negative form of negatable options.- Since:
- 4.0
- See Also:
-
mixinStandardHelpOptions
Sets whether the standard help options should be mixed in with this command.- Returns:
- this CommandSpec for method chaining
- See Also:
-
withToString
Sets the string representation of this command, used in error messages and trace messages.- Parameters:
newValue
- the string representation- Returns:
- this CommandSpec for method chaining
-
updateCommandAttributes
Updates the following attributes from the specified
@Command
annotation: aliases,parser separator
, command name, version, help command, version provider, default provider andusage message spec
.- Parameters:
cmd
- the@Command
annotation to get attribute values fromfactory
- factory used to instantiate classes- Since:
- 3.7
-
findOption
Returns the option with the specified short name, ornull
if no option with that name is defined for this command. -
findOption
Returns the option with the specified name, ornull
if no option with that name is defined for this command.- Parameters:
name
- used to search the options. May include option name prefix characters or not.
-