aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common/Logging/LogRow.cs
blob: 052f6062aaa40ca15ebe656e36eaefd0f996cf2d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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] ");
        }
    }
}