LethalCompany/Lethal Company/ExportedProject/Assets/Scripts/Assembly-CSharp/DunGen/GenerationStats.cs

113 lines
2.7 KiB
C#
Raw Normal View History

2023-12-22 22:51:17 +00:00
using System.Diagnostics;
namespace DunGen
{
public sealed class GenerationStats
{
private Stopwatch stopwatch = new Stopwatch();
private GenerationStatus generationStatus;
public int MainPathRoomCount { get; private set; }
public int BranchPathRoomCount { get; private set; }
public int TotalRoomCount { get; private set; }
public int MaxBranchDepth { get; private set; }
public int TotalRetries { get; private set; }
public int PrunedBranchTileCount { get; internal set; }
public float PreProcessTime { get; private set; }
public float MainPathGenerationTime { get; private set; }
public float BranchPathGenerationTime { get; private set; }
public float PostProcessTime { get; private set; }
public float TotalTime { get; private set; }
internal void Clear()
{
MainPathRoomCount = 0;
BranchPathRoomCount = 0;
TotalRoomCount = 0;
MaxBranchDepth = 0;
TotalRetries = 0;
PrunedBranchTileCount = 0;
PreProcessTime = 0f;
MainPathGenerationTime = 0f;
BranchPathGenerationTime = 0f;
PostProcessTime = 0f;
TotalTime = 0f;
}
internal void IncrementRetryCount()
{
TotalRetries++;
}
internal void SetRoomStatistics(int mainPathRoomCount, int branchPathRoomCount, int maxBranchDepth)
{
MainPathRoomCount = mainPathRoomCount;
BranchPathRoomCount = branchPathRoomCount;
MaxBranchDepth = maxBranchDepth;
TotalRoomCount = MainPathRoomCount + BranchPathRoomCount;
}
internal void BeginTime(GenerationStatus status)
{
if (stopwatch.IsRunning)
{
EndTime();
}
generationStatus = status;
stopwatch.Reset();
stopwatch.Start();
}
internal void EndTime()
{
stopwatch.Stop();
float num = (float)stopwatch.Elapsed.TotalMilliseconds;
switch (generationStatus)
{
case GenerationStatus.PreProcessing:
PreProcessTime += num;
break;
case GenerationStatus.MainPath:
MainPathGenerationTime += num;
break;
case GenerationStatus.Branching:
BranchPathGenerationTime += num;
break;
case GenerationStatus.PostProcessing:
PostProcessTime += num;
break;
}
TotalTime = PreProcessTime + MainPathGenerationTime + BranchPathGenerationTime + PostProcessTime;
}
public GenerationStats Clone()
{
return new GenerationStats
{
MainPathRoomCount = MainPathRoomCount,
BranchPathRoomCount = BranchPathRoomCount,
TotalRoomCount = TotalRoomCount,
MaxBranchDepth = MaxBranchDepth,
TotalRetries = TotalRetries,
PrunedBranchTileCount = PrunedBranchTileCount,
PreProcessTime = PreProcessTime,
MainPathGenerationTime = MainPathGenerationTime,
BranchPathGenerationTime = BranchPathGenerationTime,
PostProcessTime = PostProcessTime,
TotalTime = TotalTime
};
}
}
}