2022-06-24 17:44:30 +10:00
|
|
|
using Content.Shared.Spawners.Components;
|
2023-04-10 15:37:03 +10:00
|
|
|
using Robust.Shared.GameStates;
|
|
|
|
|
using Robust.Shared.Serialization;
|
2022-06-24 17:44:30 +10:00
|
|
|
using Robust.Shared.Timing;
|
|
|
|
|
|
|
|
|
|
namespace Content.Shared.Spawners.EntitySystems;
|
|
|
|
|
|
|
|
|
|
public abstract class SharedTimedDespawnSystem : EntitySystem
|
|
|
|
|
{
|
|
|
|
|
[Dependency] private readonly IGameTiming _timing = default!;
|
|
|
|
|
|
2023-01-08 07:04:09 +13:00
|
|
|
public override void Initialize()
|
|
|
|
|
{
|
|
|
|
|
base.Initialize();
|
|
|
|
|
UpdatesOutsidePrediction = true;
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-24 17:44:30 +10:00
|
|
|
public override void Update(float frameTime)
|
|
|
|
|
{
|
|
|
|
|
base.Update(frameTime);
|
|
|
|
|
|
2023-09-17 19:18:52 +12:00
|
|
|
// AAAAAAAAAAAAAAAAAAAAAAAAAAA
|
|
|
|
|
// Client both needs to predict this, but also can't properly handle prediction resetting.
|
2023-04-10 15:37:03 +10:00
|
|
|
if (!_timing.IsFirstTimePredicted)
|
|
|
|
|
return;
|
2022-06-24 17:44:30 +10:00
|
|
|
|
2023-04-10 15:37:03 +10:00
|
|
|
var query = EntityQueryEnumerator<TimedDespawnComponent>();
|
2022-06-24 17:44:30 +10:00
|
|
|
|
2023-04-10 15:37:03 +10:00
|
|
|
while (query.MoveNext(out var uid, out var comp))
|
|
|
|
|
{
|
2022-06-24 17:44:30 +10:00
|
|
|
comp.Lifetime -= frameTime;
|
|
|
|
|
|
2023-04-10 15:37:03 +10:00
|
|
|
if (!CanDelete(uid))
|
|
|
|
|
continue;
|
|
|
|
|
|
2022-06-24 17:44:30 +10:00
|
|
|
if (comp.Lifetime <= 0)
|
2023-04-10 15:37:03 +10:00
|
|
|
{
|
|
|
|
|
var ev = new TimedDespawnEvent();
|
|
|
|
|
RaiseLocalEvent(uid, ref ev);
|
|
|
|
|
QueueDel(uid);
|
|
|
|
|
}
|
2022-06-24 17:44:30 +10:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected abstract bool CanDelete(EntityUid uid);
|
|
|
|
|
}
|