aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Utilities/Tango.LogViewer.UI/LogViewerManager.cs
blob: 3615eb50a7cd3979e1fd7d62871ca642368038f2 (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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.Logging;
using Tango.LogViewer.UI.LogViewerFileParser;

namespace Tango.LogViewer.UI
{
    public class LogViewerManager
    {
        private ILogViewerParser _parser;

        public LogFile LogFile { get; set; }

        public string FileName { get; set; }

        public bool IsEmbeddedLog { get; set; }

        public int CountOfSet { get; set; }

        public LogViewerManager()
        {
            LogFile = null; ;
        }

        /// <summary>
        /// Create LogFile by given path.
        /// </summary>
        /// <param name="file">The file.</param>
        public void InitLogFile(String file)
        {
            LogFile = GetLogFile(file);
        }

        /// <summary>
        /// Gets set of log files by path.
        /// </summary>
        public LogFile GetLogFile(string filePath)
        {
            if (!File.Exists(filePath))
            {
                throw new IOException("File not found.");
            }
            if (Path.GetExtension(filePath) != ".log")
            {
                throw new IOException("Invalid log file extension. extension must be *.log");
            }

            var directoryName = Path.GetDirectoryName(filePath);
            var logfileName = Path.GetFileNameWithoutExtension(filePath);
            String fileName = logfileName;
            int index = logfileName.IndexOf("-");
            if (index >= 0)
            {
                fileName = logfileName.Substring(0, index);
            }
            int indexPos = logfileName.IndexOf(FileLogger.FILE_SET_EXTENSION);
            if (indexPos > 0)
            {
                logfileName = logfileName.Substring(0, indexPos);
            }

            String dateString = System.IO.Path.GetFileNameWithoutExtension(filePath).Replace($"{fileName}-", "").Replace("_session", "");
            indexPos = dateString.IndexOf(FileLogger.FILE_SET_EXTENSION);
            int indexOfFile = 0;
            CountOfSet = 0;
            if (indexPos > 0)
            {
                string fileNameIndex = dateString.Substring(indexPos + FileLogger.FILE_SET_EXTENSION.Length);
                string[] fileEntries = Directory.GetFiles(directoryName, $"{logfileName}*{Path.GetExtension(filePath)}").Where(x => Path.GetFileName(x).StartsWith(logfileName)).OrderBy(x => x).ToArray();
                CountOfSet = fileEntries.Length;
                int.TryParse(fileNameIndex, out indexOfFile);
                dateString = dateString.Substring(0, indexPos);
            }
            DateTime date = DateTime.ParseExact(dateString, "dd-MM-yyyy_HH-mm-ss", CultureInfo.InvariantCulture);
            return (new LogFile() { DateTime = date, File = filePath, FileName = logfileName, PartOfSet = indexOfFile > 0, SetStartIndex = indexOfFile, SetCount = CountOfSet });
        }

        /// <summary>
        /// Parses the this LogFile.
        /// </summary>
        public List<LogItemBase> Parse()
        {
            IsEmbeddedLog = false;
            FileName = "";
            List<LogItemBase> logItems = new List<LogItemBase>();
            if (LogFile == null)
                return logItems;

            FileName = LogFile.FileName;

            IsEmbeddedLog = FileName.StartsWith("Embedded");
            if (IsEmbeddedLog)
            {
                _parser = new EmbeddedLogViewerParser();
            }
            else
            {
                _parser = new ApplicationLogViewerParser();
            }

            if (LogFile.PartOfSet)
            {
                string extension = Path.GetExtension(LogFile.File);
                var directoryName = Path.GetDirectoryName(LogFile.File);

                string[] fileEntries = Directory.GetFiles(directoryName, $"{FileName}*{extension}").Where(x => Path.GetFileName(x).StartsWith(FileName)).OrderBy(x => x).ToArray();

                foreach (var file in fileEntries)
                {
                    _parser.Parse(file, LogFile.DateTime, ref logItems);
                }
            }
            else
            {
                _parser.Parse(LogFile.File, LogFile.DateTime, ref logItems);
            }

            return logItems;
        }
    }
}