Skip to content

Releases: spectreconsole/spectre.console

0.57.0

11 Jun 20:43

Choose a tag to compare

0.57.0 Pre-release
Pre-release

What's Changed

Full Changelog: 0.56.0...0.57.0

0.56.0

05 Jun 21:59

Choose a tag to compare

0.56.0 Pre-release
Pre-release

What's Changed

New Contributors

Full Changelog: 0.55.2...0.56.0

0.55.2

17 Apr 11:50

Choose a tag to compare

0.55.2 Pre-release
Pre-release

What's Changed

  • Support variation selectors, ZWJ sequences and surrogate pairs in length calculation by @fabsenet in #2082
  • Add default value to selection prompt and multiselection prompt by @AntekOlszewski in #2079

New Contributors

Full Changelog: 0.55.1...0.55.2

0.55.1

16 Apr 21:57

Choose a tag to compare

0.55.1 Pre-release
Pre-release

What's Changed

New Contributors

Full Changelog: 0.55.0...0.55.1

0.55.0

03 Apr 12:58

Choose a tag to compare

0.55.0 Pre-release
Pre-release

This release brings new features, performance improvements, bug fixes, and some important architectural changes.

Caution

There are breaking changes in this release, so make sure you review the release notes and try things out before upgrading in production.

New Spectre.Console.Ansi Library

One of the biggest changes in this release is the introduction of
Spectre.Console.Ansi,
a new standalone library for writing ANSI escape
sequences to the terminal without taking a full dependency on Spectre.Console.

This makes it easy to add ANSI support to lightweight tools and libraries where
pulling in the full Spectre.Console package would be overkill. Spectre.Console
itself now depends on this library internally.

We've also added some nice convenience methods for the .NET Console class:

using Spectre.Console.Ansi;

Console.Markup("[yellow]Hello[/] ");
Console.MarkupLine("[blue]World[/]");
  
Console.Ansi(writer => writer
    .BeginLink("https://spectreconsole.net", linkId: 123)
    .Decoration(Decoration.Bold | Decoration.Italic)
    .Foreground(Color.Yellow)
    .Write("Spectre Console")
    .ResetStyle()
    .EndLink());

Style Is Now a Struct

Style has been converted from a class to a struct, and link/URL information
has been extracted into a separate Link type. This improves allocation
performance, especially in rendering-heavy scenarios, but is a breaking change
for code that relies on reference semantics.

Progress Improvements

The Progress widget received a lot of love in this release. It now uses
TimeProvider instead of the wall clock, making it significantly easier to
write deterministic tests. ProgressTask has a new Tag property for attaching
arbitrary metadata, and you can now override the global hide-when-completed
behavior on individual tasks. Tasks can also be removed from the progress
context entirely.

Speed calculations have been improved with configurable max sampling age and
sample count, giving you more control over how responsive or smooth the speed
readout is. Speed calculations for stopped tasks have been fixed, and
indeterminate tasks no longer show a meaningless time estimate.

Prompt Enhancements

Prompts now accept a CancellationToken, making it possible to cancel a waiting
prompt programmatically. TextPrompt default values can now be edited by the
user instead of being accepted or rejected as a whole. There is also a new
option to clear the prompt line after the user provides input.

Tables and Rendering

Table body rows now support column spans, and a new minimal border style has
been added for a cleaner look. The Canvas widget gained half-block support,
which enables double the vertical resolution when rendering graphics. JsonText
now has a configurable indentation depth. Various performance improvements have
also been made to Markup instantiation and formatting.

Bug Fixes

A memory leak related to Segment has been fixed, along with
Segment.SplitLines ignoring multiple consecutive line breaks. A crash in
SegmentShape.Calculate when the lines list was empty has been resolved.
Interactive console detection when output is redirected now works correctly,
and table expand now properly respects fixed column widths. Truncation and
overflow handling for fullwidth characters has been corrected, and locking
performance on .NET 9.0+ has been improved.

Breaking Changes

This release contains several breaking changes. Please review the following
before upgrading.

Style is now a struct. Code relying on reference semantics such as null
checks or reference equality will need to be updated. Related to this, link
and URL information has moved from Style to a new Link type, so any code
that reads or writes links through Style will need to be adjusted.

Several previously obsoleted members have been removed. The Alignment property
on Calendar, Table, and Grid, as well as the Render extension method,
no longer exist. AnsiConsoleFactory has been made static and internal, so code
that instantiated this class directly will need an alternative approach.

Finally, ANSI output is now disabled when stdout or stderr is redirected. This
is a behavior change: output that previously included ANSI escape codes when
piped or redirected will now be plain text.

What's Changed

Read more

0.53.1 (hotfix)

25 Nov 20:52

Choose a tag to compare

0.53.1 (hotfix) Pre-release
Pre-release

This is a hotfix release for 0.53.0, which accidentally included OpenCli.Sources as a dependency, instead of being included in the package.

As a bonus, a fix for panels was also included in this release 😄

What's Changed

Full Changelog: 0.53.0...0.53.1

0.54.0

12 Nov 23:54

Choose a tag to compare

0.54.0 Pre-release
Pre-release

Version 0.54.0 of Spectre.Console has been released!

Spectre.Console.Cli has a new home!

We've decided to move Spectre.Console.Cli to its own repository, where we will prepare it for a 1.0 release. This means that the Spectre.Console.Cli NuGet packages will no longer be versioned together with Spectre.Console. They will now have a preview version such as 1.0.0-alpha-0.x.

There should be no issues staying on version 0.53.0 of Spectre.Console.Cli until we release a stable version if you prefer not to use a pre-release dependency.

New unit testing package for Spectre.Console.Cli

There is now a new testing package for Spectre.Console.Cli called Spectre.Console.Cli.Testing. This is where you will find the CommandAppTester from now on.

You can find more information about unit testing in the documentation.

What's Changed

Full Changelog: 0.53.0...0.54.0

0.53.0

12 Nov 21:27

Choose a tag to compare

0.53.0 Pre-release
Pre-release

What's Changed

  • Add top-level CancellationToken support to Spectre.Console.Cli by @0xced in #1911
  • Update the Spectre.Console.Cli documentation with CancellationToken by @0xced in #1920

Full Changelog: 0.52.0...0.53.0

0.52.0

10 Oct 19:02

Choose a tag to compare

0.52.0 Pre-release
Pre-release

What's Changed

Full Changelog: 0.51.1...0.52.0

0.51.1

06 Sep 22:53

Choose a tag to compare

0.51.1 Pre-release
Pre-release

What's Changed

New Contributors

Full Changelog: 0.50.0...0.51.1