From 89a8e78b2cc53e19c0fb459cbd85196013a24902 Mon Sep 17 00:00:00 2001 From: Gabe Stocco <98900+gfs@users.noreply.github.com> Date: Thu, 27 Jul 2023 16:48:09 -0700 Subject: [PATCH] Display appropriate separator when writing default enumerable values in HelpText Fix #490 --- src/CommandLine/Text/HelpText.cs | 9 ++++--- ..._Default_Set_To_Sequence_With_Separator.cs | 18 +++++++++++++ .../Unit/Text/HelpTextTests.cs | 27 +++++++++++++++++++ 3 files changed, 51 insertions(+), 3 deletions(-) create mode 100644 tests/CommandLine.Tests/Fakes/Options_With_Default_Set_To_Sequence_With_Separator.cs diff --git a/src/CommandLine/Text/HelpText.cs b/src/CommandLine/Text/HelpText.cs index f5e9a7b9..705e3995 100644 --- a/src/CommandLine/Text/HelpText.cs +++ b/src/CommandLine/Text/HelpText.cs @@ -971,8 +971,11 @@ specification is OptionSpecification optionSpecification && if (addEnumValuesToHelpText && specification.EnumValues.Any()) optionHelpText += " Valid values: " + string.Join(", ", specification.EnumValues); + var separator = (specification is OptionSpecification optionSpecification && optionSpecification.Separator != '\0') + ? optionSpecification.Separator + : ' '; specification.DefaultValue.Do( - defaultValue => optionHelpText = "(Default: {0}) ".FormatInvariant(FormatDefaultValue(defaultValue)) + optionHelpText); + defaultValue => optionHelpText = "(Default: {0}) ".FormatInvariant(FormatDefaultValue(defaultValue, separator)) + optionHelpText); var optionGroupSpecification = GetOptionGroupSpecification(); @@ -1106,7 +1109,7 @@ private int GetMaxValueLength(ValueSpecification spec) return specLength; } - private static string FormatDefaultValue(T value) + private static string FormatDefaultValue(T value, char separator) { if (value is bool) return value.ToStringLocal().ToLowerInvariant(); @@ -1122,7 +1125,7 @@ private static string FormatDefaultValue(T value) foreach (var item in asEnumerable) builder .Append(item.ToStringLocal()) - .Append(" "); + .Append(separator); return builder.Length > 0 ? builder.ToString(0, builder.Length - 1) diff --git a/tests/CommandLine.Tests/Fakes/Options_With_Default_Set_To_Sequence_With_Separator.cs b/tests/CommandLine.Tests/Fakes/Options_With_Default_Set_To_Sequence_With_Separator.cs new file mode 100644 index 00000000..181a8a26 --- /dev/null +++ b/tests/CommandLine.Tests/Fakes/Options_With_Default_Set_To_Sequence_With_Separator.cs @@ -0,0 +1,18 @@ +// Copyright 2005-2015 Giacomo Stelluti Scala & Contributors. All rights reserved. See License.md in the project root for license information. + +using System.Collections.Generic; + +namespace CommandLine.Tests.Fakes +{ + class Options_With_Default_Set_To_Sequence_With_Separator + { + [Option('z', "strseq", Default = new[] { "a", "b", "c" }, Separator = ',')] + public IEnumerable StringSequence { get; set; } + + [Option('y', "intseq", Default = new[] { 1, 2, 3 }, Separator = ',')] + public IEnumerable IntSequence { get; set; } + + [Option('q', "dblseq", Default = new[] { 1.1, 2.2, 3.3 }, Separator = ',')] + public IEnumerable DoubleSequence { get; set; } + } +} diff --git a/tests/CommandLine.Tests/Unit/Text/HelpTextTests.cs b/tests/CommandLine.Tests/Unit/Text/HelpTextTests.cs index 9811f7be..9a678105 100644 --- a/tests/CommandLine.Tests/Unit/Text/HelpTextTests.cs +++ b/tests/CommandLine.Tests/Unit/Text/HelpTextTests.cs @@ -849,6 +849,33 @@ public void Options_should_be_separated_by_spaces() // Teardown } + + [Fact] + public void Options_should_be_separated_by_separator() + { + // Fixture setup + var handlers = new CultureInfo("en-US").MakeCultureHandlers(); + var fakeResult = + new NotParsed( + typeof(Options_With_Default_Set_To_Sequence_With_Separator).ToTypeInfo(), + Enumerable.Empty() + ); + + // Exercize system + handlers.ChangeCulture(); + var helpText = HelpText.AutoBuild(fakeResult); + handlers.ResetCulture(); + + // Verify outcome + var text = helpText.ToString(); + var lines = text.ToLines().TrimStringArray(); + + lines[3].Should().Be("-z, --strseq (Default: a,b,c)"); + lines[5].Should().Be("-y, --intseq (Default: 1,2,3)"); + lines[7].Should().Be("-q, --dblseq (Default: 1.1,2.2,3.3)"); + + // Teardown + } [Fact] public void Options_Should_Render_OptionGroup_In_Parenthesis_When_Available()