Improve preview directive

This commit is contained in:
Alexey Golub
2020-01-28 14:48:21 +02:00
parent 4cf622abe5
commit 82895f2e42
5 changed files with 38 additions and 23 deletions

View File

@@ -47,35 +47,51 @@ namespace CliFx
return null; return null;
} }
private int? HandlePreviewDirective(CommandLineInput commandLineInput) private int? HandlePreviewDirective(ApplicationSchema applicationSchema, CommandLineInput commandLineInput)
{ {
var isPreviewMode = _configuration.IsPreviewModeAllowed && commandLineInput.IsPreviewDirectiveSpecified; var isPreviewMode = _configuration.IsPreviewModeAllowed && commandLineInput.IsPreviewDirectiveSpecified;
if (!isPreviewMode) if (!isPreviewMode)
return null; return null;
// Render command name var commandSchema = applicationSchema.TryFindCommand(commandLineInput, out var argumentOffset);
_console.Output.WriteLine($"Arguments: {string.Join(" ", commandLineInput.Arguments)}");
_console.Output.WriteLine();
// Render directives _console.Output.WriteLine("Parser preview:");
_console.Output.WriteLine("Directives:");
foreach (var directive in commandLineInput.Directives) // Command name
if (commandSchema != null && argumentOffset > 0)
{ {
_console.Output.Write(" "); _console.WithForegroundColor(ConsoleColor.Cyan, () =>
_console.Output.WriteLine(directive); _console.Output.Write(commandSchema.Name));
_console.Output.Write(' ');
} }
// Margin // Parameters
_console.Output.WriteLine(); foreach (var parameter in commandLineInput.Arguments.Skip(argumentOffset))
{
_console.Output.Write('<');
// Render options _console.WithForegroundColor(ConsoleColor.White, () =>
_console.Output.WriteLine("Options:"); _console.Output.Write(parameter));
_console.Output.Write('>');
_console.Output.Write(' ');
}
// Options
foreach (var option in commandLineInput.Options) foreach (var option in commandLineInput.Options)
{ {
_console.Output.Write(" "); _console.Output.Write('[');
_console.Output.WriteLine(option);
_console.WithForegroundColor(ConsoleColor.White, () =>
_console.Output.Write(option));
_console.Output.Write(']');
_console.Output.Write(' ');
} }
_console.Output.WriteLine();
return 0; return 0;
} }
@@ -91,9 +107,7 @@ namespace CliFx
return 0; return 0;
} }
private int? HandleHelpOption( private int? HandleHelpOption(ApplicationSchema applicationSchema, CommandLineInput commandLineInput)
ApplicationSchema applicationSchema,
CommandLineInput commandLineInput)
{ {
// Help is rendered either when it's requested or when the user provides no arguments and there is no default command // Help is rendered either when it's requested or when the user provides no arguments and there is no default command
var shouldRenderHelp = var shouldRenderHelp =
@@ -139,7 +153,7 @@ namespace CliFx
return return
await HandleDebugDirectiveAsync(commandLineInput) ?? await HandleDebugDirectiveAsync(commandLineInput) ??
HandlePreviewDirective(commandLineInput) ?? HandlePreviewDirective(applicationSchema, commandLineInput) ??
HandleVersionOption(commandLineInput) ?? HandleVersionOption(commandLineInput) ??
HandleHelpOption(applicationSchema, commandLineInput) ?? HandleHelpOption(applicationSchema, commandLineInput) ??
await HandleCommandExecutionAsync(applicationSchema, commandLineInput, environmentVariables); await HandleCommandExecutionAsync(applicationSchema, commandLineInput, environmentVariables);

View File

@@ -43,7 +43,8 @@ namespace CliFx.Domain
? Commands.Where(c => TryFindParentCommand(c.Name)?.MatchesName(parentCommandName) == true).ToArray() ? Commands.Where(c => TryFindParentCommand(c.Name)?.MatchesName(parentCommandName) == true).ToArray()
: Commands.Where(c => !string.IsNullOrWhiteSpace(c.Name) && TryFindParentCommand(c.Name) == null).ToArray(); : Commands.Where(c => !string.IsNullOrWhiteSpace(c.Name) && TryFindParentCommand(c.Name) == null).ToArray();
private CommandSchema? TryFindCommand(CommandLineInput commandLineInput, out int argumentOffset) // TODO: this out parameter is not a really nice design
public CommandSchema? TryFindCommand(CommandLineInput commandLineInput, out int argumentOffset)
{ {
// Try to find the command that contains the most of the input arguments in its name // Try to find the command that contains the most of the input arguments in its name
for (var i = commandLineInput.Arguments.Count; i >= 0; i--) for (var i = commandLineInput.Arguments.Count; i >= 0; i--)

View File

@@ -65,7 +65,7 @@ namespace CliFx.Domain
private static readonly IFormatProvider ConversionFormatProvider = CultureInfo.InvariantCulture; private static readonly IFormatProvider ConversionFormatProvider = CultureInfo.InvariantCulture;
private static readonly IReadOnlyDictionary<Type, Func<string, object>> PrimitiveConverters = private static readonly IReadOnlyDictionary<Type, Func<string, object>> PrimitiveConverters =
new Dictionary<Type, Func<string, object>> new Dictionary<Type, Func<string?, object>>
{ {
[typeof(object)] = v => v, [typeof(object)] = v => v,
[typeof(string)] = v => v, [typeof(string)] = v => v,

View File

@@ -36,7 +36,7 @@ namespace CliFx.Domain
IsRequired = isRequired; IsRequired = isRequired;
} }
public bool MatchesName(string name) => public bool MatchesName(string? name) =>
!string.IsNullOrWhiteSpace(Name) && !string.IsNullOrWhiteSpace(Name) &&
string.Equals(Name, name, StringComparison.OrdinalIgnoreCase); string.Equals(Name, name, StringComparison.OrdinalIgnoreCase);

View File

@@ -38,7 +38,7 @@ namespace CliFx.Domain
Parameters = parameters; Parameters = parameters;
} }
public bool MatchesName(string name) => string.Equals(name, Name, StringComparison.OrdinalIgnoreCase); public bool MatchesName(string? name) => string.Equals(name, Name, StringComparison.OrdinalIgnoreCase);
private void InjectParameters(ICommand command, IReadOnlyList<string> parameterInputs) private void InjectParameters(ICommand command, IReadOnlyList<string> parameterInputs)
{ {