HelloCommand.cs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using Microsoft.Extensions.Logging;
  2. using System;
  3. using System.CommandLine;
  4. using System.CommandLine.Invocation;
  5. using System.CommandLine.IO;
  6. using System.CommandLine.Rendering;
  7. using System.Threading.Tasks;
  8. namespace CustomHostingDemo
  9. {
  10. public class HelloCommand : CustomCommand<HelloCommand.HelloArgs>
  11. {
  12. public HelloCommand()
  13. : base("hello", "says hello", typeof(DefaultHandler))
  14. {
  15. AddArgument(new Argument<DateTime>("date", () => DateTime.Today));
  16. AddOption(new Option<bool>("--verbose"));
  17. }
  18. public class HelloArgs
  19. {
  20. public DateTime Date { get; set; }
  21. public bool Verbose { get; set; }
  22. }
  23. public class DefaultHandler : ICommandHandler<HelloArgs>
  24. {
  25. private readonly ILogger _logger;
  26. private readonly ILog _log;
  27. public DefaultHandler(Logger<DefaultHandler> logger, ILog log)
  28. {
  29. _logger = logger;
  30. _log = log;
  31. }
  32. public Task<int> InvokeAsync(InvocationContext context, HelloArgs args)
  33. {
  34. _log.LogMessage("Hello YOU!");
  35. _log.LogMessage($"P: --date {args.Date}");
  36. _log.LogMessage($"P: --verbose {args.Verbose}");
  37. _logger.LogInformation("INFO from DefaultHandler");
  38. var span = new ContainerSpan(StyleSpan.UnderlinedOn(),
  39. new ContentSpan("Underlining"),
  40. StyleSpan.UnderlinedOff());
  41. context.Console.Out.WriteLine(span.ToString(OutputMode.Auto));
  42. context.Console.Out.WriteLine(new ContainerSpan(
  43. ForegroundColorSpan.LightGreen(),
  44. StyleSpan.BlinkOn(),
  45. new ContentSpan("Blinking"),
  46. StyleSpan.BlinkOff(),
  47. new ContentSpan("Noblink"),
  48. ForegroundColorSpan.Reset(),
  49. new ContentSpan("Normal")
  50. ).ToString(OutputMode.Ansi));
  51. return Task.FromResult(3);
  52. }
  53. }
  54. }
  55. }