mirror of
				https://github.com/spectreconsole/spectre.console.git
				synced 2025-10-25 15:19:23 +00:00 
			
		
		
		
	* Adding a dark mode * Adding reference for types to summary pages * Adding API Reference * Adding modifiers to methods/fields/etc * Minimizing files input * Caching a lot of the output pages * Cache only for each execution * Adding API references to existing docs
		
			
				
	
	
		
			38 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Serilog.Core;
 | |
| using Serilog.Events;
 | |
| 
 | |
| namespace Logging.Infrastructure;
 | |
| 
 | |
| internal class LoggingEnricher : ILogEventEnricher
 | |
| {
 | |
|     private string _cachedLogFilePath;
 | |
|     private LogEventProperty _cachedLogFilePathProperty;
 | |
| 
 | |
|     // this path and level will be set by the LogInterceptor.cs after parsing the settings
 | |
|     public static string Path = string.Empty;
 | |
| 
 | |
|     public const string LogFilePathPropertyName = "LogFilePath";
 | |
| 
 | |
|     public void Enrich(LogEvent logEvent, ILogEventPropertyFactory propertyFactory)
 | |
|     {
 | |
|         // the settings might not have a path or we might not be within a command in which case
 | |
|         // we won't have the setting so a default value for the log file will be required
 | |
|         LogEventProperty logFilePathProperty;
 | |
| 
 | |
|         if (_cachedLogFilePathProperty != null && Path.Equals(_cachedLogFilePath))
 | |
|         {
 | |
|             // Path hasn't changed, so let's use the cached property
 | |
|             logFilePathProperty = _cachedLogFilePathProperty;
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             // We've got a new path for the log. Let's create a new property
 | |
|             // and cache it for future log events to use
 | |
|             _cachedLogFilePath = Path;
 | |
|             _cachedLogFilePathProperty = logFilePathProperty = propertyFactory.CreateProperty(LogFilePathPropertyName, Path);
 | |
|         }
 | |
| 
 | |
|         logEvent.AddPropertyIfAbsent(logFilePathProperty);
 | |
|     }
 | |
| }
 |