mirror of
				https://github.com/velopack/velopack.git
				synced 2025-10-25 15:19:22 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Text;
 | |
| using Velopack.Logging;
 | |
| 
 | |
| namespace CSharpAvalonia;
 | |
| 
 | |
| public class LogUpdatedEventArgs : EventArgs
 | |
| {
 | |
|     public string Text { get; set; }
 | |
| }
 | |
| 
 | |
| public class MemoryLogger : IVelopackLogger
 | |
| {
 | |
|     public event EventHandler<LogUpdatedEventArgs> LogUpdated;
 | |
|     private readonly StringBuilder _sb = new StringBuilder();
 | |
| 
 | |
|     public IDisposable BeginScope<TState>(TState state)
 | |
|     {
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     public override string ToString()
 | |
|     {
 | |
|         lock (_sb) {
 | |
|             return _sb.ToString();
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public void Log(VelopackLogLevel logLevel, string message, Exception exception)
 | |
|     {
 | |
|         if (logLevel < VelopackLogLevel.Information) return;
 | |
|         lock (_sb) {
 | |
|             message = $"{logLevel}: {message}";
 | |
|             if (exception != null) message += "\n" + exception.ToString();
 | |
|             Console.WriteLine("log: " + message);
 | |
|             _sb.AppendLine(message);
 | |
|             LogUpdated?.Invoke(this, new LogUpdatedEventArgs { Text = _sb.ToString() });
 | |
|         }
 | |
|     }
 | |
| } |