private void OnPolymorphActionEvent(Entity<PolymorphableComponent> ent, ref PolymorphActionEvent args)
{
- PolymorphEntity(ent, args.Prototype.Configuration);
+ if (!_proto.TryIndex(args.ProtoId, out var prototype))
+ return;
+
+ PolymorphEntity(ent, prototype.Configuration);
}
private void OnRevertPolymorphActionEvent(Entity<PolymorphedEntityComponent> ent,
if (target.Comp.PolymorphActions.ContainsKey(id))
return;
- var polyProto = _proto.Index(id);
+ if (!_proto.TryIndex(id, out var polyProto))
+ return;
+
var entProto = _proto.Index(polyProto.Configuration.Entity);
EntityUid? actionId = default!;
baseAction.Icon = new SpriteSpecifier.EntityPrototype(polyProto.Configuration.Entity);
if (baseAction is InstantActionComponent action)
- action.Event = new PolymorphActionEvent(prototype: polyProto);
+ action.Event = new PolymorphActionEvent(id);
}
public void RemovePolymorphAction(ProtoId<PolymorphPrototype> id, Entity<PolymorphableComponent> target)
using Content.Server.Polymorph.Systems;
using Content.Shared.Administration;
using Content.Shared.Polymorph;
+using Robust.Shared.Prototypes;
using Robust.Shared.Toolshed;
-using Robust.Shared.Toolshed.TypeParsers;
namespace Content.Server.Polymorph.Toolshed;
public sealed class PolymorphCommand : ToolshedCommand
{
private PolymorphSystem? _system;
+ [Dependency] private IPrototypeManager _proto = default!;
[CommandImplementation]
public EntityUid? Polymorph(
[PipedArgument] EntityUid input,
- [CommandArgument] Prototype<PolymorphPrototype> prototype
+ [CommandArgument] ProtoId<PolymorphPrototype> protoId
)
{
_system ??= GetSys<PolymorphSystem>();
- return _system.PolymorphEntity(input, prototype.Value.Configuration);
+ if (!_proto.TryIndex(protoId, out var prototype))
+ return null;
+
+ return _system.PolymorphEntity(input, prototype.Configuration);
}
[CommandImplementation]
public IEnumerable<EntityUid> Polymorph(
[PipedArgument] IEnumerable<EntityUid> input,
- [CommandArgument] Prototype<PolymorphPrototype> prototype
+ [CommandArgument] ProtoId<PolymorphPrototype> protoId
)
- => input.Select(x => Polymorph(x, prototype)).Where(x => x is not null).Select(x => (EntityUid)x!);
+ => input.Select(x => Polymorph(x, protoId)).Where(x => x is not null).Select(x => (EntityUid)x!);
}
using Content.Shared.Actions;
+using Robust.Shared.Prototypes;
namespace Content.Shared.Polymorph;
public sealed partial class PolymorphActionEvent : InstantActionEvent
{
/// <summary>
- /// The polymorph prototype containing all the information about
- /// the specific polymorph.
+ /// The polymorph proto id, containing all the information about
+ /// the specific polymorph.
/// </summary>
- public PolymorphPrototype Prototype = default!;
+ [DataField]
+ public ProtoId<PolymorphPrototype>? ProtoId;
- public PolymorphActionEvent(PolymorphPrototype prototype) : this()
+ public PolymorphActionEvent(ProtoId<PolymorphPrototype> protoId) : this()
{
- Prototype = prototype;
+ ProtoId = protoId;
}
}