mirror of
https://github.com/rmroc451/TweaksAndThings.git
synced 2025-12-17 09:49:39 -06:00
111 lines
4.9 KiB
C#
111 lines
4.9 KiB
C#
using Model.AI;
|
|
using System.Collections;
|
|
using UnityEngine;
|
|
|
|
namespace RMROC451.TweaksAndThings.Extensions
|
|
{
|
|
internal static class AutoEngineer_Extensions
|
|
{
|
|
private static float CabooseHalvedFloat(this float input, bool hasCaboose) =>
|
|
hasCaboose ? input / 2 : input;
|
|
|
|
private static float CabooseAutoOilerLimit(this bool hasCaboose) =>
|
|
hasCaboose ? 0.99f : AutoOiler.OilIfBelow;
|
|
|
|
public static IEnumerator MrocAutoOilerLoop(this AutoOiler oiler, Serilog.ILogger _log, bool cabooseRequired)
|
|
{
|
|
int originIndex = oiler.FindOriginIndex();
|
|
bool hasCaboose = oiler._cars.CabooseInConsist();
|
|
if (originIndex < 0)
|
|
{
|
|
_log.Error("Couldn't find origin car {car}", oiler._originCar);
|
|
oiler._coroutine = null;
|
|
yield break;
|
|
} else if (CabooseRequirementChecker(string.Format("{0} {1}", oiler.GetType().Name, oiler.name), cabooseRequired, hasCaboose, _log))
|
|
{
|
|
yield break;
|
|
}
|
|
oiler._reverse = originIndex > oiler._cars.Count - originIndex;
|
|
_log.Information(
|
|
"AutoOiler {name} starting, rev = {reverse}, caboose required = {req}, caboose halving adjustment = {hasCaboose}, oil limit = {limit}",
|
|
oiler.name,
|
|
oiler._reverse,
|
|
cabooseRequired,
|
|
hasCaboose,
|
|
hasCaboose.CabooseAutoOilerLimit()
|
|
);
|
|
while (true)
|
|
{
|
|
yield return new WaitForSeconds(AutoOiler.StartDelay.CabooseHalvedFloat(hasCaboose));
|
|
int carIndex = originIndex;
|
|
float adjustedTimeToWalk = AutoOiler.TimeToWalkCar.CabooseHalvedFloat(hasCaboose);
|
|
do
|
|
{
|
|
if (oiler.TryGetCar(carIndex, out var car))
|
|
{
|
|
float num = 0f;
|
|
float origOil = car.Oiled;
|
|
if (car.NeedsOiling && car.Oiled < hasCaboose.CabooseAutoOilerLimit())
|
|
{
|
|
float num2 = 1f - car.Oiled;
|
|
car.OffsetOiled(num2);
|
|
float num3 = num2 * AutoOiler.TimeToFullyOil.CabooseHalvedFloat(hasCaboose);
|
|
num += num3;
|
|
oiler._pendingRunDuration += num3;
|
|
oiler._oiledCount++;
|
|
_log.Information("AutoOiler {name}: oiled {car} from {orig} => {new}", oiler.name, car, origOil, car.Oiled);
|
|
}
|
|
num += adjustedTimeToWalk;
|
|
oiler._pendingRunDuration += adjustedTimeToWalk;
|
|
yield return new WaitForSeconds(num);
|
|
}
|
|
carIndex = oiler.NextIndex(carIndex);
|
|
}
|
|
while (oiler.InBounds(carIndex));
|
|
oiler._reverse = !oiler._reverse;
|
|
oiler.PayWages();
|
|
}
|
|
}
|
|
|
|
public static IEnumerator MrocAutoHotboxSpotterLoop(this AutoHotboxSpotter spotter, Serilog.ILogger _log, bool cabooseRequired)
|
|
{
|
|
while (true)
|
|
{
|
|
bool hasCaboose = spotter._cars.CabooseInConsist();
|
|
if (!spotter.HasCars)
|
|
{
|
|
yield return new WaitForSeconds(1f);
|
|
continue;
|
|
}
|
|
_log.Information("AutoHotboxSpotter {name}: Hotbox Spotter Running, Has Caboose => {hasCaboose}; Has Cars {hasCars}; Requires Caboose {requiresCaboose}", spotter.name, hasCaboose, spotter.HasCars, cabooseRequired);
|
|
if (CabooseRequirementChecker(string.Format("{0} {1}", spotter.GetType().Name, spotter.name), cabooseRequired, hasCaboose, _log))
|
|
{
|
|
yield break;
|
|
}
|
|
spotter.CheckForHotbox();
|
|
while (spotter.HasCars)
|
|
{
|
|
int num = Random.Range(60, 300);
|
|
if (hasCaboose)
|
|
{
|
|
var numOrig = num;
|
|
num = Random.Range(15, 30);
|
|
_log.Information("AutoHotboxSpotter {name}: Next check went from num(60,300) => {numOrig}; to num(15,30) => {hasCaboose}; Requires Caboose {requiresCaboose}", spotter.name, numOrig, num, hasCaboose, cabooseRequired);
|
|
}
|
|
yield return new WaitForSeconds(num);
|
|
spotter.CheckForHotbox();
|
|
}
|
|
}
|
|
}
|
|
|
|
private static bool CabooseRequirementChecker(string name, bool cabooseRequired, bool hasCaboose, Serilog.ILogger _log)
|
|
{
|
|
bool error = cabooseRequired && !hasCaboose;
|
|
if (error) {
|
|
_log.Debug("{name}: Couldn't find required caboose!", name);
|
|
}
|
|
return error;
|
|
}
|
|
}
|
|
}
|