Turn brain behavior into a component/system (#5281)
This commit is contained in:
@@ -79,6 +79,7 @@ namespace Content.Client.Entry
|
|||||||
"Hitscan",
|
"Hitscan",
|
||||||
"StunOnCollide",
|
"StunOnCollide",
|
||||||
"RandomPottedPlant",
|
"RandomPottedPlant",
|
||||||
|
"Brain",
|
||||||
"CommunicationsConsole",
|
"CommunicationsConsole",
|
||||||
"BarSign",
|
"BarSign",
|
||||||
"DroppedBodyPart",
|
"DroppedBodyPart",
|
||||||
|
|||||||
@@ -1,70 +0,0 @@
|
|||||||
using Content.Server.Ghost;
|
|
||||||
using Content.Server.Ghost.Components;
|
|
||||||
using Content.Server.Mind.Components;
|
|
||||||
using Content.Shared.Body.Components;
|
|
||||||
using Content.Shared.Body.Part;
|
|
||||||
using Content.Shared.Movement.Components;
|
|
||||||
using Robust.Shared.GameObjects;
|
|
||||||
|
|
||||||
namespace Content.Server.Body.Behavior
|
|
||||||
{
|
|
||||||
public class BrainBehavior : MechanismBehavior
|
|
||||||
{
|
|
||||||
protected override void OnAddedToBody(SharedBodyComponent body)
|
|
||||||
{
|
|
||||||
base.OnAddedToBody(body);
|
|
||||||
|
|
||||||
HandleMind(body.Owner, Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnAddedToPart(SharedBodyPartComponent part)
|
|
||||||
{
|
|
||||||
base.OnAddedToPart(part);
|
|
||||||
|
|
||||||
HandleMind(part.Owner, Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnAddedToPartInBody(SharedBodyComponent body, SharedBodyPartComponent part)
|
|
||||||
{
|
|
||||||
base.OnAddedToPartInBody(body, part);
|
|
||||||
|
|
||||||
HandleMind(body.Owner, Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnRemovedFromBody(SharedBodyComponent old)
|
|
||||||
{
|
|
||||||
base.OnRemovedFromBody(old);
|
|
||||||
|
|
||||||
HandleMind(Part!.Owner, old.Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnRemovedFromPart(SharedBodyPartComponent old)
|
|
||||||
{
|
|
||||||
base.OnRemovedFromPart(old);
|
|
||||||
|
|
||||||
HandleMind(Owner, old.Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnRemovedFromPartInBody(SharedBodyComponent oldBody, SharedBodyPartComponent oldPart)
|
|
||||||
{
|
|
||||||
base.OnRemovedFromPartInBody(oldBody, oldPart);
|
|
||||||
|
|
||||||
HandleMind(oldBody.Owner, Owner);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void HandleMind(IEntity newEntity, IEntity oldEntity)
|
|
||||||
{
|
|
||||||
newEntity.EnsureComponent<MindComponent>();
|
|
||||||
var oldMind = oldEntity.EnsureComponent<MindComponent>();
|
|
||||||
|
|
||||||
if (!newEntity.HasComponent<IGhostOnMove>())
|
|
||||||
newEntity.AddComponent<GhostOnMoveComponent>();
|
|
||||||
|
|
||||||
// TODO: This is an awful solution.
|
|
||||||
if (!newEntity.HasComponent<IMoverComponent>())
|
|
||||||
newEntity.AddComponent<SharedDummyInputMoverComponent>();
|
|
||||||
|
|
||||||
oldMind.Mind?.TransferTo(newEntity);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
12
Content.Server/Body/Components/BrainComponent.cs
Normal file
12
Content.Server/Body/Components/BrainComponent.cs
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
using Content.Server.Body.Systems;
|
||||||
|
using Robust.Shared.Analyzers;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Server.Body.Components
|
||||||
|
{
|
||||||
|
[RegisterComponent, Friend(typeof(BrainSystem))]
|
||||||
|
public class BrainComponent : Component
|
||||||
|
{
|
||||||
|
public override string Name => "Brain";
|
||||||
|
}
|
||||||
|
}
|
||||||
49
Content.Server/Body/Systems/BrainSystem.cs
Normal file
49
Content.Server/Body/Systems/BrainSystem.cs
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
using Content.Server.Body.Components;
|
||||||
|
using Content.Server.Ghost;
|
||||||
|
using Content.Server.Ghost.Components;
|
||||||
|
using Content.Server.Mind.Components;
|
||||||
|
using Content.Shared.Body.Events;
|
||||||
|
using Content.Shared.Movement.Components;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Server.Body.Systems
|
||||||
|
{
|
||||||
|
public class BrainSystem : EntitySystem
|
||||||
|
{
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
base.Initialize();
|
||||||
|
|
||||||
|
SubscribeLocalEvent<BrainComponent, AddedToBodyEvent>((uid, component, args) => HandleMind(args.Body.OwnerUid, uid));
|
||||||
|
SubscribeLocalEvent<BrainComponent, AddedToPartEvent>((uid, component, args) => HandleMind(args.Part.OwnerUid, uid));
|
||||||
|
SubscribeLocalEvent<BrainComponent, AddedToPartInBodyEvent>((uid, component, args) => HandleMind(args.Body.OwnerUid, uid));
|
||||||
|
SubscribeLocalEvent<BrainComponent, RemovedFromBodyEvent>(OnRemovedFromBody);
|
||||||
|
SubscribeLocalEvent<BrainComponent, RemovedFromPartEvent>((uid, component, args) => HandleMind(uid, args.Old.OwnerUid));
|
||||||
|
SubscribeLocalEvent<BrainComponent, RemovedFromPartInBodyEvent>((uid, component, args) => HandleMind(args.OldBody.OwnerUid, uid));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnRemovedFromBody(EntityUid uid, BrainComponent component, RemovedFromBodyEvent args)
|
||||||
|
{
|
||||||
|
// This one needs to be special, okay?
|
||||||
|
if (!EntityManager.TryGetComponent(uid, out MechanismComponent mech))
|
||||||
|
return;
|
||||||
|
|
||||||
|
HandleMind(mech.Part!.OwnerUid, args.Old.OwnerUid);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void HandleMind(EntityUid newEntity, EntityUid oldEntity)
|
||||||
|
{
|
||||||
|
EntityManager.EnsureComponent<MindComponent>(newEntity);
|
||||||
|
var oldMind = EntityManager.EnsureComponent<MindComponent>(oldEntity);
|
||||||
|
|
||||||
|
if (!EntityManager.HasComponent<IGhostOnMove>(newEntity))
|
||||||
|
EntityManager.AddComponent<GhostOnMoveComponent>(newEntity);
|
||||||
|
|
||||||
|
// TODO: This is an awful solution.
|
||||||
|
if (!EntityManager.HasComponent<IMoverComponent>(newEntity))
|
||||||
|
EntityManager.AddComponent<SharedDummyInputMoverComponent>(newEntity);
|
||||||
|
|
||||||
|
oldMind.Mind?.TransferTo(EntityManager.GetEntity(newEntity));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Content.Shared.Body.Behavior;
|
using Content.Shared.Body.Behavior;
|
||||||
|
using Content.Shared.Body.Events;
|
||||||
using Content.Shared.Body.Part;
|
using Content.Shared.Body.Part;
|
||||||
using Robust.Shared.GameObjects;
|
using Robust.Shared.GameObjects;
|
||||||
using Robust.Shared.IoC;
|
using Robust.Shared.IoC;
|
||||||
@@ -168,12 +169,14 @@ namespace Content.Shared.Body.Components
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO BODY Turn these into event listeners so they dont need to be exposed
|
|
||||||
public void AddedToBody(SharedBodyComponent body)
|
public void AddedToBody(SharedBodyComponent body)
|
||||||
{
|
{
|
||||||
DebugTools.AssertNotNull(Body);
|
DebugTools.AssertNotNull(Body);
|
||||||
DebugTools.AssertNotNull(body);
|
DebugTools.AssertNotNull(body);
|
||||||
|
|
||||||
|
var ev = new AddedToBodyEvent(body);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.AddedToBody(body);
|
behavior.AddedToBody(body);
|
||||||
@@ -187,6 +190,9 @@ namespace Content.Shared.Body.Components
|
|||||||
|
|
||||||
Owner.Transform.AttachParent(part.Owner);
|
Owner.Transform.AttachParent(part.Owner);
|
||||||
|
|
||||||
|
var ev = new AddedToPartEvent(part);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.AddedToPart(part);
|
behavior.AddedToPart(part);
|
||||||
@@ -202,6 +208,9 @@ namespace Content.Shared.Body.Components
|
|||||||
|
|
||||||
Owner.Transform.AttachParent(part.Owner);
|
Owner.Transform.AttachParent(part.Owner);
|
||||||
|
|
||||||
|
var ev = new AddedToPartInBodyEvent(body, part);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.AddedToPartInBody(body, part);
|
behavior.AddedToPartInBody(body, part);
|
||||||
@@ -213,6 +222,9 @@ namespace Content.Shared.Body.Components
|
|||||||
DebugTools.AssertNull(Body);
|
DebugTools.AssertNull(Body);
|
||||||
DebugTools.AssertNotNull(old);
|
DebugTools.AssertNotNull(old);
|
||||||
|
|
||||||
|
var ev = new RemovedFromBodyEvent(old);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.RemovedFromBody(old);
|
behavior.RemovedFromBody(old);
|
||||||
@@ -226,6 +238,9 @@ namespace Content.Shared.Body.Components
|
|||||||
|
|
||||||
Owner.Transform.AttachToGridOrMap();
|
Owner.Transform.AttachToGridOrMap();
|
||||||
|
|
||||||
|
var ev = new RemovedFromPartEvent(old);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.RemovedFromPart(old);
|
behavior.RemovedFromPart(old);
|
||||||
@@ -241,6 +256,9 @@ namespace Content.Shared.Body.Components
|
|||||||
|
|
||||||
Owner.Transform.AttachToGridOrMap();
|
Owner.Transform.AttachToGridOrMap();
|
||||||
|
|
||||||
|
var ev = new RemovedFromPartInBodyEvent(oldBody, oldPart);
|
||||||
|
Owner.EntityManager.EventBus.RaiseLocalEvent(OwnerUid, ev, false);
|
||||||
|
|
||||||
foreach (var behavior in _behaviors.Values)
|
foreach (var behavior in _behaviors.Values)
|
||||||
{
|
{
|
||||||
behavior.RemovedFromPartInBody(oldBody, oldPart);
|
behavior.RemovedFromPartInBody(oldBody, oldPart);
|
||||||
|
|||||||
90
Content.Shared/Body/Events/MechanismBodyEvents.cs
Normal file
90
Content.Shared/Body/Events/MechanismBodyEvents.cs
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
using Content.Shared.Body.Components;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Shared.Body.Events
|
||||||
|
{
|
||||||
|
// All of these events are raised on a mechanism entity when added/removed to a body in different
|
||||||
|
// ways.
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is added to a body.
|
||||||
|
/// </summary>
|
||||||
|
public class AddedToBodyEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyComponent Body;
|
||||||
|
|
||||||
|
public AddedToBodyEvent(SharedBodyComponent body)
|
||||||
|
{
|
||||||
|
Body = body;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is added to a body part.
|
||||||
|
/// </summary>
|
||||||
|
public class AddedToPartEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyPartComponent Part;
|
||||||
|
|
||||||
|
public AddedToPartEvent(SharedBodyPartComponent part)
|
||||||
|
{
|
||||||
|
Part = part;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is added to a body part within a body.
|
||||||
|
/// </summary>
|
||||||
|
public class AddedToPartInBodyEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyComponent Body;
|
||||||
|
public SharedBodyPartComponent Part;
|
||||||
|
|
||||||
|
public AddedToPartInBodyEvent(SharedBodyComponent body, SharedBodyPartComponent part)
|
||||||
|
{
|
||||||
|
Body = body;
|
||||||
|
Part = part;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is removed from a body.
|
||||||
|
/// </summary>
|
||||||
|
public class RemovedFromBodyEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyComponent Old;
|
||||||
|
|
||||||
|
public RemovedFromBodyEvent(SharedBodyComponent old)
|
||||||
|
{
|
||||||
|
Old = old;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is removed from a body part.
|
||||||
|
/// </summary>
|
||||||
|
public class RemovedFromPartEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyPartComponent Old;
|
||||||
|
|
||||||
|
public RemovedFromPartEvent(SharedBodyPartComponent old)
|
||||||
|
{
|
||||||
|
Old = old;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised on a mechanism when it is removed from a body part within a body.
|
||||||
|
/// </summary>
|
||||||
|
public class RemovedFromPartInBodyEvent : EntityEventArgs
|
||||||
|
{
|
||||||
|
public SharedBodyComponent OldBody;
|
||||||
|
public SharedBodyPartComponent OldPart;
|
||||||
|
|
||||||
|
public RemovedFromPartInBodyEvent(SharedBodyComponent oldBody, SharedBodyPartComponent oldPart)
|
||||||
|
{
|
||||||
|
OldBody = oldBody;
|
||||||
|
OldPart = oldPart;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -28,12 +28,11 @@
|
|||||||
- type: Mechanism
|
- type: Mechanism
|
||||||
size: 1
|
size: 1
|
||||||
compatibility: Biological
|
compatibility: Biological
|
||||||
behaviors:
|
|
||||||
- !type:BrainBehavior {}
|
|
||||||
- type: Input
|
- type: Input
|
||||||
context: "ghost"
|
context: "ghost"
|
||||||
- type: DummyInputMover
|
- type: DummyInputMover
|
||||||
- type: GhostOnMove
|
- type: GhostOnMove
|
||||||
|
- type: Brain
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
id: OrganHumanEyes
|
id: OrganHumanEyes
|
||||||
|
|||||||
Reference in New Issue
Block a user