vertical-cli 1.0.0-dev.20250113.9

Prefix Reserved
This is a prerelease version of vertical-cli.
dotnet add package vertical-cli --version 1.0.0-dev.20250113.9                
NuGet\Install-Package vertical-cli -Version 1.0.0-dev.20250113.9                
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="vertical-cli" Version="1.0.0-dev.20250113.9" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add vertical-cli --version 1.0.0-dev.20250113.9                
#r "nuget: vertical-cli, 1.0.0-dev.20250113.9"                
#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 vertical-cli as a Cake Addin
#addin nuget:?package=vertical-cli&version=1.0.0-dev.20250113.9&prerelease

// Install vertical-cli as a Cake Tool
#tool nuget:?package=vertical-cli&version=1.0.0-dev.20250113.9&prerelease                

vertical-cli

Minimal, AOT friendly command line arguments parser.

Quick start

Install

dotnet add package vertical-cli --prerelease

Configure and run

// Define a model
public record ZipOptions(FileInfo Source, FileInfo Destination, bool Overwrite);

// Build an application with two commands
var app = new CliApplicationBuilder("gzip")
    .RouteAsync<ZipOptions>("gzip create", async (model, cancelToken) => {
        if (model.Destination.Exists && !model.Overwrite){
            Console.WriteLine("Target file already exists");
            return -1;
        }
        await using var inputStream = File.OpenRead(model.Source);
        await using var outputStream = File.OpenWrite(model.Destination);
        await using var zipStream = new GZipStream(outputStream, CompressionMode.Compress);
        await inputStream.CopyToAsync(zipStream, cancelToken);

        Console.WriteLine($"Compressed file {model.Destination} created.");
    })
    .RouteAsync<ZipOptions>("gzip extract", async (model, cancelToken) => {
        if (model.Destination.Exists && !model.Overwrite){
            Console.WriteLine("Target file already exists");
            return -1;
        }
        await using var inputStream = File.OpenRead(model.Source);
        await using var outputStream = File.OpenWrite(model.Destination);
        await using var zipStream = new GZipStream(inputStream, CompressionMode.Decompress);
        await zipStream.CopyToAsync(outputStream, cancelToken);

        Console.WriteLine($"File {model.Source} extracted.");
    })
    .MapModel<ZipOptions>(map => map
        .Argument(x => x.Source)
        .Argument(x => x.Destination)
        .Switch(x => x.Overwrite, ["--overwrite"]))
    .Build();

await app.InvokeAsync(args);

// Run:
// $ gzip picture.png picture.gz --overwrite

Features

  • Binds command line arguments to strongly typed models
  • Configure positional arguments. options and switches using short and long form notations
  • Define a hierarchy of commands each with derived models
  • Uses a source generator to bind models removing the need for reflection (AOT friendly)
  • Uses analyzers to provide wranings and errors for common misconfiguration issues
  • Display generated help content

See full docs.

Product 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.
  • net9.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.

Version Downloads Last updated
1.0.0-dev.20250113.9 21 1/13/2025
1.0.0-dev.20250112.8 29 1/12/2025
1.0.0-dev.20241214.7 55 12/14/2024
1.0.0-dev.20241207.6 57 12/7/2024
1.0.0-dev.20241207.5 48 12/7/2024
1.0.0-dev.20241206.4 54 12/6/2024
1.0.0-dev.20241206.3 45 12/6/2024
1.0.0-dev.20241206.2 49 12/6/2024
1.0.0-dev.20241206.1 49 12/6/2024
1.0.0-dev.20241118.44 51 11/18/2024
1.0.0-dev.20241116.43 52 11/16/2024
1.0.0-dev.20241113.42 61 11/13/2024
1.0.0-dev.20241113.40 52 11/13/2024
1.0.0-dev.20241113.39 51 11/13/2024
1.0.0-dev.20241113.38 53 11/13/2024
1.0.0-dev.20241029.37 59 10/29/2024
1.0.0-dev.20241023.36 55 10/23/2024
1.0.0-dev.20241022.35 58 10/22/2024
1.0.0-dev.20241022.33 57 10/22/2024
1.0.0-dev.20241022.32 57 10/22/2024
1.0.0-dev.20241022.31 56 10/22/2024
1.0.0-dev.20241020.30 66 10/20/2024
1.0.0-dev.20241019.29 77 10/19/2024
1.0.0-dev.20241019.28 78 10/19/2024
1.0.0-dev.20241019.27 89 10/19/2024
1.0.0-dev.20241012.26 61 10/12/2024
1.0.0-dev.20241010.25 64 10/10/2024
1.0.0-dev.20240712.24 72 7/12/2024
1.0.0-dev.20240702.23 69 7/2/2024
1.0.0-dev.20240702.22 67 7/2/2024
1.0.0-dev.20240628.21 70 6/28/2024
1.0.0-dev.20240625.20 68 6/25/2024
1.0.0-dev.20240624.19 68 6/24/2024
1.0.0-dev.20240621.18 74 6/21/2024
1.0.0-dev.20240620.17 75 6/20/2024
1.0.0-dev.20240620.16 74 6/20/2024
1.0.0-dev.20240620.15 70 6/20/2024
1.0.0-dev.20240620.14 73 6/20/2024
1.0.0-dev.20240619.13 75 6/19/2024
1.0.0-dev.20240617.11 67 6/17/2024
1.0.0-dev.20240130.9 78 1/30/2024
1.0.0-dev.20240118.8 61 1/18/2024