CommandLineSwitchParser 1.1.0
dotnet add package CommandLineSwitchParser --version 1.1.0
NuGet\Install-Package CommandLineSwitchParser -Version 1.1.0
<PackageReference Include="CommandLineSwitchParser" Version="1.1.0" />
paket add CommandLineSwitchParser --version 1.1.0
#r "nuget: CommandLineSwitchParser, 1.1.0"
// Install CommandLineSwitchParser as a Cake Addin #addin nuget:?package=CommandLineSwitchParser&version=1.1.0 // Install CommandLineSwitchParser as a Cake Tool #tool nuget:?package=CommandLineSwitchParser&version=1.1.0
CommandLineSwitchParser
data:image/s3,"s3://crabby-images/8b63a/8b63a07b91ea926a619f52ba2531634289e591bc" alt="Build status"
Summary
This is a simple parser for command line options on .NET Framework & .NET Core.
What you should do is only define your option class and write code like "var option = CommandLineSwitch.Parse<YourOptionClass>(ref args);
".
There is no need to annotate your option class with any attributes.
Install
PM> Install-Package CommandLineSwitchParser
Example
This library provides CommandLineSwitch.Parse<T>()
static method.
// Open name space.
using CommandLineSwitchParser;
...
// Declare your own class that represents a command line switch.
public class Option1
{
public bool Recursive { get; set; }
public int Port { get; set; } = 8080;
}
// if args is "--port 80 c:\wwwroot\inetpub -r", then ...
public static void Main(string[] args)
{
var options = CommandLineSwitch.Parse<Option1>(ref args);
// Short switch matches an initial of option class property name.
Console.WriteLine(options.Recursive); // True
// Long switch matches a full name of option class property name.
Console.WriteLine(options.Port); // 80
// Switches in "args" are stripped.
Console.WriteLine(args[0]) // "c:\wwwroot\inetpub"
}
This library also provides CommandLineSwitch.TryParse<T>()
static method, too.
if (CommandLineSwitch.TryParse<Option1>(ref args, out var options, out var err)){
// Success!
}
Command line switches/options naming convention
- All properties of option class are mapped to lowercase option name.
- A full property name with converted to lower case is mapped to long name starts with a double hyphen ("--").
- An initial of property name with converted to lower case is mapped to short name starts with single hyphen ("-").
public class Option1
{
public bool Recursive { get; set; }
// -> mapped to "-r" and "--recursive"
public int Port { get; set; }
// -> mapped to "-p" and "--port"
}
- If the option class has some properties those are same initials, those properties aren't mapped to short name. Those properties are mapped only long name.
// In this case, short name "-a" is unavailable.
public class Option2
{
public bool AutoGenerate { get; set; }
// -> mapped to only "--autogenerate"
public int Align { get; set; }
// -> mapped to only "--align"
}
- You can use "enum" type in properties of option class.
- "enum" values are also mapped to lower case symbols.
public enum {
Left,
Center,
Right
}
public class Option3
{
public int Align { get; set; }
// -> mapped to "-a" and "--align",
// and this option can specify with
// one of the "left", "center", "right".
}
Parsing error handling
If CommandLineSwitch.Parse<T>()
encountered invalid syntax command line arguments, it throws InvalidCommandLineSwitchException
exception.
You can retrieve the details of parsing error from ParserError
property of the InvalidCommandLineSwitchException
exception object.
// The option class has not "-x" switch/option.
public class Option1
{
public bool Recursive { get; set; }
public int Port { get; set; }
}
// if args is new []{"-x"} ...
try {
var option = CommandLineSwitch.Parse<Option1>(ref args);
// -> it throw exception!
}
catch (InvalidCommandLineSwitchException e){
// You can access "e.ParserError" property
// to retrieve details of the error.
}
CommandLineSwitch.TryParse<T>()
return false when it encountered invalid command line arguments instead of throwing exception.
You can retrieve the details of parsing error from 3rd output argument of CommandLineSwitch.TryParse<T>()
method.
// if args is new []{"-x"} ...
if (CommandLineSwitch.TryParse<Option1>(ref args, out var option, out var err) == false){
// -> it returns false.
// You can access "err" output variable
// to retrieve details of the error.
}
The parsing error information is provided by CommandLineSwitchParserError
class.
CommandLineSwitchParserError
class exposes the following properties:
Property type and name | Description |
---|---|
ErrorTypes ErrorType | It represents the reason of parsing error. |
string OptionName | The option name that causes parsing error. |
string Parameter | The option parameter that causes parsing error. |
Type ExpectedParameterType | The .NET type that expected to option parameter. |
ErrorType
take the one of ErrorTypes
enum values the following:
- UnknownOption
- MissingParameter
- InvalidParameterFormat
- ParameterOverflow
When the parsing error occurred:
- It returns only one of the first parsing error.
- The command line arguments are not stripped.
FAQ
Questions
- Is there any way to setup custom option name?
- Can I get "usage" document automatically generated?
- Can I use "/" instead of "-" ?
- Can I use "-name=value" syntax instead of "-name value" ?
- Can I use "-ab" syntax instead of "-a -b" ?
Answer
Sorry, no way.
I'm interested in keeping this library to simple usage.
That is the most important reason I created this library despite there are already numerous command line parsing libraries.
So I have no plan at this time.
If you need those features, you may consider using Microsoft.Extensions.CommandLineUtils (see also), or choose one of the many libraries published on NuGet that was tagged with "commandline" (search result is here).
Release Notes
License
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. |
.NET Core | netcoreapp1.0 was computed. netcoreapp1.1 was computed. netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard1.1 is compatible. netstandard1.2 was computed. netstandard1.3 was computed. netstandard1.4 was computed. netstandard1.5 was computed. netstandard1.6 was computed. netstandard2.0 was computed. netstandard2.1 was computed. |
.NET Framework | net45 was computed. net451 was computed. net452 is compatible. net46 was computed. 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 | tizen30 was computed. tizen40 was computed. tizen60 was computed. |
Universal Windows Platform | uap was computed. uap10.0 was computed. |
Windows Phone | wpa81 was computed. |
Windows Store | netcore was computed. netcore45 was computed. netcore451 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.5.2
- No dependencies.
-
.NETStandard 1.1
- NETStandard.Library (>= 1.6.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on CommandLineSwitchParser:
Package | Downloads |
---|---|
dotnet-md2html
Yet another implementation of the Markdown Text to HTML Converter, built on .NET Core console application. |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on CommandLineSwitchParser:
Repository | Stars |
---|---|
jsakamoto/BlazorWasmPreRendering.Build
When you publish your Blazor Wasm app, this package pre-renders and saves the app as static HTML files in your public folder.
|
Version | Downloads | Last updated |
---|---|---|
1.1.0 | 6,235 | 1/17/2022 |
1.0.0 | 3,566 | 9/28/2017 |
0.5.0-beta | 978 | 9/15/2017 |
0.4.0-beta | 969 | 9/14/2017 |
0.3.0-beta | 1,012 | 9/13/2017 |
0.2.0-beta | 864 | 1/5/2017 |
v.1.1.0
- Improve: added parser options and allowed users to change enum parsing style.