* Oh the possibilities * Merge fixes * Forgot to remote LavaSystem oops * Changed EntityEffectArgs to EntityEffectBaseArgs and EntityEffectReagentArgs * Throw exception for unimplemented effectargs * Remove Json and overrideable datafields * Fix test issues * Actually fix the compiling issue * Fix comments and remove EntityEffectArgs (no longer used, replaced with EntityEffectBaseArgs)
93 lines
3.8 KiB
C#
93 lines
3.8 KiB
C#
using Content.Shared.Body.Prototypes;
|
|
using Content.Shared.Chemistry.Reagent;
|
|
using Content.Shared.EntityEffects;
|
|
using Content.Shared.FixedPoint;
|
|
using JetBrains.Annotations;
|
|
using Robust.Shared.Prototypes;
|
|
using Robust.Shared.Serialization.TypeSerializers.Implementations.Custom.Prototype;
|
|
|
|
namespace Content.Server.EntityEffects.Effects
|
|
{
|
|
[UsedImplicitly]
|
|
public sealed partial class AdjustReagent : EntityEffect
|
|
{
|
|
/// <summary>
|
|
/// The reagent ID to remove. Only one of this and <see cref="Group"/> should be active.
|
|
/// </summary>
|
|
[DataField(customTypeSerializer: typeof(PrototypeIdSerializer<ReagentPrototype>))]
|
|
public string? Reagent = null;
|
|
// TODO use ReagentId
|
|
|
|
/// <summary>
|
|
/// The metabolism group to remove, if the reagent satisfies any.
|
|
/// Only one of this and <see cref="Reagent"/> should be active.
|
|
/// </summary>
|
|
[DataField(customTypeSerializer: typeof(PrototypeIdSerializer<MetabolismGroupPrototype>))]
|
|
public string? Group = null;
|
|
|
|
[DataField(required: true)]
|
|
public FixedPoint2 Amount = default!;
|
|
|
|
public override void Effect(EntityEffectBaseArgs args)
|
|
{
|
|
if (args is EntityEffectReagentArgs reagentArgs)
|
|
{
|
|
if (reagentArgs.Source == null)
|
|
return;
|
|
|
|
var amount = Amount;
|
|
amount *= reagentArgs.Scale;
|
|
|
|
if (Reagent != null)
|
|
{
|
|
if (amount < 0 && reagentArgs.Source.ContainsPrototype(Reagent))
|
|
reagentArgs.Source.RemoveReagent(Reagent, -amount);
|
|
if (amount > 0)
|
|
reagentArgs.Source.AddReagent(Reagent, amount);
|
|
}
|
|
else if (Group != null)
|
|
{
|
|
var prototypeMan = IoCManager.Resolve<IPrototypeManager>();
|
|
foreach (var quant in reagentArgs.Source.Contents.ToArray())
|
|
{
|
|
var proto = prototypeMan.Index<ReagentPrototype>(quant.Reagent.Prototype);
|
|
if (proto.Metabolisms != null && proto.Metabolisms.ContainsKey(Group))
|
|
{
|
|
if (amount < 0)
|
|
reagentArgs.Source.RemoveReagent(quant.Reagent, amount);
|
|
if (amount > 0)
|
|
reagentArgs.Source.AddReagent(quant.Reagent, amount);
|
|
}
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
|
|
// TODO: Someone needs to figure out how to do this for non-reagent effects.
|
|
throw new NotImplementedException();
|
|
}
|
|
|
|
protected override string? ReagentEffectGuidebookText(IPrototypeManager prototype, IEntitySystemManager entSys)
|
|
{
|
|
if (Reagent is not null && prototype.TryIndex(Reagent, out ReagentPrototype? reagentProto))
|
|
{
|
|
return Loc.GetString("reagent-effect-guidebook-adjust-reagent-reagent",
|
|
("chance", Probability),
|
|
("deltasign", MathF.Sign(Amount.Float())),
|
|
("reagent", reagentProto.LocalizedName),
|
|
("amount", MathF.Abs(Amount.Float())));
|
|
}
|
|
else if (Group is not null && prototype.TryIndex(Group, out MetabolismGroupPrototype? groupProto))
|
|
{
|
|
return Loc.GetString("reagent-effect-guidebook-adjust-reagent-group",
|
|
("chance", Probability),
|
|
("deltasign", MathF.Sign(Amount.Float())),
|
|
("group", groupProto.LocalizedName),
|
|
("amount", MathF.Abs(Amount.Float())));
|
|
}
|
|
|
|
throw new NotImplementedException();
|
|
}
|
|
}
|
|
}
|