Files
LuaCsForBarotraumaEP/Barotrauma/BarotraumaShared/SharedSource/LuaCs/LuaCsPerformanceCounter.cs
MapleWheels 6880e5e9ee [Milestone] AssemblyLoader completed.
Details:
- Assembly Mgmt Service for loading now a separate interface, not intended for normal use.
- Assembly Loader work; implemented custom dictionary key and table.
- Assembly loading work.
- EventService completed.
- Moved assembly extensions to ModUtils.cs
- Work to event service.
NetworkService work
- Added ImpromptuInterfaces package.
- Networking Service work to support NetVars
- Event Service
- Added assemblies references package for script compilation. Updated Roslyn version for compatibility.
- Package Loading work.
Swap Harmony to HarmonyX
- More refactor conversion to FluentResults.
- Updated StylesService to return Results.
- Refactor of PackageService partially complete.
- Made IService.Reset() required to return a Result.
- Moved plugin/assembly related code to their own folder (same namespace).
- Updated interfaces to reflect the use of Result<T>.
- Partial refactor, incomplete.
- Added 'FluentResults' so we can stop using cursed Exception-based flow control in loading code.
- Added 'OneOf' nuget package: https://github.com/mcintyre321/OneOf
for the implementation of the Optional<T> pattern and complex discrete return types instead of cursed enums (see current AssemblyManager.cs).
- Reapplied old branch changes.
2026-02-07 20:10:26 -05:00

82 lines
2.3 KiB
C#

using Barotrauma.LuaCs.Services;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
namespace Barotrauma
{
public interface IPerformanceData
{
public string Identifier { get; }
public long ElapsedTicks { get; }
}
public class SimplePerformanceData : IPerformanceData
{
public string Identifier { get; }
public long ElapsedTicks { get; }
public SimplePerformanceData(string identifier, long elapsedTicks)
{
Identifier = identifier;
ElapsedTicks = elapsedTicks;
}
}
public class PerformanceCounterService : IReusableService
{
public bool EnablePerformanceCounter { get; set; } = false;
private Dictionary<string, List<IPerformanceData>> _data = new Dictionary<string, List<IPerformanceData>>();
public void AddElapsedTicks(IPerformanceData data)
{
if (!EnablePerformanceCounter) { return; }
if (!_data.ContainsKey(data.Identifier))
{
_data.Add(data.Identifier, new List<IPerformanceData>());
}
_data[data.Identifier].Add(data);
Trim(data.Identifier, 100);
}
public T GetLatestSnapshot<T>(string identifier) where T : class, IPerformanceData
{
if (!_data.ContainsKey(identifier)) { return default; }
return (T)_data[identifier].Last();
}
public T[] GetSnapshot<T>(string identifier, int length) where T : class, IPerformanceData, new()
{
if (!_data.ContainsKey(identifier)) { return new T[] { }; }
length = Math.Min(length, _data[identifier].Count);
return _data[identifier].GetRange(_data[identifier].Count - length, length).Cast<T>().ToArray();
}
public void Trim(string identifier, int maxSize)
{
if (!_data.ContainsKey(identifier)) { return; }
if (_data[identifier].Count > maxSize)
{
_data[identifier].RemoveRange(0, _data[identifier].Count - maxSize);
}
}
public FluentResults.Result Reset()
{
_data = new Dictionary<string, List<IPerformanceData>>();
return FluentResults.Result.Ok();
}
public void Dispose() { }
}
}