Core features

Go back


ITGlobal.CLI’s core features are located in ITGlobal.CLI.Terminal Nuget package and provide the following abilities:

Initialization

Before you may use any of ITGlobal.CLI’s features, you need to initialize terminal driver:

using var _ = Terminal.Initialize();

You may call this method multiple times, it will run initialization only one anyway.

Colored console output

ITGlobal.CLI provides (and uses internally) a unified wrapper for standart input, output and error streams - an AnsiString struct. This is basically an array for characters combined with color attributes.

Under the hood ITGlobal.CLI uses ANSI escape codes for colorization. Also it contains a driver to properly handle ANSI color codes while running on Windows. However, only color codes are supported, full ANSI support is not available.

Converting an AnsiString into a string (via standard ToString() method) will result in colored ANSI string that may be consumed by an ANSI compatible terminal.

Creating colored strings

AnsiString offers few ways to to create and manage it:

Printing colored strings

Once created, an AnsiString may be printed to a console using default System.Console class:

using var _ = Terminal.Initialize();

Console.WriteLine("GREEN on DEFAULT".Green());
Console.WriteLine($"GREEN on RED {"(but this would be RED on GREEN)".RedOnGreen()} GREEN on RED".GreenOnRed());
Console.WriteLine("RED on DEFAULT".Red());

Here’s an output of this code sample:

colors

Ctrl+C/SIGINT interceptor

You can easily intercept a Ctrl-C/SIGINT event and convert it into a CancellationToken:

using(var ctrlC = Terminal.OnCtrlC())
{
    CancellationToken token = ctrlC.CancellationToken;

    token.Register(() => Console.WriteLine("This is a callback on a CancellationToken"));

    Console.WriteLine("Press Ctrl+C to exit...");
    token.WaitHandle.WaitOne();
    Console.WriteLine("Cancelled!");
}

ctrl-c

Unified error handling

ITGlobal CLI offers an easy way to pretty-print exceptions in a command line application:

TerminalErrorHandler.Handle(() =>
{
    throw new Exception("This exception will be pretty-printed to console");
});

error

Note that CommandLineExceptions are handled differently, allowing you to create a nice error message:

TerminalErrorHandler.Handle(() =>
{
    throw new CommandLineException(
        "You have done something wrong, please read the manual and correct youself."
    );
});

cli-error

Async functions are supported too:

await TerminalErrorHandler.HandleAsync(async () =>
{
    await Task.Delay(100);
    throw new Exception("This exception will be pretty-printed to console");
});

No-Colors mode

ITGlobal.CLI allows you to (temporarily) disable console output colorization. This might come in handy when you need to keep your console output clean of ANSI escape sequences.

Console.WriteLine("This text will be printed in color".Green());

using (Terminal.DisableColors())
{
    Console.WriteLine("This text will be printed in black and white".Green());
}

Console.WriteLine("This text will be printed in color".Green());

no-color