From 2b9b4c5f44072fd1f06b24e181be0d5d482b463e Mon Sep 17 00:00:00 2001 From: Victoria Plitt Date: Mon, 27 Jan 2020 16:56:22 +0200 Subject: Implement embedded logs in LogViewer Related Work Items: #2430 --- .../ApplicationLogViewerParser.cs | 50 ++++++++++++++++++++ .../LogViewerFileParser/EmbeddedLogViewerParser.cs | 55 ++++++++++++++++++++++ .../LogViewerFileParser/ILogViewerParser.cs | 14 ++++++ 3 files changed, 119 insertions(+) create mode 100644 Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ApplicationLogViewerParser.cs create mode 100644 Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/EmbeddedLogViewerParser.cs create mode 100644 Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ILogViewerParser.cs (limited to 'Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser') diff --git a/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ApplicationLogViewerParser.cs b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ApplicationLogViewerParser.cs new file mode 100644 index 000000000..93d856b2e --- /dev/null +++ b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ApplicationLogViewerParser.cs @@ -0,0 +1,50 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using Tango.Logging; +using System.Text.RegularExpressions; +using System.IO; +using System.Globalization; + +namespace Tango.LogViewer.UI.LogViewerFileParser +{ + public class ApplicationLogViewerParser : ILogViewerParser + { + public ApplicationLogViewerParser() + { + + } + public void Parse(string file, DateTime datetime, ref List logItems) + { + String text = File.ReadAllText(file); + var logs = Regex.Split(text, @"(\[\d{2}:\d{2}:\d{2}.\d{2}\])"); + + for (int i = 1; i < logs.Length; i += 2) + { + try + { + DateTime date = DateTime.ParseExact(logs[i].Replace("[", "").Replace("]", ""), "HH:mm:ss.ff", CultureInfo.InvariantCulture); + String rest = logs[i + 1]; + + var entries = Regex.Split(rest, @"\[(.*?)\]"); + + MessageLogItem item = new MessageLogItem(); + item.TimeStamp = new DateTime(datetime.Year, datetime.Month, datetime.Day, date.Hour, date.Minute, date.Second, date.Millisecond); + item.Category = (LogCategory)Enum.Parse(typeof(LogCategory), entries[1]); + item.CallerFile = entries[3]; + item.CallerMethodName = entries[5]; + item.CallerLineNumber = int.Parse(entries[7]); + item.Message = new String(entries[8].Skip(2).ToArray()); + + logItems.Add(item); + } + catch (Exception ex) + { + //LogManager.Default.Log(ex, "Could not parse log line: " + logs[i]); + } + } + } + } +} diff --git a/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/EmbeddedLogViewerParser.cs b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/EmbeddedLogViewerParser.cs new file mode 100644 index 000000000..1d0028f10 --- /dev/null +++ b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/EmbeddedLogViewerParser.cs @@ -0,0 +1,55 @@ +using System; +using System.Collections.Generic; +using System.Globalization; +using System.IO; +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; +using System.Threading.Tasks; +using Tango.Integration.Logging; +using Tango.Logging; + +namespace Tango.LogViewer.UI.LogViewerFileParser +{ + public class EmbeddedLogViewerParser : ILogViewerParser + { + public EmbeddedLogViewerParser() + { + + + } + public void Parse(string file, DateTime datetime, ref List logItems) + { + String text = File.ReadAllText(file); + var logs = Regex.Split(text, @"(\[\d{2}:\d{2}:\d{2}.\d{2}\])"); + + for (int i = 1; i < logs.Length; i += 2) + { + try + { + DateTime date = DateTime.ParseExact(logs[i].Replace("[", "").Replace("]", ""), "HH:mm:ss.ff", CultureInfo.InvariantCulture); + String rest = logs[i + 1]; + + var entries = Regex.Split(rest, @"\[(.*?)\]"); + + LogItemBase item = new EmbeddedLogItem(new PMR.Debugging.StartDebugLogResponse() + { + Category = (PMR.Debugging.DebugLogCategory)Enum.Parse(typeof(PMR.Debugging.DebugLogCategory), entries[1]), + FileName = entries[3], + LineNumber = uint.Parse(entries[5]), + ModuleId = uint.Parse(entries[7]), + Filter = uint.Parse(entries[9]), + Message = new String(entries[10].Skip(2).ToArray()) + }); + item.TimeStamp = new DateTime(datetime.Year, datetime.Month, datetime.Day, date.Hour, date.Minute, date.Second, date.Millisecond); + + logItems.Add(item); + } + catch (Exception ex) + { + //LogManager.Default.Log(ex, "Could not parse log line: " + logs[i]); + } + } + } + } +} diff --git a/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ILogViewerParser.cs b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ILogViewerParser.cs new file mode 100644 index 000000000..a0088a770 --- /dev/null +++ b/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerFileParser/ILogViewerParser.cs @@ -0,0 +1,14 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using Tango.Logging; + +namespace Tango.LogViewer.UI.LogViewerFileParser +{ + public interface ILogViewerParser + { + void Parse(string file, DateTime datetime, ref List logItems); + } +} -- cgit v1.3.1