You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
using System; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; using System.Text;
namespace Newtonsoft.Json.Serialization { /// <summary>
/// Represents a trace writer that writes to memory. When the trace message limit is
/// reached then old trace messages will be removed as new messages are added.
/// </summary>
internal class MemoryTraceWriter : ITraceWriter { private readonly Queue<string> _traceMessages; private readonly object _lock;
/// <summary>
/// Gets the <see cref="TraceLevel"/> that will be used to filter the trace messages passed to the writer.
/// For example a filter level of <see cref="TraceLevel.Info"/> will exclude <see cref="TraceLevel.Verbose"/> messages and include <see cref="TraceLevel.Info"/>,
/// <see cref="TraceLevel.Warning"/> and <see cref="TraceLevel.Error"/> messages.
/// </summary>
/// <value>
/// The <see cref="TraceLevel"/> that will be used to filter the trace messages passed to the writer.
/// </value>
public TraceLevel LevelFilter { get; set; }
/// <summary>
/// Initializes a new instance of the <see cref="MemoryTraceWriter"/> class.
/// </summary>
public MemoryTraceWriter() { LevelFilter = TraceLevel.Verbose; _traceMessages = new Queue<string>(); _lock = new object(); }
/// <summary>
/// Writes the specified trace level, message and optional exception.
/// </summary>
/// <param name="level">The <see cref="TraceLevel"/> at which to write this trace.</param>
/// <param name="message">The trace message.</param>
/// <param name="ex">The trace exception. This parameter is optional.</param>
public void Trace(TraceLevel level, string message, Exception ex) { StringBuilder sb = new StringBuilder(); sb.Append(DateTime.Now.ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'.'fff", CultureInfo.InvariantCulture)); sb.Append(" "); sb.Append(level.ToString("g")); sb.Append(" "); sb.Append(message);
string s = sb.ToString();
lock (_lock) { if (_traceMessages.Count >= 1000) { _traceMessages.Dequeue(); }
_traceMessages.Enqueue(s); } }
/// <summary>
/// Returns an enumeration of the most recent trace messages.
/// </summary>
/// <returns>An enumeration of the most recent trace messages.</returns>
public IEnumerable<string> GetTraceMessages() { return _traceMessages; }
/// <summary>
/// Returns a <see cref="String"/> of the most recent trace messages.
/// </summary>
/// <returns>
/// A <see cref="String"/> of the most recent trace messages.
/// </returns>
public override string ToString() { lock (_lock) { StringBuilder sb = new StringBuilder(); foreach (string traceMessage in _traceMessages) { if (sb.Length > 0) { sb.AppendLine(); }
sb.Append(traceMessage); }
return sb.ToString(); } } } }
|