SkillAgentSearch skills...

Typin

Declarative framework for interactive CLI applications

Install / Use

/learn @adambajguz/Typin

README

Typin

<p align="center">

Build Coverage Version Downloads of Typin Downloads of Typin.Core

</p>

See TypinExamples website for interective examples.

<table> <tr> <td> <p align="center"> <img src="https://raw.githubusercontent.com/adambajguz/Typin/master/.img/typin-logo-256px.png" width="75%"> </p> </td> <td>

<b>Table of contents</b>

</tr> </table>

Typin is a simple to use, ASP.NET Core inspired framework for building both interactive command line applications and command line tools (direct mode). However, it is not limited to direct and interactive modes, because you can create your own modes.

Etymology: Typin is made out of "Typ" for "Type" and "in" for "interactively". It's pronounced as "Ty pin".

Typin is not just a parser but a complete application framework. Its main goal is to provide an enjoyable, similar to ASP.NET Core, development experience when building command line applications. Its primary goal is to completely take over the user input layer, letting you forget about the infrastructure and instead focus on writing your application.

Typin roots in CliFx

Typin is build based on the source code of CliFx, but it wants to be a ASP.NET Core for CLI like Cocona but faster. It has many additional features compared to CliFx:

  • Interactive mode with auto-completion, parameter escaping with ", and support for user-defined shortcuts,
  • Middleware pipeline,
  • Custom directives that can be used as either flags (IDirective) or dynamic pipeline extensions (IPipelinedDirective),
  • IOptionFallbackProvider for custom fallback providers instead of only environment variable fallback,
  • Build-in DI support with Microsoft.Extensions.DependencyInjection that is used accross entire framework,
  • Build-in options support with Microsoft.Extensions.Options,
  • Ability to modify exception handling with one or more exception handlers,
  • Ability to execute commands from other commands or services with ICliCommandExecutor (NOT RECOMMENDED, except for custom CLI mode classes),
  • DI injectable ICliContext with lots of useful data,
  • Manual property in CommandAttribute that can be used to provide a long, extended description of a command,
  • Custom help writer.
  • Custom modes support and application lifetime management.
  • Startup message color personalization through a callback method.
  • Console IO wrapper classes (StandardStreamReader and StandardStreamWriter) and IO interfaces.
  • Logging with Microsoft.Extensions.Logging.
  • Optional option and parameter names by automatically generated kebab case name.
  • Better char parsing: support for the following escape sequences: '\0', '\a', '\b', '\f', '\n', '\r', '\t', '\v', '\\', and Unicode escape e.g. \u006A).
  • Native support for Half, DateOnly, and TimeOnly.
  • Validation can be easily added with FluentValidation and a middleware.
  • Console input/output targeted extensions through IStandardInput, IStandardOuput, IStandardError, IStandardOutputAndError, IStandardRedirectableConsoleStream, StandardStreamReader, StandardStreamWriter.

Overall, Typin is a framework that is much more flexible and rich with both features and metadata about defined commands etc.

See CHANGELOG.md for a complete list of changes.

Also see WIKI: Roadmap and support for more info about future and support.

Features

  • Complete application framework
  • Argument (options and parmeters) parser.
  • Requires minimal amount of code to get started.
  • Configuration via attributes.
  • Handles conversions to various types, including custom types.
  • Similarly to ASP.NET Core, relies on dependency injection, thus is very extensible.
  • Supports multi-level command hierarchies.
  • Supports interactive mode and user defined modes.
  • Intuitive auto-completion (Tab / Shift + Tab) in interactive mode.
  • Intuitive command history (Up and Down arrows) in interactive mode, accessible also from user code.
  • Exposes raw input, output, error streams to handle binary data.
  • Allows graceful command cancellation.
  • Prints errors and routes exit codes on exceptions.
  • Provides comprehensive and colorful auto-generated help text.
  • Highly testable and easy to debug.
  • Automatic generation of option and parameter names by transforming property name with kebab-case formatter.
  • Targets .NET Standard 2.0, .NET Standard 2.1., .NET 5.0, and .NET 6.0.
  • Uses Microsoft.Extensions.DependencyInjection. Microsoft.Extensions.Logging.Debug and Microsoft.Extensions.Options but no other non essential dependencies.

Installing Typin

You should install Typin with NuGet:

Install-Package Typin

Or via the .NET Core command line interface:

dotnet add package Typin

Both commands will download and install Typin with all required dependencies.

Typin.Core

If you need only API interfaces, you can install TypinCore with NuGet.

Install-Package Typin.Core

Or via the .NET Core command line interface:

dotnet add package Typin.Core

Both commands will download and install Typin.Core with all required dependencies.

Getting started and Documentation

public static class Program
{
    public static async Task<int> Main() =>
        await new CliApplicationBuilder()
            .AddCommandsFromThisAssembly()
            .Build()
            .RunAsync();
}

[Command]
public class HelloWorldCommand : ICommand
{
    public async ValueTask ExecuteAsync(IConsole console)
    {
        await console.Output.WriteLineAsync("Hello world!");
    }
}

See wiki for detailed instructions and documentation.

Screenshots

help screen

Benchmarks

Here's how Typin's execution overhead compares to that of other libraries (single command comparison) and with increasing number of commands.

Typin 3.1

BenchmarkDotNet=v0.13.1, OS=Windows 10.0.19044.1415 (21H2)
Intel Core i7-4790 CPU 3.60GHz (Haswell), 1 CPU, 8 logical and 4 physical cores
.NET SDK=6.0.101
  [Host]     : .NET 6.0.1 (6.0.121.56705), X64 RyuJIT
  DefaultJob : .NET 6.0.1 (6.0.121.56705), X64 RyuJIT

| Method | Mean | Error | StdDev | Ratio | Rank | |------------------------------------- |-------------:|-----------:|------------:|------:|-----:| | CommandLineParser | 1.810 us | 0.0283 us | 0.0265 us | 0.009 | 1 | | CliFx | 70.937 us | 0.8013 us | 0.7103 us | 0.373 | 2 | | Clipr | 81.382 us | 1.3975 us | 1.3725 us | 0.428 | 3 | | McMaster.Extensions.CommandLineUtils | 88.881 us | 1.0713 us | 1.0021 us | 0.468 | 4 | | Typin | 190.249 us | 0.3856 us | 0.3220 us | 1.000 | 5 | | System.CommandLine | 278.502 us | 5.5451 us | 5.9332 us | 1.462 | 6 | | PowerArgs | 300.629 us | 1.3090 us | 1.1604 us | 1.579 | 7 | | Cocona | 1,283.562 us | 88.6368 us | 244.1316 us | 6.492 | 8 |

| Method | Mean | Error | StdDev | Ratio | Rank | |---------------------- |----------:|---------:|---------:|------:|-----:| | 'CliFx - 1 command' | 68.67 us | 0.207 us | 0.173 us | 0.36 | 1 | | 'CliFx - 2 commands' | 77.32 us | 0.577 us | 0.512 us | 0.40 | 2 | | 'CliFx - 5 commands' | 98.64 us | 0.260 us | 0.230 us | 0.51 | 3 | | 'CliFx - 10 commands' | 135.11 us | 0.317 us | 0.297 us | 0.70 | 4 | | 'Typin - 1 command' | 192.11 us | 0.662 us | 0.553 us | 1.00 | 5 | | 'Typin - 2 commands' | 202.54 us | 0.851 us | 0.754 us | 1.05 | 6 | | 'CliFx - 20 commands' | 231.62 us | 0.502 us | 0.445 us | 1.21 | 7 | | 'Typin - 5 commands' | 237.19 us | 0.388 us | 0.363 us | 1.23 | 8 | | 'Typin - 10 commands' | 298.32 us | 2.848 us | 2.378 us | 1.55 | 9 | | 'Typin - 20 commands' | 440.23 us | 0.773 us | 0.646 us | 2.29 | 10 |

Typin <= 2.1.1

BenchmarkDotNet=v0.12.0, OS=Windows 10.0.19041
Intel Core i7-4790 CPU 3.60GHz (Haswell), 1 CPU, 8 logical and 4 physical cores
.NET Core SDK=3.1.402
  [Host]     : .NET Core 3.1.8 (CoreCLR 4.700.20
View on GitHub
GitHub Stars254
CategoryDevelopment
Updated1mo ago
Forks13

Languages

C#

Security Score

85/100

Audited on Feb 11, 2026

No findings