* Add nullable to some Content.Shared files. * Use [NotNullWhen(true)] * Undo adding now redundant !'s * Forgot one * Add a ton more nullable * You can guess * Fix some issues * It actually compiles now * Auto stash before merge of "null2" and "origin/master" * I lied * enable annotations -> enable * Revert ActionBlockerSystem.cs to original * Fix ActionBlockerSystem.cs * More nullable * Undo some added exclamation marks * Fix issues * Update Content.Shared/Maps/ContentTileDefinition.cs Co-authored-by: metalgearsloth <31366439+metalgearsloth@users.noreply.github.com> * Resolve some issues * Remove unused method * Fix more issues * Fix more issues * Fix more issues * Fix more issues * Fix issue, rollback SharedGhostComponent.cs * Update submodule * Fix issue, invert some if-statements to reduce nesting * Revert RobustToolbox * FIx things broken by merge * Some fixes - Replaced with string.Empty - Remove some exclamation marks - Revert file * Some fixes * Trivial #nullable enable * Fix null ables Co-authored-by: metalgearsloth <31366439+metalgearsloth@users.noreply.github.com> Co-authored-by: Metal Gear Sloth <metalgearsloth@gmail.com>
88 lines
2.8 KiB
C#
88 lines
2.8 KiB
C#
#nullable enable
|
|
using System.Collections.Generic;
|
|
using Robust.Shared.Prototypes;
|
|
using Robust.Shared.Serialization;
|
|
using Robust.Shared.Utility;
|
|
using YamlDotNet.RepresentationModel;
|
|
|
|
namespace Content.Shared.Alert
|
|
{
|
|
/// <summary>
|
|
/// Defines the order of alerts so they show up in a consistent order.
|
|
/// </summary>
|
|
[Prototype("alertOrder")]
|
|
public class AlertOrderPrototype : IPrototype, IComparer<AlertPrototype>
|
|
{
|
|
public string ID { get; private set; } = string.Empty;
|
|
|
|
private readonly Dictionary<AlertType, int> _typeToIdx = new();
|
|
private readonly Dictionary<AlertCategory, int> _categoryToIdx = new();
|
|
|
|
public void LoadFrom(YamlMappingNode mapping)
|
|
{
|
|
var serializer = YamlObjectSerializer.NewReader(mapping);
|
|
|
|
serializer.DataField(this, x => x.ID, "id", string.Empty);
|
|
|
|
if (!mapping.TryGetNode("order", out YamlSequenceNode? orderMapping)) return;
|
|
|
|
var i = 0;
|
|
foreach (var entryYaml in orderMapping)
|
|
{
|
|
var orderEntry = (YamlMappingNode) entryYaml;
|
|
var orderSerializer = YamlObjectSerializer.NewReader(orderEntry);
|
|
if (orderSerializer.TryReadDataField("category", out AlertCategory alertCategory))
|
|
{
|
|
_categoryToIdx[alertCategory] = i++;
|
|
}
|
|
else if (orderSerializer.TryReadDataField("alertType", out AlertType alertType))
|
|
{
|
|
_typeToIdx[alertType] = i++;
|
|
}
|
|
}
|
|
}
|
|
|
|
private int GetOrderIndex(AlertPrototype alert)
|
|
{
|
|
if (_typeToIdx.TryGetValue(alert.AlertType, out var idx))
|
|
{
|
|
return idx;
|
|
}
|
|
if (alert.Category != null &&
|
|
_categoryToIdx.TryGetValue((AlertCategory) alert.Category, out idx))
|
|
{
|
|
return idx;
|
|
}
|
|
|
|
return -1;
|
|
}
|
|
|
|
public int Compare(AlertPrototype? x, AlertPrototype? y)
|
|
{
|
|
if ((x == null) && (y == null)) return 0;
|
|
if (x == null) return 1;
|
|
if (y == null) return -1;
|
|
var idx = GetOrderIndex(x);
|
|
var idy = GetOrderIndex(y);
|
|
if (idx == -1 && idy == -1)
|
|
{
|
|
// break ties by type value
|
|
return x.AlertType - y.AlertType;
|
|
}
|
|
|
|
if (idx == -1) return 1;
|
|
if (idy == -1) return -1;
|
|
var result = idx - idy;
|
|
// not strictly necessary (we don't care about ones that go at the same index)
|
|
// but it makes the sort stable
|
|
if (result == 0)
|
|
{
|
|
// break ties by type value
|
|
return x.AlertType - y.AlertType;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
}
|
|
}
|