2024-08-14 14:13:00 +02:00
|
|
|
|
using CodexPlugin.OverwatchSupport;
|
|
|
|
|
using Logging;
|
2024-08-06 15:56:42 +02:00
|
|
|
|
using OverwatchTranscript;
|
|
|
|
|
using TranscriptAnalysis;
|
|
|
|
|
|
|
|
|
|
public static class Program
|
|
|
|
|
{
|
2024-08-07 11:18:40 +02:00
|
|
|
|
private static readonly ILog log = new ConsoleLog();
|
2024-08-06 15:56:42 +02:00
|
|
|
|
|
|
|
|
|
public static void Main(string[] args)
|
|
|
|
|
{
|
|
|
|
|
Log("Transcript Analysis");
|
2024-10-17 09:37:15 +02:00
|
|
|
|
if (!args.Any())
|
2024-10-14 09:11:29 +02:00
|
|
|
|
{
|
2024-10-17 09:37:15 +02:00
|
|
|
|
Log("Please pass a .owts file");
|
|
|
|
|
Console.ReadLine();
|
|
|
|
|
return;
|
2024-08-06 15:56:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-17 09:37:15 +02:00
|
|
|
|
if (!File.Exists(args[0]))
|
2024-08-06 15:56:42 +02:00
|
|
|
|
{
|
2024-10-17 09:37:15 +02:00
|
|
|
|
Log("File doesn't exist: " + args[0]);
|
|
|
|
|
Console.ReadLine();
|
|
|
|
|
return;
|
2024-10-14 09:11:29 +02:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-17 09:37:15 +02:00
|
|
|
|
var reader = OpenReader(args[0]);
|
|
|
|
|
AppDomain.CurrentDomain.ProcessExit += (e, s) =>
|
|
|
|
|
{
|
|
|
|
|
CloseReader(reader);
|
|
|
|
|
};
|
2024-08-06 15:56:42 +02:00
|
|
|
|
|
2024-08-14 14:13:00 +02:00
|
|
|
|
var header = reader.GetHeader<OverwatchCodexHeader>("cdx_h");
|
2024-10-17 09:37:15 +02:00
|
|
|
|
var receivers = new ReceiverSet(args[0], log, reader, header);
|
2024-08-07 11:18:40 +02:00
|
|
|
|
receivers.InitAll();
|
2024-08-06 15:56:42 +02:00
|
|
|
|
|
|
|
|
|
var processor = new Processor(log, reader);
|
|
|
|
|
processor.RunAll();
|
|
|
|
|
|
2024-08-07 11:18:40 +02:00
|
|
|
|
receivers.FinishAll();
|
2024-08-06 15:56:42 +02:00
|
|
|
|
|
|
|
|
|
CloseReader(reader);
|
2024-10-17 09:37:15 +02:00
|
|
|
|
Log("Done.");
|
|
|
|
|
Console.ReadLine();
|
2024-08-06 15:56:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static ITranscriptReader OpenReader(string filepath)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
Log($"Opening: '{filepath}'");
|
|
|
|
|
return Transcript.NewReader(filepath);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
Log("Failed to open file for reading: " + ex);
|
|
|
|
|
Console.ReadLine();
|
|
|
|
|
Environment.Exit(1);
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void CloseReader(ITranscriptReader reader)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
Log("Closing...");
|
|
|
|
|
reader.Close();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
Log("Failed to close reader: " + ex);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void Log(string msg)
|
|
|
|
|
{
|
|
|
|
|
log.Log(msg);
|
|
|
|
|
}
|
|
|
|
|
}
|