jellyfin/MediaBrowser.Common/Logging/LogRow.cs
LukePulverenti Luke Pulverenti luke pulverenti a3f08b02ca Tweaked log output formatting
2012-08-22 16:07:16 -04:00

47 lines
1.2 KiB
C#

using System;
using System.Text;
using System.Collections.Generic;
using System.Linq;
namespace MediaBrowser.Common.Logging
{
public struct LogRow
{
const string TimePattern = "h:mm:ss.fff tt d/M/yyyy";
public LogSeverity Severity { get; set; }
public string Message { get; set; }
public int ThreadId { get; set; }
public string ThreadName { get; set; }
public DateTime Time { get; set; }
public override string ToString()
{
List<string> data = new List<string>();
data.Add(Time.ToString(TimePattern));
data.Add(Severity.ToString());
if (!string.IsNullOrEmpty(Message))
{
data.Add(Encode(Message));
}
data.Add(ThreadId.ToString());
if (!string.IsNullOrEmpty(ThreadName))
{
data.Add(Encode(ThreadName));
}
return string.Join(" , ", data.ToArray());
}
private string Encode(string str)
{
return (str ?? "").Replace(",", ",,").Replace(Environment.NewLine, " [n] ");
}
}
}