Skip to content

Features#

Feature
Commands
   Define commands as methods docs ✔️
      Parameter Resolvers
         Inject console and other contexts as a parameter:
         IConsole, CommandContext, CancellationToken & IPrompter by default.
docs ✔️
   Infinite nesting of subcommands docs ✔️
      Nested classes ✔️
      Composed classes ✔️
   Command interception
      interceptors for subcommands
      middleware for all commands
✔️
   Method interception
      CommandContext.InvocationPipeline to access method and params
✔️
Arguments
   Positional (Operands) docs ✔️
   Named (Options) docs ✔️
      short and long names: -h or --help, not /help ✔️
      flags: -a instead of -a true docs ✔️
      bundling/clubbing: -a -b -c or -abc docs ✔️
      value assignments: -a one, -a=one & -a:one docs ✔️
   Define arguments as parameters in methods docs ✔️
   Define arguments as properties in POCOs docs ✔️
Data Types
   Primitives, Enums & Nullable< T > docs ✔️
   Collections docs ✔️
   Dictionaries #251
   Password: mask value in logs and output with ***** docs ✔️
   Any type with a string constructor docs ✔️
   Any type with a static Parse(string) method docs ✔️
   Any type with a TypeConverter docs ✔️
   Custom Type Descriptors
      Customize parsing and the type name shown in help and
docs ✔️
   Define allowed values by type
      Allowed values are shown in help and will soon be used for suggestions
docs ✔️
Argument Values
   Response Files docs ✔️
   Piped Input docs ✔️
      Streaming docs ✔️
   Prompts docs ✔️
      Hide passwords docs ✔️
      Multi-entry for collections docs ✔️
      Auto prompt for missing arguments (optional) docs ✔️
   Default from EnvVar docs ✔️
   Default from AppSetting docs ✔️
Validation
   FluentValidation for argument models docs ✔️
   DataAnnotations docs ✔️
Help
   Autocomplete #48
   Typo suggestions docs ✔️
   Auto generated help
      Aliases: -? -h --help
docs ✔️
   Custom help generators docs ✔️
Diagnostics
   App Version
      _-v or --version
docs ✔️
   [debug] directive
      step into debugger
docs ✔️
   [time] directive
      outputs the execution time of a command
docs ✔️
   [parse] directive docs ✔️
      show final values ✔️
      show inputs and source
         original source of value, including response file paths
✔️
      show defaults and source
         including key if from EnvVar or AppSetting
✔️
   Command logging
      show parse output and optionally system info and app config
docs ✔️
Testing docs
   BDD Framework
      Test an app as if run from the console
✔️
   Supports parallel test
      the whole framework avoids static state to support parallel test runs
✔️
   TestConsole ✔️
   TestDependencyResolver
      new TestDependencyResolver{ dbSvc, httpSvc }
✔️
   TempFiles helper
      create and cleanup files used for tests
✔️
   Capture State
      Capture state within a run to help test custom middleware components
✔️
Dependency Injection docs
   MicrosoftDependencyInjection ✔️
   Autofac ✔️
   SimpleInjector ✔️
   Test injector docs ✔️
   Custom ✔️
Localization (beta)
   IStringLocalizer pattern docs ✔️
   resx translation files
      currently english only. PRs accepted.
src ✔️
   json translation pattern
      currently english only. PRs accepted.
src ✔️
   Culture directive
      set the culture a command will run in
docs ✔️
   Test support docs ✔️
Other
   Ctrl+C docs ✔️
   Name casing
      consistent name casing via Humanizer
docs ✔️
   Spectre AnsiConsole
      ansi, colors, markup syntax, prompting, progress bars, tables. live displays, test capture, and much more
docs ✔️
Extensibility
   Custom middleware docs ✔️
   Custom directives docs ✔️
   Custom token transformations docs ✔️
   Custom parameter resolvers docs ✔️
Back to top