CsConsole 0.1.2
dotnet add package CsConsole --version 0.1.2
NuGet\Install-Package CsConsole -Version 0.1.2
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="CsConsole" Version="0.1.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="CsConsole" Version="0.1.2" />
<PackageReference Include="CsConsole" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add CsConsole --version 0.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: CsConsole, 0.1.2"
#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.
#:package CsConsole@0.1.2
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=CsConsole&version=0.1.2
#tool nuget:?package=CsConsole&version=0.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
CsConsole
CsConsole is a simple C# console application utility library that simplifies creating interactive console applications. The repository also contains a header-only C++20 library with equivalent functionality.
Example usage:
using CsConsole;
namespace CsConsole.Example;
public class SomeState : ICommandState
{
public int Value { get; set; }
public bool Done { get; set; }
}
internal static class Program
{
public static async Task Main()
{
var parser = new CommandParser<SomeState>();
parser.Add(new ClearCommand());
parser.Add(new HelpCommand(parser));
parser.Add(
new SyncCommand<SomeState>(
"set",
(args, _, state) =>
{
int v = args.Int("value");
state.Value = v;
}
)
{
Description = "Sets the state value to the given integer",
Usage = "<value>",
}
);
parser.Add(
new SyncCommand<SomeState>(
"get",
(_, output, state) => output.WriteLine(state.Value.ToString())
)
);
parser.Add(
new SyncCommand<SomeState>(["quit", "q", "exit"], (_, _, state) => state.Done = true)
{
Description = "Exits the program",
}
);
var loop = new ConsoleLoop<SomeState>(parser, new SomeState());
var cin = new ConsoleInput();
var cout = new ConsoleOutput();
await loop.RunMain(cin, cout);
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.