Patrik Svensson 7fd2efaeb5 Merge segments before rendering
This will reduce the number of segments to render
and produce cleaner ANSI escape code sequences.

Closes #46
2020-08-30 12:40:34 +02:00
2020-08-29 11:25:19 +02:00
2020-08-28 11:56:54 +02:00
2020-08-30 12:40:34 +02:00
2020-07-21 12:03:41 +02:00
2020-07-21 12:03:41 +02:00
2020-08-27 19:31:44 +02:00
2020-07-21 12:03:41 +02:00
2020-07-21 12:03:41 +02:00
2020-07-21 12:03:41 +02:00
2020-08-25 11:19:58 +02:00

Spectre.Console

Spectre.Console NuGet Version

A .NET Standard 2.0 library that makes it easier to create beautiful console applications.
It is heavily inspired by the excellent Rich library for Python.

Table of Contents

  1. Features
  2. Example
  3. Usage
    3.1. Using the static API
    3.2. Creating a console
  4. Running examples
  5. Available styles
  6. Predefined colors

Features

  • Written with unit testing in mind.
  • Supports tables, grids, panels, and a rich inspired markup language.
  • Supports the most common SRG parameters when it comes to text styling such as bold, dim, italic, underline, strikethrough, and blinking text.
  • Supports 3/4/8/24-bit colors in the terminal.
    The library will detect the capabilities of the current terminal and downgrade colors as needed.

Example

Example

Usage

The Spectre.Console API is stateful and is not thread-safe. If you need to write to the console from different threads, make sure that you take appropriate precautions, just like when you use the regular System.Console API.

If the current terminal does not support ANSI escape sequences, Spectre.Console will fallback to using the System.Console API.

NOTE: This library is currently under development and API's might change or get removed at any point up until a 1.0 release.

Using the static API

The static API is perfect when you just want to output text like you usually do with the System.Console API, but prettier.

AnsiConsole.Foreground = Color.CornflowerBlue;
AnsiConsole.Decoration = Decoration.Underline | Decoration.Bold;
AnsiConsole.WriteLine("Hello World!");

AnsiConsole.Reset();
AnsiConsole.MarkupLine("[bold yellow on red]{0}[/] [underline]world[/]!", "Goodbye");

If you want to get a reference to the default IAnsiConsole, you can access it via AnsiConsole.Console.

Creating a console

Sometimes it's useful to explicitly create a console with specific capabilities, such as during unit testing when you want control over the environment your code runs in.

It's recommended to not use AnsiConsole in code that run as part of a unit test.

IAnsiConsole console = AnsiConsole.Create(
    new AnsiConsoleSettings()
    {
        Ansi = AnsiSupport.Yes,
        ColorSystem = ColorSystemSupport.TrueColor,
        Out = new StringWriter(),
    });

NOTE: Even if you can specify a specific color system to use when manually creating a console, remember that the user's terminal might not be able to use it, so unless you're creating an IAnsiConsole for testing, always use ColorSystemSupport.Detect and AnsiSupport.Detect.

Running examples

To see Spectre.Console in action, install the dotnet-example global tool.

> dotnet tool install -g dotnet-example

Now you can list available examples in this repository:

> dotnet example

╭────────┬───────────────────────────────┬─────────────────────────────────────────────────╮
│ Name   │ Path                          │ Description                                     │
├────────┼───────────────────────────────┼─────────────────────────────────────────────────┤
│ Colors │ examples/Colors/Colors.csproj │ Demonstrates how to use colors in the console.  │
│ Grid   │ examples/Grid/Grid.csproj     │ Demonstrates how to render grids in a console.  │
│ Panel  │ examples/Panel/Panel.csproj   │ Demonstrates how to render items in panels.     │
│ Table  │ examples/Table/Table.csproj   │ Demonstrates how to render tables in a console. │
╰────────┴───────────────────────────────┴─────────────────────────────────────────────────╯

And to run an example:

> dotnet example table
┌──────────┬──────────┬────────┐
│ Foo      │ Bar      │ Baz    │
├──────────┼──────────┼────────┤
│ Hello    │ World!   │        │
│ Bonjour  │ le       │ monde! │
│ Hej      │ Världen! │        │
└──────────┴──────────┴────────┘

Available styles

NOTE: Not all styles are supported in every terminal.

Name Description
bold Bold text
dim Dim or faint text
italic Italic text
underline Underlined text
invert Swaps the foreground and background colors
conceal Hides the text
slowblink Makes text blink slowly
rapidblink Makes text blink
strikethrough Shows text with a horizontal line through the center

Predefined colors

Number Name RGB Hex System.ConsoleColor
0 black 0,0,0 #000000 Black
1 maroon 128,0,0 #800000 DarkRed
2 green 0,128,0 #008000 DarkGreen
3 olive 128,128,0 #808000 DarkYellow
4 navy 0,0,128 #000080 DarkBlue
5 purple 128,0,128 #800080 DarkMagenta
6 teal 0,128,128 #008080 DarkCyan
7 silver 192,192,192 #c0c0c0 Gray
8 grey 128,128,128 #808080 DarkGray
9 red 255,0,0 #ff0000 Red
10 lime 0,255,0 #00ff00 Green
11 yellow 255,255,0 #ffff00 Yellow
12 blue 0,0,255 #0000ff Blue
13 fuchsia 255,0,255 #ff00ff Magenta
14 aqua 0,255,255 #00ffff Cyan
15 white 255,255,255 #ffffff White
16 grey0 0,0,0 #000000
17 navyblue 0,0,95 #00005f
18 darkblue 0,0,135 #000087
19 blue3 0,0,175 #0000af
20 blue3_1 0,0,215 #0000d7
21 blue1 0,0,255 #0000ff
22 darkgreen 0,95,0 #005f00
23 deepskyblue4 0,95,95 #005f5f
24 deepskyblue4_1 0,95,135 #005f87
25 deepskyblue4_2 0,95,175 #005faf
26 dodgerblue3 0,95,215 #005fd7
27 dodgerblue2 0,95,255 #005fff
28 green4 0,135,0 #008700
29 springgreen4 0,135,95 #00875f
30 turquoise4 0,135,135 #008787
31 deepskyblue3 0,135,175 #0087af
32 deepskyblue3_1 0,135,215 #0087d7
33 dodgerblue1 0,135,255 #0087ff
34 green3 0,175,0 #00af00
35 springgreen3 0,175,95 #00af5f
36 darkcyan 0,175,135 #00af87
37 lightseagreen 0,175,175 #00afaf
38 deepskyblue2 0,175,215 #00afd7
39 deepskyblue1 0,175,255 #00afff
40 green3_1 0,215,0 #00d700
41 springgreen3_1 0,215,95 #00d75f
42 springgreen2 0,215,135 #00d787
43 cyan3 0,215,175 #00d7af
44 darkturquoise 0,215,215 #00d7d7
45 turquoise2 0,215,255 #00d7ff
46 green1 0,255,0 #00ff00
47 springgreen2_1 0,255,95 #00ff5f
48 springgreen1 0,255,135 #00ff87
49 mediumspringgreen 0,255,175 #00ffaf
50 cyan2 0,255,215 #00ffd7
51 cyan1 0,255,255 #00ffff
52 darkred 95,0,0 #5f0000
53 deeppink4 95,0,95 #5f005f
54 purple4 95,0,135 #5f0087
55 purple4_1 95,0,175 #5f00af
56 purple3 95,0,215 #5f00d7
57 blueviolet 95,0,255 #5f00ff
58 orange4 95,95,0 #5f5f00
59 grey37 95,95,95 #5f5f5f
60 mediumpurple4 95,95,135 #5f5f87
61 slateblue3 95,95,175 #5f5faf
62 slateblue3_1 95,95,215 #5f5fd7
63 royalblue1 95,95,255 #5f5fff
64 chartreuse4 95,135,0 #5f8700
65 darkseagreen4 95,135,95 #5f875f
66 paleturquoise4 95,135,135 #5f8787
67 steelblue 95,135,175 #5f87af
68 steelblue3 95,135,215 #5f87d7
69 cornflowerblue 95,135,255 #5f87ff
70 chartreuse3 95,175,0 #5faf00
71 darkseagreen4_1 95,175,95 #5faf5f
72 cadetblue 95,175,135 #5faf87
73 cadetblue_1 95,175,175 #5fafaf
74 skyblue3 95,175,215 #5fafd7
75 steelblue1 95,175,255 #5fafff
76 chartreuse3_1 95,215,0 #5fd700
77 palegreen3 95,215,95 #5fd75f
78 seagreen3 95,215,135 #5fd787
79 aquamarine3 95,215,175 #5fd7af
80 mediumturquoise 95,215,215 #5fd7d7
81 steelblue1_1 95,215,255 #5fd7ff
82 chartreuse2 95,255,0 #5fff00
83 seagreen2 95,255,95 #5fff5f
84 seagreen1 95,255,135 #5fff87
85 seagreen1_1 95,255,175 #5fffaf
86 aquamarine1 95,255,215 #5fffd7
87 darkslategray2 95,255,255 #5fffff
88 darkred_1 135,0,0 #870000
89 deeppink4_1 135,0,95 #87005f
90 darkmagenta 135,0,135 #870087
91 darkmagenta_1 135,0,175 #8700af
92 darkviolet 135,0,215 #8700d7
93 purple_1 135,0,255 #8700ff
94 orange4_1 135,95,0 #875f00
95 lightpink4 135,95,95 #875f5f
96 plum4 135,95,135 #875f87
97 mediumpurple3 135,95,175 #875faf
98 mediumpurple3_1 135,95,215 #875fd7
99 slateblue1 135,95,255 #875fff
100 yellow4 135,135,0 #878700
101 wheat4 135,135,95 #87875f
102 grey53 135,135,135 #878787
103 lightslategrey 135,135,175 #8787af
104 mediumpurple 135,135,215 #8787d7
105 lightslateblue 135,135,255 #8787ff
106 yellow4_1 135,175,0 #87af00
107 darkolivegreen3 135,175,95 #87af5f
108 darkseagreen 135,175,135 #87af87
109 lightskyblue3 135,175,175 #87afaf
110 lightskyblue3_1 135,175,215 #87afd7
111 skyblue2 135,175,255 #87afff
112 chartreuse2_1 135,215,0 #87d700
113 darkolivegreen3_1 135,215,95 #87d75f
114 palegreen3_1 135,215,135 #87d787
115 darkseagreen3 135,215,175 #87d7af
116 darkslategray3 135,215,215 #87d7d7
117 skyblue1 135,215,255 #87d7ff
118 chartreuse1 135,255,0 #87ff00
119 lightgreen 135,255,95 #87ff5f
120 lightgreen_1 135,255,135 #87ff87
121 palegreen1 135,255,175 #87ffaf
122 aquamarine1_1 135,255,215 #87ffd7
123 darkslategray1 135,255,255 #87ffff
124 red3 175,0,0 #af0000
125 deeppink4_2 175,0,95 #af005f
126 mediumvioletred 175,0,135 #af0087
127 magenta3 175,0,175 #af00af
128 darkviolet_1 175,0,215 #af00d7
129 purple_2 175,0,255 #af00ff
130 darkorange3 175,95,0 #af5f00
131 indianred 175,95,95 #af5f5f
132 hotpink3 175,95,135 #af5f87
133 mediumorchid3 175,95,175 #af5faf
134 mediumorchid 175,95,215 #af5fd7
135 mediumpurple2 175,95,255 #af5fff
136 darkgoldenrod 175,135,0 #af8700
137 lightsalmon3 175,135,95 #af875f
138 rosybrown 175,135,135 #af8787
139 grey63 175,135,175 #af87af
140 mediumpurple2_1 175,135,215 #af87d7
141 mediumpurple1 175,135,255 #af87ff
142 gold3 175,175,0 #afaf00
143 darkkhaki 175,175,95 #afaf5f
144 navajowhite3 175,175,135 #afaf87
145 grey69 175,175,175 #afafaf
146 lightsteelblue3 175,175,215 #afafd7
147 lightsteelblue 175,175,255 #afafff
148 yellow3 175,215,0 #afd700
149 darkolivegreen3_2 175,215,95 #afd75f
150 darkseagreen3_1 175,215,135 #afd787
151 darkseagreen2 175,215,175 #afd7af
152 lightcyan3 175,215,215 #afd7d7
153 lightskyblue1 175,215,255 #afd7ff
154 greenyellow 175,255,0 #afff00
155 darkolivegreen2 175,255,95 #afff5f
156 palegreen1_1 175,255,135 #afff87
157 darkseagreen2_1 175,255,175 #afffaf
158 darkseagreen1 175,255,215 #afffd7
159 paleturquoise1 175,255,255 #afffff
160 red3_1 215,0,0 #d70000
161 deeppink3 215,0,95 #d7005f
162 deeppink3_1 215,0,135 #d70087
163 magenta3_1 215,0,175 #d700af
164 magenta3_2 215,0,215 #d700d7
165 magenta2 215,0,255 #d700ff
166 darkorange3_1 215,95,0 #d75f00
167 indianred_1 215,95,95 #d75f5f
168 hotpink3_1 215,95,135 #d75f87
169 hotpink2 215,95,175 #d75faf
170 orchid 215,95,215 #d75fd7
171 mediumorchid1 215,95,255 #d75fff
172 orange3 215,135,0 #d78700
173 lightsalmon3_1 215,135,95 #d7875f
174 lightpink3 215,135,135 #d78787
175 pink3 215,135,175 #d787af
176 plum3 215,135,215 #d787d7
177 violet 215,135,255 #d787ff
178 gold3_1 215,175,0 #d7af00
179 lightgoldenrod3 215,175,95 #d7af5f
180 tan 215,175,135 #d7af87
181 mistyrose3 215,175,175 #d7afaf
182 thistle3 215,175,215 #d7afd7
183 plum2 215,175,255 #d7afff
184 yellow3_1 215,215,0 #d7d700
185 khaki3 215,215,95 #d7d75f
186 lightgoldenrod2 215,215,135 #d7d787
187 lightyellow3 215,215,175 #d7d7af
188 grey84 215,215,215 #d7d7d7
189 lightsteelblue1 215,215,255 #d7d7ff
190 yellow2 215,255,0 #d7ff00
191 darkolivegreen1 215,255,95 #d7ff5f
192 darkolivegreen1_1 215,255,135 #d7ff87
193 darkseagreen1_1 215,255,175 #d7ffaf
194 honeydew2 215,255,215 #d7ffd7
195 lightcyan1 215,255,255 #d7ffff
196 red1 255,0,0 #ff0000
197 deeppink2 255,0,95 #ff005f
198 deeppink1 255,0,135 #ff0087
199 deeppink1_1 255,0,175 #ff00af
200 magenta2_1 255,0,215 #ff00d7
201 magenta1 255,0,255 #ff00ff
202 orangered1 255,95,0 #ff5f00
203 indianred1 255,95,95 #ff5f5f
204 indianred1_1 255,95,135 #ff5f87
205 hotpink 255,95,175 #ff5faf
206 hotpink_1 255,95,215 #ff5fd7
207 mediumorchid1_1 255,95,255 #ff5fff
208 darkorange 255,135,0 #ff8700
209 salmon1 255,135,95 #ff875f
210 lightcoral 255,135,135 #ff8787
211 palevioletred1 255,135,175 #ff87af
212 orchid2 255,135,215 #ff87d7
213 orchid1 255,135,255 #ff87ff
214 orange1 255,175,0 #ffaf00
215 sandybrown 255,175,95 #ffaf5f
216 lightsalmon1 255,175,135 #ffaf87
217 lightpink1 255,175,175 #ffafaf
218 pink1 255,175,215 #ffafd7
219 plum1 255,175,255 #ffafff
220 gold1 255,215,0 #ffd700
221 lightgoldenrod2_1 255,215,95 #ffd75f
222 lightgoldenrod2_2 255,215,135 #ffd787
223 navajowhite1 255,215,175 #ffd7af
224 mistyrose1 255,215,215 #ffd7d7
225 thistle1 255,215,255 #ffd7ff
226 yellow1 255,255,0 #ffff00
227 lightgoldenrod1 255,255,95 #ffff5f
228 khaki1 255,255,135 #ffff87
229 wheat1 255,255,175 #ffffaf
230 cornsilk1 255,255,215 #ffffd7
231 grey100 255,255,255 #ffffff
232 grey3 8,8,8 #080808
233 grey7 18,18,18 #121212
234 grey11 28,28,28 #1c1c1c
235 grey15 38,38,38 #262626
236 grey19 48,48,48 #303030
237 grey23 58,58,58 #3a3a3a
238 grey27 68,68,68 #444444
239 grey30 78,78,78 #4e4e4e
240 grey35 88,88,88 #585858
241 grey39 98,98,98 #626262
242 grey42 108,108,108 #6c6c6c
243 grey46 118,118,118 #767676
244 grey50 128,128,128 #808080
245 grey54 138,138,138 #8a8a8a
246 grey58 148,148,148 #949494
247 grey62 158,158,158 #9e9e9e
248 grey66 168,168,168 #a8a8a8
249 grey70 178,178,178 #b2b2b2
250 grey74 188,188,188 #bcbcbc
251 grey78 198,198,198 #c6c6c6
252 grey82 208,208,208 #d0d0d0
253 grey85 218,218,218 #dadada
254 grey89 228,228,228 #e4e4e4
255 grey93 238,238,238 #eeeeee
Description
A .NET library that makes it easier to create beautiful console applications.
Readme 15 MiB
Languages
C# 99.9%
PowerShell 0.1%