clapnet 0.2.0
dotnet add package clapnet --version 0.2.0
NuGet\Install-Package clapnet -Version 0.2.0
<PackageReference Include="clapnet" Version="0.2.0" />
<PackageVersion Include="clapnet" Version="0.2.0" />
<PackageReference Include="clapnet" />
paket add clapnet --version 0.2.0
#r "nuget: clapnet, 0.2.0"
#:package clapnet@0.2.0
#addin nuget:?package=clapnet&version=0.2.0
#tool nuget:?package=clapnet&version=0.2.0
clapnet
Small helper library that provides a simple way to use System.CommandLine by just passing a bunch of functions into a builder and creating a command line application.
Usage
It works great with the newly introduced dotnet scripts. More about the scripts here.
Logic for how the library turns a function into a command is straightforward:
- each basic type (e.g. bool, string, int) parameter is turned into an argument
- each class parameter is turned into bunch of options, where each field is turned into an option. Default values from class declaration are respected.
- if return type is
intthen the command will return the value of the function. Otherwise, it will return 0.
Small example
This is a valid program that can be run from the command line:
#!/usr/bin/env dotnet run
#:package clapnet@0.2.*
return clapnet.CommandBuilder.New()
.WithRootCommand(()=> Console.WriteLine("Hello world"), "Small program")
.Run(args);
More feature-rich example
Example with extra settings and more commands:
#!/usr/bin/env dotnet run
#:project clapnet@0.1.*
var builder = clapnet.CommandBuilder.New();
return builder
.With(()=> Console.WriteLine("ssss"), "", "lambda_two")
.With(Gather, "Documentation for gather command")
.With(Failing, "This command will fail")
.With(()=> Console.WriteLine("ssss"),"Test command", "lambda")
.WithRootCommand(Other, "Super command to show what can be done")
.Run(args);
void Gather(SomeSettings settings, string test2 = "some", bool assert = false)
{
Console.WriteLine("Hello World argument test: {0}", test2);
}
void Other(SomeSettings settings)
{
Console.WriteLine("Hello World from the root command");
Console.WriteLine("Hello World from the root command");
}
int Failing()
{
/// Returning non zero value
return 1;
}
class SomeSettings
{
/// <summary>
/// Test value, it will be possible to set its value by passing `--test true/false`.
/// </summary>
public bool Test = false;
/// <summary>
/// Test value, it will be possible to set its value by passing `--other "string value"`.
/// </summary>
public string other = "Default Value";
}
Now when called from the CLI it will print out:
./Test.cs -- --help
Description:
Super command to show what can be done
Usage:
Test [command] [options]
Options:
--test
--other <other>
-?, -h, --help Show help and usage information
--version Show version information
Commands:
lambda_two
gather <test> <assert> Documentation for gather command [default: some]
failing This command will fail
lambda Test command
Take a look at the examples directory for a simple example of how to use clapnet.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- System.CommandLine (>= 2.0.0-rc.2.25502.107)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.