A batch of frame callbacks.
Definition frameevent.h:70
void ExecuteAsync(World *world)
Definition frameevent.cc:264
Util::Array< Processor * > processors
Definition frameevent.h:100
int order
sorting order in frame event
Definition frameevent.h:91
void Execute(World *world)
Definition frameevent.cc:152
bool async
Definition frameevent.h:92
~Batch()
Definition frameevent.cc:140
void CacheTable(MemDb::TableId, MemDb::TableSignature const &)
add a table to the cache of any processors that accepts it, that is attached to this frame batch
Definition frameevent.cc:224
void Prefilter(World *world, bool force=false)
prefilter all processors. Should not be done per frame - instead use CacheTable if you need to do inc...
Definition frameevent.cc:207
void ExecuteSequential(World *world)
Definition frameevent.cc:307
bool TryInsert(Processor *processor)
Try to insert a processor into the batch.
Definition frameevent.cc:168
Util::Array< Processor const * > GetProcessors() const
Definition frameevent.cc:249
Definition frameevent.h:34
void AddProcessor(Processor *processor)
Definition frameevent.cc:66
Util::Array< Batch const * > const GetBatches() const
Definition frameevent.cc:126
int order
Definition frameevent.h:50
Util::Array< Batch * > batches
Batches that this event will execute.
Definition frameevent.h:61
FramePipeline * pipeline
Which pipeline is this event attached to.
Definition frameevent.h:58
void CacheTable(MemDb::TableId, MemDb::TableSignature const &)
add a table to the caches of any processors that accepts it, that is attached to this frame event
Definition frameevent.cc:114
void Run(World *world)
Definition frameevent.cc:47
friend FramePipeline
Definition frameevent.h:55
void Prefilter(World *world, bool force=false)
prefilter all processors. Should not be done per frame - instead use CacheTable if you need to do inc...
Definition frameevent.cc:102
Util::StringAtom name
Definition frameevent.h:49
~FrameEvent()
Definition frameevent.cc:35
Definition frameevent.h:108
volatile bool inAsync
Definition frameevent.h:144
Util::Array< FrameEvent const * > const GetFrameEvents() const
Definition frameevent.cc:486
void RunRemaining()
Run until the pipeline ends.
Definition frameevent.cc:439
void Prefilter(bool force=false)
prefilter all processors. Should not be done per frame - instead use CacheTable if you need to do inc...
Definition frameevent.cc:462
void Reset()
Reset the pipeline to the start.
Definition frameevent.cc:411
void Begin()
Start running the pipeline.
Definition frameevent.cc:393
friend FrameEvent
Definition frameevent.h:140
IndexT currentIndex
Definition frameevent.h:145
bool isRunning
Definition frameevent.h:143
bool IsRunningAsync()
check if the pipeline is currently executing an async frame event batch
Definition frameevent.cc:453
World * world
Definition frameevent.h:142
Util::Array< FrameEvent * > frameEvents
Definition frameevent.h:146
void CacheTable(MemDb::TableId, MemDb::TableSignature const &)
add a table to the caches of any processors that accepts it, that is attached to this frame event
Definition frameevent.cc:474
FrameEvent * GetFrameEvent(Util::StringAtom name)
Definition frameevent.cc:377
void End()
Stop running the pipeline.
Definition frameevent.cc:404
void RunThru(Util::StringAtom name)
Run and execute until a certain event is executed (inclusive)
Definition frameevent.cc:420
~FramePipeline()
Definition frameevent.cc:332
FrameEvent * RegisterFrameEvent(int order, Util::StringAtom name)
Definition frameevent.cc:344
Definition processor.h:22
Basically a bitfield with packed ComponentIds.
Definition tablesignature.h:26
Nebula's dynamic array class.
Definition array.h:60
A StringAtom.
Definition stringatom.h:22
Definition orientation.h:7
This represents a "view" into an entity table.
Definition dataset.h:35
Definition frameevent.h:25
ProcessorJobInput * inputs
Definition frameevent.h:27
Game::World * world
Definition frameevent.h:26
Table identifier.
Definition tableid.h:14
int IndexT
Definition types.h:48