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;
}
}
}
|