-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cleaning up destroyed entities #3
Comments
Thought I'd share the approach I went with. This involves // build the gameplay schedule (basically all our systems are part of it)
gameplaySchedule.build();
// create a new schedule and make executing the gameplay schedule part of it
export const schedule = new Schedule();
const RunGameplay = ({world}) => {
gameplaySchedule.run({world});
}
// add the entity destruction system after it
schedule.add(RunGameplay);
schedule.add(DestroyEntities, {after: RunGameplay});
schedule.build(); // <- this is the schedule we'll run in rAF
// new trait that the `DestroyEntities` system will query for
export const MarkedForDestruction = trait({
destructionCb: {
cb: (entity: Entity, world: World) => {}
}
});
// helper function that can be called instead of `entity.destroy()` whenever we want
// to schedule destruction. Optionally accepts a callback
export function destroyAtEndOfFrame(entity: Entity, onDestroy?) {
entity.add(MarkedForDestruction({
destructionCb: {
cb: onDestroy
}
}));
}
// Omitting the destruction system – all it does is query for entities with the
// MarkedForDestruction trait, execute the callback and destroy the entity. This then allows you to write your own cleanup systems, i.e. I feel like at the current point in time it's better not to build anything in, unless we decide we want to make systems part of the package (I'm a proponent of that, the ecosystem is currently lacking a systems scheduler) and offer a default schedule out of the box, then sth like this could be an approach. |
This is the approach where instead of destroying an entity, it gets tagged for cleanup and then a system down the line destroys it. The problem I see with this is that it makes destroying an entity an unsafe operation. You now need to have perfect knowledge over which entities need cleanup, so should not be destroyed, and which entities don't need cleanup, so can be destroyed. Which means you need knowledge of what traits are on it and the systems operating on those traits. I foresee this being a problem with a growing ecosystem where each package installed is a black box. Ideally, we implement a solution where entities can be safely destroyed and cleaned up without special knowledge about how all the internals are working. |
IMO, a system abstraction is something that would work on top of whatever we implement, so we would need to be able to express the cleanup and destroy life cycles without it anyway. |
What if we build in a destruction tag like above with a cleanup system at the end of the schedule and then have Then an extra method like |
What is the preferred workflow and behavior here? Should the removed trackers remove entities that are destroyed? Should there be a way to flag entities for cleanup so destroying them keeps their data until another command is given? Should data that needs to persist for cleanup be stored outside of the entity? Should side effects be done in callbacks like onAdd and onRemove?
The text was updated successfully, but these errors were encountered: