using System.Linq; using Content.Shared.Dataset; using Robust.Shared.Random; namespace Content.Shared.Random.Helpers { public static class SharedRandomExtensions { public static string Pick(this IRobustRandom random, DatasetPrototype prototype) { return random.Pick(prototype.Values); } public static string Pick(this WeightedRandomPrototype prototype, IRobustRandom? random = null) { IoCManager.Resolve(ref random); var picks = prototype.Weights; var sum = picks.Values.Sum(); var accumulated = 0f; var rand = random.NextFloat() * sum; foreach (var (key, weight) in picks) { accumulated += weight; if (accumulated >= rand) { return key; } } // Shouldn't happen throw new InvalidOperationException($"Invalid weighted pick for {prototype.ID}!"); } } }