Package picocli

Class 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

    Class Diagram of the CommandLine.Help API

    Layered API

    The CommandLine.Command annotation and the CommandLine.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 or CommandLine.Parameters to an array of CommandLine.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 a CommandLine.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 the CommandLine.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.

    • Constructor Detail

      • Help

        public Help​(Object command)
        Constructs a new Help 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 new Help 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
        ansi - whether to emit ANSI escape codes or not
      • Help

        public Help​(CommandLine.Model.CommandSpec commandSpec,
                    CommandLine.Help.ColorScheme colorScheme)
        Constructs a new Help instance with the specified color scheme, initialized from annotations on the specified class and superclasses.
        Parameters:
        commandSpec - the command model to create usage help for
        colorScheme - the color scheme to use
    • Method Detail

      • colorScheme

        public CommandLine.Help.ColorScheme colorScheme()
        Returns the ColorScheme model that this Help was constructed with.
        Since:
        3.0
      • allSubcommands

        public Map<String,​CommandLine.Help> allSubcommands()
        Returns the map of all subcommand Help 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
      • addSubcommand

        @Deprecated
        public CommandLine.Help addSubcommand​(String commandName,
                                              Object command)
        Deprecated.
        Registers 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 message
        command - the CommandSpec 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
      • 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)
        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 or null if options should not be sorted
        clusterBooleanOptions - 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 line
        optionSort - comparator to sort options or null if options should not be sorted
        clusterBooleanOptions - 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 groups
        endOfOptionsText - the Ansi.Text object containing the end of options delimiter (if enabled)
        positionalParamText - the Ansi.Text object showing the rendered positional parameters
        commandText - 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 or null if options should not be sorted
        clusterBooleanOptions - 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 synopsis
        optionSort - comparator to sort options or null if options should not be sorted
        clusterBooleanOptions - 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, or null, 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
      • optionListExcludingGroups

        public String optionListExcludingGroups​(List<CommandLine.Model.OptionSpec> optionList,
                                                CommandLine.Help.Layout layout,
                                                Comparator<CommandLine.Model.OptionSpec> optionSort,
                                                CommandLine.Help.IParamLabelRenderer valueLabelRenderer)
        Sorts all Options with the specified comparator (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 displayed
        layout - the layout responsible for rendering the option list
        valueLabelRenderer - 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()
      • 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 use
        paramLabelRenderer - 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 displayed
        layout - the layout to use
        paramLabelRenderer - 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

        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 not
        usageHelpWidth - the width of the usage help message
        adjustCJK - true if wide Chinese, Japanese and Korean characters should be counted as double the size of other characters for line-breaking purposes
        values - the values to format and append to the StringBuilder
        sb - the StringBuilder to collect the formatted strings
        params - 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 the CommandLine.Command.customSynopsis() annotation attribute or programmatically by setting the Help instance's customSynopsis(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 the CommandLine.Command.description() annotation attribute or programmatically by setting the Help instance's description(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 the CommandLine.Command.header() annotation attribute or programmatically by setting the Help instance's header(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 the CommandLine.Command.footer() annotation attribute or programmatically by setting the Help instance's footer(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 of String.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 of String.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 of String.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 of String.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 of String.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 of String.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 of String.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 of String.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 specifiers
        params - 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-column TextTable 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 a TextTable
        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 by subcommands().
        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 a Text object containing the command name and all aliases, separated with the specified separator. Command names will use the command style for the color scheme of this Help.
        Since:
        3.9
      • createDefaultLayout

        public CommandLine.Help.Layout createDefaultLayout()
        Returns a Layout instance configured with the user preferences captured in this Help instance.
        Returns:
        a Layout
      • createDefaultOptionRenderer

        public CommandLine.Help.IOptionRenderer createDefaultOptionRenderer()
        Returns a new default OptionRenderer which converts Options to five columns of text to match the default TextTable column layout. The first row of values looks like this:
        1. the required option marker
        2. 2-character short option name (or empty string if no short option exists)
        3. comma separator (only if both short option and long option exist, empty string otherwise)
        4. comma-separated string with long option name(s)
        5. 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 converts Options 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
      • 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 the paramLabel 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, unless CommandLine.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()
        Sorts OptionSpecs 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
      • 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 new CommandLine.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