Gapotchenko.FX.Diagnostics.CommandLine 2022.2.7

Prefix Reserved
dotnet add package Gapotchenko.FX.Diagnostics.CommandLine --version 2022.2.7                
NuGet\Install-Package Gapotchenko.FX.Diagnostics.CommandLine -Version 2022.2.7                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Gapotchenko.FX.Diagnostics.CommandLine" Version="2022.2.7" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Gapotchenko.FX.Diagnostics.CommandLine --version 2022.2.7                
#r "nuget: Gapotchenko.FX.Diagnostics.CommandLine, 2022.2.7"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Gapotchenko.FX.Diagnostics.CommandLine as a Cake Addin
#addin nuget:?package=Gapotchenko.FX.Diagnostics.CommandLine&version=2022.2.7

// Install Gapotchenko.FX.Diagnostics.CommandLine as a Cake Tool
#tool nuget:?package=Gapotchenko.FX.Diagnostics.CommandLine&version=2022.2.7                

Overview

The module provides primitives for command line manipulation.

CommandLineBuilder

CommandLineBuilder class from Gapotchenko.FX.Diagnostics.CommandLine module allows to dynamically build a command line on the fly. It provides the built-in support for characters than need escaping.

Semantically CommandLineBuilder is similar to StringBuilder class:

using Gapotchenko.FX.Diagnostics;

var clb = new CommandLineBuilder();
clb.AppendParameter("/b");
clb.AppendParameter(@"C:\Temp\Test 1.txt");
clb.AppendParameter(@"C:\Temp\Test 2.txt");

Console.WriteLine(clb.ToString());

The code above produces the following output:

/b "C:\Temp\Test 1.txt" "C:\Temp\Test 2.txt"

Note how some command line parameters were automatically quoted because they contained whitespace characters.

CommandLineBuilder supports a fluent interface just like conventional StringBuilder, so the code can be rewritten as:

var clb = new CommandLineBuilder()
    .AppendParameter("/b")
    .AppendParameter(@"C:\Temp\Test 1.txt")
    .AppendParameter(@"C:\Temp\Test 2.txt");

Console.WriteLine(clb.ToString());

The resulting command line can be used in various places, most notably for starting a new process:

using System.Diagnostics;

…
Process.Start("copy", clb.ToString());

CommandLine

CommandLine static class provides operations for command line manipulation.

Build

CommandLine.Build method allows to quickly build a command line string from a specified list of arguments. Basically, this is a shortcut to CommandLineBuilder class in a handy functional form:

string s = CommandLine.Build("/b", @"C:\Temp\Test 1.txt", @"C:\Temp\Test 2.txt");

Such a form is very useful in something like this:

Process.Start(
    "cmd",
    CommandLine.Build(
        "/C", "copy",
        "/b", @"C:\Temp\Test 1.txt", @"C:\Temp\Test 2.txt"));

Another cool thing: if you want to exclude some argument from a command line then you can just make it null:

string mode = null;

// 'mode' can be assigned to a non-null value if there is a need to specify it.

string s = CommandLine.Build(mode, @"C:\Temp\Test 1.txt", @"C:\Temp\Test 2.txt");
Console.WriteLine(s);

The code above produces the following output:

"C:\Temp\Test 1.txt" "C:\Temp\Test 2.txt"

This is a neat departure from a traditional .NET convention where it always throws ArgumentNullException. Instead, Gapotchenko.FX uses a slightly different philosophy. It does the best job possible under existing conditions by following common-sense expectations of a user.

Split

CommandLine.Split provides the opposite operation to CommandLine.Build. It allows to split a command line string into a list of arguments using the rules of a host operating system:

using Gapotchenko.FX.Diagnostics;

string s = "/b \"C:\\Temp\\Test 1.txt\" \"C:\\Temp\\Test 2.txt\"";

foreach (string arg in CommandLine.Split(s))
    Console.WriteLine(arg);

The code above produces the following output:

/b
C:\Temp\Test 1.txt
C:\Temp\Test 2.txt

Commonly Used Types

  • Gapotchenko.FX.Diagnostics.CommandLine
  • Gapotchenko.FX.Diagnostics.CommandLineBuilder

Other Modules

Let's continue with a look at some other modules provided by Gapotchenko.FX:

Or look at the full list of modules.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  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 is compatible.  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. 
.NET Core netcoreapp2.0 is compatible.  netcoreapp2.1 is compatible.  netcoreapp2.2 was computed.  netcoreapp3.0 is compatible.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net46 is compatible.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 is compatible.  net472 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Gapotchenko.FX.Diagnostics.CommandLine:

Package Downloads
Gapotchenko.FX.Diagnostics.Process

The module provides extended functionality for process manipulation.

Gapotchenko.FX.Diagnostics.WebBrowser

The module provides high-level integration with OS web browser.

Gapotchenko.FX.Profiles.Core

Represents the Core profile of Gapotchenko.FX.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2022.2.7 32,450 5/1/2022
2022.2.5 1,830 5/1/2022
2022.1.4 938 4/6/2022
2021.2.21 1,044 1/21/2022
2021.2.20 922 1/17/2022
2021.1.5 714 7/6/2021
2020.2.2-beta 453 11/21/2020
2020.1.15 865 11/5/2020
2020.1.9-beta 522 7/14/2020
2020.1.8-beta 500 7/14/2020
2020.1.7-beta 541 7/14/2020
2020.1.1-beta 600 2/11/2020
2019.3.7 880 11/4/2019
2019.2.20 852 8/13/2019
2019.1.151 951 3/30/2019