CliRunAsync(Delegate, CliSettings, CancellationToken) Method
            Parses the command line arguments and runs the indicated command as delegate.
            
Namespace: DotMake.CommandLineAssembly: DotMake.CommandLine (in DotMake.CommandLine.dll) Version: 2.8.2
public static Task<int> RunAsync(
	Delegate cliCommandAsDelegate,
	CliSettings settings = null,
	CancellationToken cancellationToken = default
)
- cliCommandAsDelegate  Delegate
 - 
    
             The command as delegate.
             
([CliArgument] string argument1, bool option1) => { }
([CliArgument] string argument1, bool option1) => { return 0; }
async ([CliArgument] string argument1, bool option1) => { await Task.Delay(1000); }
MethodReference
 - settings  CliSettings  (Optional)
 - 
    The settings for the parser's grammar and behaviors.
  
 - cancellationToken  CancellationToken  (Optional)
 - 
    
    The token to monitor for cancellation requests.
  
  
 
TaskInt32
    The exit code for the invocation.
  
 //In Program.cs, to go async, add this simple code:
Cli.Run(async ([CliArgument] string argument1, bool option1) =>
{
    Console.WriteLine($@"Value for {nameof(argument1)} parameter is '{argument1}'");
    Console.WriteLine($@"Value for {nameof(option1)} parameter is '{option1}'");
    await Task.Delay(1000);
});
//Or:
Cli.Run(Method);
async Task Method([CliArgument] string argument2, bool option2)
{
    Console.WriteLine($@"Value for {nameof(argument2)} parameter is '{argument2}'");
    Console.WriteLine($@"Value for {nameof(option2)} parameter is '{option2}'");
    await Task.Delay(1000);
}
//In Program.cs, to go async, add this simple code for returning exit code:
return Cli.Run(async ([CliArgument] string argument1, bool option1) =>
{
    Console.WriteLine($@"Value for {nameof(argument1)} parameter is '{argument1}'");
    Console.WriteLine($@"Value for {nameof(option1)} parameter is '{option1}'");
    await Task.Delay(1000);
    return 0;
});