mirror of
				https://github.com/spectreconsole/spectre.console.git
				synced 2025-10-25 15:19:23 +00:00 
			
		
		
		
	- ExceptionFormat -> ExceptionFormats. - Fix link to documentation. - Add cross reference to Styles. - Render table in example code. - Add code for setting background color.
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| Title: Exceptions
 | |
| Order: 3
 | |
| ---
 | |
| 
 | |
| Exceptions isn't always readable when viewed in the terminal.  
 | |
| You can make exception a bit more readable by using the `WriteException` method.
 | |
| 
 | |
| ```csharp
 | |
| AnsiConsole.WriteException(ex);
 | |
| ```
 | |
| 
 | |
| <img src="assets/images/exception.png" style="max-width: 100%;">
 | |
| 
 | |
| ## Shortening parts
 | |
| 
 | |
| You can also shorten specific parts of the exception to make it even
 | |
| more readable, and make paths clickable hyperlinks. Whether or not
 | |
| the hyperlinks are clickable is up to the terminal. 
 | |
| 
 | |
| ```csharp
 | |
| AnsiConsole.WriteException(ex, 
 | |
|     ExceptionFormats.ShortenPaths | ExceptionFormats.ShortenTypes |
 | |
|     ExceptionFormats.ShortenMethods | ExceptionFormats.ShowLinks);
 | |
| ```
 | |
| 
 | |
| <img src="assets/images/compact_exception.png" style="max-width: 100%;">
 | |
| 
 | |
| ## Customizing exception output
 | |
| 
 | |
| In addition to shorten specific part of the exception, you can 
 | |
| also override the default styling.
 | |
| 
 | |
| ```csharp
 | |
| AnsiConsole.WriteException(ex, new ExceptionSettings
 | |
| {
 | |
|     Format = ExceptionFormats.ShortenEverything | ExceptionFormats.ShowLinks,
 | |
|     Style = new ExceptionStyle
 | |
|     {
 | |
|         Exception = new Style().Foreground(Color.Grey),
 | |
|         Message = new Style().Foreground(Color.White),
 | |
|         NonEmphasized = new Style().Foreground(Color.Cornsilk1),
 | |
|         Parenthesis = new Style().Foreground(Color.Cornsilk1),
 | |
|         Method = new Style().Foreground(Color.Red),
 | |
|         ParameterName = new Style().Foreground(Color.Cornsilk1),
 | |
|         ParameterType = new Style().Foreground(Color.Red),
 | |
|         Path = new Style().Foreground(Color.Red),
 | |
|         LineNumber = new Style().Foreground(Color.Cornsilk1),
 | |
|     }
 | |
| });
 | |
| ```
 | |
| 
 | |
| <img src="assets/images/custom_exception.png" style="max-width: 100%;">
 |