Enable nullable in ReactionPrototype & ReagentPrototype (#3005)
* Enable nullable in ReactionPrototype & ReagentPrototype * Remove unecessary sets * Fix updates branch * Review fixes Co-authored-by: py01 <pyronetics01@gmail.com>
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
#nullable enable
|
||||||
using Content.Shared.Chemistry;
|
using Content.Shared.Chemistry;
|
||||||
using Content.Shared.GameObjects.EntitySystems;
|
using Content.Shared.GameObjects.EntitySystems;
|
||||||
using Robust.Server.GameObjects.EntitySystems;
|
using Robust.Server.GameObjects.EntitySystems;
|
||||||
@@ -11,7 +12,8 @@ namespace Content.Server.GameObjects.EntitySystems.NewFolder
|
|||||||
{
|
{
|
||||||
base.OnReaction(reaction, owner, unitReactions);
|
base.OnReaction(reaction, owner, unitReactions);
|
||||||
|
|
||||||
Get<AudioSystem>().PlayAtCoords(reaction.Sound, owner.Transform.Coordinates);
|
if (reaction.Sound != null)
|
||||||
|
Get<AudioSystem>().PlayAtCoords(reaction.Sound, owner.Transform.Coordinates);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
#nullable enable
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Content.Server.Interfaces.Chemistry;
|
using Content.Server.Interfaces.Chemistry;
|
||||||
using Content.Shared.Interfaces;
|
using Content.Shared.Interfaces;
|
||||||
@@ -15,11 +16,11 @@ namespace Content.Shared.Chemistry
|
|||||||
[Prototype("reaction")]
|
[Prototype("reaction")]
|
||||||
public class ReactionPrototype : IPrototype, IIndexedPrototype
|
public class ReactionPrototype : IPrototype, IIndexedPrototype
|
||||||
{
|
{
|
||||||
private string _id;
|
private string _id = default!;
|
||||||
private string _name;
|
private string _name = default!;
|
||||||
private Dictionary<string, ReactantPrototype> _reactants;
|
private Dictionary<string, ReactantPrototype> _reactants = default!;
|
||||||
private Dictionary<string, ReagentUnit> _products;
|
private Dictionary<string, ReagentUnit> _products = default!;
|
||||||
private List<IReactionEffect> _effects;
|
private List<IReactionEffect> _effects = default!;
|
||||||
|
|
||||||
public string ID => _id;
|
public string ID => _id;
|
||||||
public string Name => _name;
|
public string Name => _name;
|
||||||
@@ -36,7 +37,7 @@ namespace Content.Shared.Chemistry
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public IReadOnlyList<IReactionEffect> Effects => _effects;
|
public IReadOnlyList<IReactionEffect> Effects => _effects;
|
||||||
|
|
||||||
public string Sound { get; private set; }
|
public string? Sound { get; private set; }
|
||||||
|
|
||||||
[Dependency] private readonly IModuleManager _moduleManager = default!;
|
[Dependency] private readonly IModuleManager _moduleManager = default!;
|
||||||
|
|
||||||
@@ -56,6 +57,10 @@ namespace Content.Shared.Chemistry
|
|||||||
//Some implementations of IReactionEffect can't currently be moved to shared, so this is here to prevent the client from breaking when reading server-only IReactionEffects.
|
//Some implementations of IReactionEffect can't currently be moved to shared, so this is here to prevent the client from breaking when reading server-only IReactionEffects.
|
||||||
serializer.DataField(ref _effects, "effects", new List<IReactionEffect>());
|
serializer.DataField(ref _effects, "effects", new List<IReactionEffect>());
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_effects = new(); //To ensure _effects isn't null since it is only serializable on the server right snow
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using System;
|
#nullable enable
|
||||||
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Content.Shared.Interfaces;
|
using Content.Shared.Interfaces;
|
||||||
using Content.Shared.Interfaces.Chemistry;
|
using Content.Shared.Interfaces.Chemistry;
|
||||||
@@ -18,16 +19,16 @@ namespace Content.Shared.Chemistry
|
|||||||
{
|
{
|
||||||
[Dependency] private readonly IModuleManager _moduleManager = default!;
|
[Dependency] private readonly IModuleManager _moduleManager = default!;
|
||||||
|
|
||||||
private string _id;
|
private string _id = default!;
|
||||||
private string _name;
|
private string _name = default!;
|
||||||
private string _description;
|
private string _description = default!;
|
||||||
private string _physicalDescription;
|
private string _physicalDescription = default!;
|
||||||
private Color _substanceColor;
|
private Color _substanceColor;
|
||||||
private string _spritePath;
|
private string _spritePath = default!;
|
||||||
private List<IMetabolizable> _metabolism;
|
private List<IMetabolizable> _metabolism = default!;
|
||||||
private List<ITileReaction> _tileReactions;
|
private List<ITileReaction> _tileReactions = default!;
|
||||||
private List<IPlantMetabolizable> _plantMetabolism;
|
private List<IPlantMetabolizable> _plantMetabolism = default!;
|
||||||
private float _customPlantMetabolism = 1f;
|
private float _customPlantMetabolism;
|
||||||
|
|
||||||
public string ID => _id;
|
public string ID => _id;
|
||||||
public string Name => _name;
|
public string Name => _name;
|
||||||
@@ -60,15 +61,17 @@ namespace Content.Shared.Chemistry
|
|||||||
|
|
||||||
if (_moduleManager.IsServerModule)
|
if (_moduleManager.IsServerModule)
|
||||||
{
|
{
|
||||||
|
//Implementations of the needed interfaces are currently server-only, so they cannot be read on client
|
||||||
serializer.DataField(ref _metabolism, "metabolism", new List<IMetabolizable> { new DefaultMetabolizable() });
|
serializer.DataField(ref _metabolism, "metabolism", new List<IMetabolizable> { new DefaultMetabolizable() });
|
||||||
serializer.DataField(ref _tileReactions, "tileReactions", new List<ITileReaction> { });
|
serializer.DataField(ref _tileReactions, "tileReactions", new List<ITileReaction> { });
|
||||||
serializer.DataField(ref _plantMetabolism, "plantMetabolism", new List<IPlantMetabolizable> { });
|
serializer.DataField(ref _plantMetabolism, "plantMetabolism", new List<IPlantMetabolizable> { });
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
//ensure the following fields cannot null since they can only be serialized on server right now
|
||||||
_metabolism = new List<IMetabolizable> { new DefaultMetabolizable() };
|
_metabolism = new List<IMetabolizable> { new DefaultMetabolizable() };
|
||||||
_tileReactions = new List<ITileReaction>(0);
|
_tileReactions = new();
|
||||||
_plantMetabolism = new List<IPlantMetabolizable>(0);
|
_plantMetabolism = new();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user