Organ fixes (#20488)
This commit is contained in:
@@ -19,25 +19,10 @@ namespace Content.Server.Body.Systems
|
|||||||
{
|
{
|
||||||
base.Initialize();
|
base.Initialize();
|
||||||
|
|
||||||
SubscribeLocalEvent<BrainComponent, AddedToBodyEvent>((uid, _, args) => HandleMind(args.Body, uid));
|
|
||||||
SubscribeLocalEvent<BrainComponent, AddedToPartEvent>((uid, _, args) => HandleMind(args.Part, uid));
|
|
||||||
SubscribeLocalEvent<BrainComponent, AddedToPartInBodyEvent>((uid, _, args) => HandleMind(args.Body, uid));
|
SubscribeLocalEvent<BrainComponent, AddedToPartInBodyEvent>((uid, _, args) => HandleMind(args.Body, uid));
|
||||||
SubscribeLocalEvent<BrainComponent, RemovedFromBodyEvent>(OnRemovedFromBody);
|
|
||||||
SubscribeLocalEvent<BrainComponent, RemovedFromPartEvent>((uid, _, args) => HandleMind(uid, args.Old));
|
|
||||||
SubscribeLocalEvent<BrainComponent, RemovedFromPartInBodyEvent>((uid, _, args) => HandleMind(args.OldBody, uid));
|
SubscribeLocalEvent<BrainComponent, RemovedFromPartInBodyEvent>((uid, _, args) => HandleMind(args.OldBody, uid));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnRemovedFromBody(EntityUid uid, BrainComponent component, RemovedFromBodyEvent args)
|
|
||||||
{
|
|
||||||
// This one needs to be special, okay?
|
|
||||||
if (!EntityManager.TryGetComponent(uid, out OrganComponent? organ))
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
HandleMind(uid, args.Old);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void HandleMind(EntityUid newEntity, EntityUid oldEntity)
|
private void HandleMind(EntityUid newEntity, EntityUid oldEntity)
|
||||||
{
|
{
|
||||||
EnsureComp<MindContainerComponent>(newEntity);
|
EnsureComp<MindContainerComponent>(newEntity);
|
||||||
|
|||||||
@@ -3,19 +3,6 @@
|
|||||||
// All of these events are raised on a mechanism entity when added/removed to a body in different
|
// All of these events are raised on a mechanism entity when added/removed to a body in different
|
||||||
// ways.
|
// ways.
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Raised on a mechanism when it is added to a body.
|
|
||||||
/// </summary>
|
|
||||||
public sealed class AddedToBodyEvent : EntityEventArgs
|
|
||||||
{
|
|
||||||
public EntityUid Body;
|
|
||||||
|
|
||||||
public AddedToBodyEvent(EntityUid body)
|
|
||||||
{
|
|
||||||
Body = body;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Raised on a mechanism when it is added to a body part.
|
/// Raised on a mechanism when it is added to a body part.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -44,29 +31,16 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Raised on a mechanism when it is removed from a body.
|
|
||||||
/// </summary>
|
|
||||||
public sealed class RemovedFromBodyEvent : EntityEventArgs
|
|
||||||
{
|
|
||||||
public EntityUid Old;
|
|
||||||
|
|
||||||
public RemovedFromBodyEvent(EntityUid old)
|
|
||||||
{
|
|
||||||
Old = old;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Raised on a mechanism when it is removed from a body part.
|
/// Raised on a mechanism when it is removed from a body part.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class RemovedFromPartEvent : EntityEventArgs
|
public sealed class RemovedFromPartEvent : EntityEventArgs
|
||||||
{
|
{
|
||||||
public EntityUid Old;
|
public EntityUid OldPart;
|
||||||
|
|
||||||
public RemovedFromPartEvent(EntityUid old)
|
public RemovedFromPartEvent(EntityUid oldPart)
|
||||||
{
|
{
|
||||||
Old = old;
|
OldPart = oldPart;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ public partial class SharedBodySystem
|
|||||||
|
|
||||||
if (TryComp(entity, out OrganComponent? organ))
|
if (TryComp(entity, out OrganComponent? organ))
|
||||||
{
|
{
|
||||||
RemoveOrgan(entity, uid, uid, organ);
|
RemoveOrgan(entity, uid, organ);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ public partial class SharedBodySystem
|
|||||||
private void AddOrgan(EntityUid uid, EntityUid bodyUid, EntityUid parentPartUid, OrganComponent component)
|
private void AddOrgan(EntityUid uid, EntityUid bodyUid, EntityUid parentPartUid, OrganComponent component)
|
||||||
{
|
{
|
||||||
component.Body = bodyUid;
|
component.Body = bodyUid;
|
||||||
RaiseLocalEvent(uid, new AddedToPartEvent(bodyUid));
|
RaiseLocalEvent(uid, new AddedToPartEvent(parentPartUid));
|
||||||
|
|
||||||
if (component.Body != null)
|
if (component.Body != null)
|
||||||
RaiseLocalEvent(uid, new AddedToPartInBodyEvent(component.Body.Value, parentPartUid));
|
RaiseLocalEvent(uid, new AddedToPartInBodyEvent(component.Body.Value, parentPartUid));
|
||||||
@@ -20,12 +20,14 @@ public partial class SharedBodySystem
|
|||||||
Dirty(uid, component);
|
Dirty(uid, component);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RemoveOrgan(EntityUid uid, EntityUid bodyUid, EntityUid parentPartUid, OrganComponent component)
|
private void RemoveOrgan(EntityUid uid, EntityUid parentPartUid, OrganComponent component)
|
||||||
{
|
{
|
||||||
RaiseLocalEvent(uid, new RemovedFromPartEvent(bodyUid));
|
RaiseLocalEvent(uid, new RemovedFromPartEvent(parentPartUid));
|
||||||
|
|
||||||
if (component.Body != null)
|
if (component.Body != null)
|
||||||
|
{
|
||||||
RaiseLocalEvent(uid, new RemovedFromPartInBodyEvent(component.Body.Value, parentPartUid));
|
RaiseLocalEvent(uid, new RemovedFromPartInBodyEvent(component.Body.Value, parentPartUid));
|
||||||
|
}
|
||||||
|
|
||||||
component.Body = null;
|
component.Body = null;
|
||||||
Dirty(uid, component);
|
Dirty(uid, component);
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Content.Shared.Body.Components;
|
using Content.Shared.Body.Components;
|
||||||
|
using Content.Shared.Body.Events;
|
||||||
using Content.Shared.Body.Organ;
|
using Content.Shared.Body.Organ;
|
||||||
using Content.Shared.Body.Part;
|
using Content.Shared.Body.Part;
|
||||||
using Content.Shared.Damage;
|
using Content.Shared.Damage;
|
||||||
@@ -61,7 +62,7 @@ public partial class SharedBodySystem
|
|||||||
|
|
||||||
if (TryComp(entity, out OrganComponent? organ))
|
if (TryComp(entity, out OrganComponent? organ))
|
||||||
{
|
{
|
||||||
RemoveOrgan(entity, organ);
|
RemoveOrgan(entity, uid, organ);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -85,7 +86,20 @@ public partial class SharedBodySystem
|
|||||||
{
|
{
|
||||||
if (TryComp(organ, out OrganComponent? organComp))
|
if (TryComp(organ, out OrganComponent? organComp))
|
||||||
{
|
{
|
||||||
|
var oldBody = organComp.Body;
|
||||||
organComp.Body = bodyUid;
|
organComp.Body = bodyUid;
|
||||||
|
|
||||||
|
if (bodyUid != null)
|
||||||
|
{
|
||||||
|
var ev = new AddedToPartInBodyEvent(bodyUid.Value, children.Id);
|
||||||
|
RaiseLocalEvent(organ, ev);
|
||||||
|
}
|
||||||
|
else if (oldBody != null)
|
||||||
|
{
|
||||||
|
var ev = new RemovedFromPartInBodyEvent(oldBody.Value, children.Id);
|
||||||
|
RaiseLocalEvent(organ, ev);
|
||||||
|
}
|
||||||
|
|
||||||
Dirty(organ, organComp);
|
Dirty(organ, organComp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user