Gapotchenko.FX.Diagnostics.CommandLine 2024.2.5

Prefix Reserved
dotnet add package Gapotchenko.FX.Diagnostics.CommandLine --version 2024.2.5                
NuGet\Install-Package Gapotchenko.FX.Diagnostics.CommandLine -Version 2024.2.5                
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="2024.2.5" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Gapotchenko.FX.Diagnostics.CommandLine --version 2024.2.5                
#r "nuget: Gapotchenko.FX.Diagnostics.CommandLine, 2024.2.5"                
#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=2024.2.5

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

Overview

The module provides primitives for command line manipulation.

CommandLineBuilder

CommandLineBuilder class allows you to dynamically build a command line. 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.AppendFileName(@"C:\Temp\Test 1.txt");
clb.AppendFileName(@"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")
    .AppendFileName(@"C:\Temp\Test 1.txt")
    .AppendFileName(@"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 you 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 commandLine = 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 arguments from the command line then you can just make them null:

// 'mode' will have a non-null value if there is a need to specify it.
string? mode = binary ? "/b" : null;

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

The code above produces the following outputs depending on the value of binary flag:

"C:\Temp\Test 1.txt" "C:\Temp\Test 2.txt"
/b "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.

Split

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

using Gapotchenko.FX.Diagnostics;

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

foreach (string arg in CommandLine.Split(commandLine))
    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 is compatible.  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 is compatible.  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 netcoreapp2.0 was computed.  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 net461 is compatible.  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

Provides extended functionality for process manipulation.

Gapotchenko.FX.Diagnostics.WebBrowser

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
2024.2.5 287 12/31/2024
2024.1.3 1,448 11/10/2024
2022.2.7 41,254 5/1/2022
2022.2.5 1,892 5/1/2022
2022.1.4 998 4/6/2022
2021.2.21 1,096 1/21/2022
2021.2.20 976 1/17/2022
2021.1.5 776 7/6/2021
2020.2.2-beta 507 11/21/2020
2020.1.15 917 11/5/2020
2020.1.9-beta 567 7/14/2020
2020.1.8-beta 530 7/14/2020
2020.1.7-beta 592 7/14/2020
2020.1.1-beta 644 2/11/2020
2019.3.7 942 11/4/2019
2019.2.20 903 8/13/2019
2019.1.151 1,007 3/30/2019