Update readme

This commit is contained in:
Oleksii Holub
2022-04-23 21:26:54 +00:00
committed by GitHub
parent 1c69d5c80d
commit 7e1db916fc

View File

@@ -66,10 +66,10 @@ public static class Program
``` ```
> ⚠️ Ensure that your `Main()` method returns the integer exit code provided by `CliApplication.RunAsync()`, as shown in the above example. > ⚠️ Ensure that your `Main()` method returns the integer exit code provided by `CliApplication.RunAsync()`, as shown in the above example.
Exit code is used to communicate execution result to the parent process, so it's important that your program propagates it. > Exit code is used to communicate execution result to the parent process, so it's important that your program propagates it.
> 💡 When calling `CliApplication.RunAsync()`, **CliFx** resolves command line arguments and environment variables from `Environment.GetCommandLineArgs()` and `Environment.GetEnvironmentVariables()` respectively. > 💡 When calling `CliApplication.RunAsync()`, **CliFx** resolves command line arguments and environment variables from `Environment.GetCommandLineArgs()` and `Environment.GetEnvironmentVariables()` respectively.
You can also provide them explicitly if you choose. > You can also provide them explicitly if you choose.
The code above uses `AddCommandsFromThisAssembly()` to detect command types defined within the current assembly. The code above uses `AddCommandsFromThisAssembly()` to detect command types defined within the current assembly.
Commands are entry points, through which the user can interact with your application. Commands are entry points, through which the user can interact with your application.
@@ -98,7 +98,7 @@ Use this abstraction in place of `System.Console` whenever you need to write out
With the basic setup above, the user can now run the application and get a greeting in return: With the basic setup above, the user can now run the application and get a greeting in return:
```sh ```powershell
> dotnet myapp.dll > dotnet myapp.dll
Hello world! Hello world!
@@ -107,7 +107,7 @@ Hello world!
Out of the box, the application also comes with built-in `--help` and `--version` options. Out of the box, the application also comes with built-in `--help` and `--version` options.
They can be used to show help text or application version respectively: They can be used to show help text or application version respectively:
```sh ```powershell
> dotnet myapp.dll --help > dotnet myapp.dll --help
MyApp v1.0 MyApp v1.0
@@ -120,7 +120,7 @@ OPTIONS
--version Shows version information. --version Shows version information.
``` ```
```sh ```powershell
> dotnet myapp.dll --version > dotnet myapp.dll --version
v1.0 v1.0
@@ -160,11 +160,11 @@ public class LogCommand : ICommand
``` ```
> 💡 **CliFx** has built-in analyzers that detect common errors in command definitions. > 💡 **CliFx** has built-in analyzers that detect common errors in command definitions.
Your code will not compile if the command contains duplicate options, overlapping parameters, or otherwise invalid configuration. > Your code will not compile if the command contains duplicate options, overlapping parameters, or otherwise invalid configuration.
In order to execute this command, at a minimum, the user needs to provide the input value: In order to execute this command, at a minimum, the user needs to provide the input value:
```sh ```powershell
> dotnet myapp.dll 10000 > dotnet myapp.dll 10000
4 4
@@ -172,7 +172,7 @@ In order to execute this command, at a minimum, the user needs to provide the in
They can also pass the `base` option to override the default logarithm base of 10: They can also pass the `base` option to override the default logarithm base of 10:
```sh ```powershell
> dotnet myapp.dll 729 -b 3 > dotnet myapp.dll 729 -b 3
6 6
@@ -180,7 +180,7 @@ They can also pass the `base` option to override the default logarithm base of 1
In case the user forgets to specify the `value` parameter, the application will exit with an error: In case the user forgets to specify the `value` parameter, the application will exit with an error:
```sh ```powershell
> dotnet myapp.dll -b 10 > dotnet myapp.dll -b 10
Missing required parameter(s): Missing required parameter(s):
@@ -189,7 +189,7 @@ Missing required parameter(s):
Available parameters and options are also listed in the command's help text, which can be accessed by passing the `--help` option: Available parameters and options are also listed in the command's help text, which can be accessed by passing the `--help` option:
```sh ```powershell
> dotnet myapp.dll --help > dotnet myapp.dll --help
MyApp v1.0 MyApp v1.0
@@ -209,7 +209,7 @@ OPTIONS
Overall, parameters and options are both used to consume input from the command line, but they differ in a few important ways: Overall, parameters and options are both used to consume input from the command line, but they differ in a few important ways:
| | Parameter | Option | | | Parameter | Option |
|--------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------| | ------------------ | ------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------- |
| **Identification** | Positional (by relative order). | Nominal (by name or short name). | | **Identification** | Positional (by relative order). | Nominal (by name or short name). |
| **Requiredness** | Required by default. Only the last parameter can be configured to be optional. | Optional by default. Any option can be configured to be required without limitations. | | **Requiredness** | Required by default. Only the last parameter can be configured to be optional. | Optional by default. Any option can be configured to be required without limitations. |
| **Arity** | Only the last parameter can be bound to a non-scalar property (i.e. an array). | Any option can be bound to a non-scalar property without limitations. | | **Arity** | Only the last parameter can be bound to a non-scalar property (i.e. an array). | Any option can be bound to a non-scalar property without limitations. |
@@ -242,7 +242,7 @@ Similarly, unseparated arguments in the form of `myapp -ofile` will be treated a
These rules also make the order of arguments important — command line string is expected to follow this pattern: These rules also make the order of arguments important — command line string is expected to follow this pattern:
```sh ```powershell
> myapp [...directives] [command] [...parameters] [...options] > myapp [...directives] [command] [...parameters] [...options]
``` ```
@@ -288,7 +288,7 @@ public class FileSizeCalculatorCommand : ICommand
} }
``` ```
```sh ```powershell
> dotnet myapp.dll file1.bin file2.exe > dotnet myapp.dll file1.bin file2.exe
Total file size: 186368 bytes Total file size: 186368 bytes
@@ -314,7 +314,7 @@ public class FileSizeCalculatorCommand : ICommand
} }
``` ```
```sh ```powershell
> dotnet myapp.dll --files file1.bin file2.exe > dotnet myapp.dll --files file1.bin file2.exe
Total file size: 186368 bytes Total file size: 186368 bytes
@@ -391,7 +391,7 @@ public class AuthCommand : ICommand
} }
``` ```
```sh ```powershell
> $env:AUTH_TOKEN="test" > $env:AUTH_TOKEN="test"
> dotnet myapp.dll > dotnet myapp.dll
@@ -445,7 +445,7 @@ For example, running `dotnet myapp.dll cmd1 arg1 -p 42` will execute `FirstComma
Requesting help will show direct subcommands of the current command: Requesting help will show direct subcommands of the current command:
```sh ```powershell
> dotnet myapp.dll --help > dotnet myapp.dll --help
MyApp v1.0 MyApp v1.0
@@ -467,7 +467,7 @@ You can run `dotnet myapp.dll [command] --help` to show help on a specific comma
The user can also refine their help request by querying it on a specific command: The user can also refine their help request by querying it on a specific command:
```sh ```powershell
> dotnet myapp.dll cmd1 --help > dotnet myapp.dll cmd1 --help
USAGE USAGE
@@ -484,7 +484,7 @@ You can run `dotnet myapp.dll cmd1 [command] --help` to show help on a specific
``` ```
> 💡 Defining a default (unnamed) command is not required. > 💡 Defining a default (unnamed) command is not required.
If it's absent, running the application without specifying a command will just show the root level help text. > If it's absent, running the application without specifying a command will just show the root level help text.
### Reporting errors ### Reporting errors
@@ -517,7 +517,7 @@ public class DivideCommand : ICommand
} }
``` ```
```sh ```powershell
> dotnet myapp.dll --dividend 10 --divisor 0 > dotnet myapp.dll --dividend 10 --divisor 0
Division by zero is not supported. Division by zero is not supported.
@@ -529,7 +529,7 @@ Division by zero is not supported.
``` ```
> ⚠️ Even though exit codes are represented by 32-bit integers in .NET, using values outside of 8-bit unsigned range will cause an overflow on Unix systems. > ⚠️ Even though exit codes are represented by 32-bit integers in .NET, using values outside of 8-bit unsigned range will cause an overflow on Unix systems.
To avoid unexpected results, use numbers between 1 and 255 for exit codes that indicate failure. > To avoid unexpected results, use numbers between 1 and 255 for exit codes that indicate failure.
### Graceful cancellation ### Graceful cancellation
@@ -562,7 +562,7 @@ public class CancellableCommand : ICommand
``` ```
> ⚠️ Forceful termination of a command can only be delayed once. > ⚠️ Forceful termination of a command can only be delayed once.
If the user issues a second interrupt signal, the process will be killed immediately without waiting for graceful cancellation. > If the user issues a second interrupt signal, the process will be killed immediately without waiting for graceful cancellation.
### Type activation ### Type activation
@@ -688,7 +688,7 @@ To do that, you need to pass the corresponding directive before any other argume
In order to run the application in debug mode, use the `[debug]` directive. In order to run the application in debug mode, use the `[debug]` directive.
This will cause the program to launch in a suspended state, waiting for debugger to be attached to the process: This will cause the program to launch in a suspended state, waiting for debugger to be attached to the process:
```sh ```powershell
> dotnet myapp.dll [debug] cmd -o > dotnet myapp.dll [debug] cmd -o
Attach debugger to PID 3148 to continue. Attach debugger to PID 3148 to continue.
@@ -697,12 +697,12 @@ Attach debugger to PID 3148 to continue.
To run the application in preview mode, use the `[preview]` directive. To run the application in preview mode, use the `[preview]` directive.
This will short-circuit the execution and instead print the consumed command line arguments as they were parsed, along with resolved environment variables: This will short-circuit the execution and instead print the consumed command line arguments as they were parsed, along with resolved environment variables:
```sh ```powershell
> dotnet myapp.dll [preview] cmd arg1 arg2 -o foo --option bar1 bar2 > dotnet myapp.dll [preview] cmd arg1 arg2 -o foo --option bar1 bar2
Command line: Command line:
cmd <arg1> <arg2> [-o foo] [--option bar1 bar2] cmd <arg1> <arg2> [-o foo] [--option bar1 bar2]
Environment: Environment:
FOO="123" FOO="123"
BAR="xyz" BAR="xyz"
@@ -721,4 +721,4 @@ var app = new CliApplicationBuilder()
## Etymology ## Etymology
**CliFx** is made out of "Cli" for "Command Line Interface" and "Fx" for "Framework". **CliFx** is made out of "Cli" for "Command Line Interface" and "Fx" for "Framework".
It's pronounced as "cliff ex". It's pronounced as "cliff ex".