Skip to content
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

Tracking issue: support change detection for delete entities & components #13

Open
AThilenius opened this issue Oct 5, 2019 · 2 comments

Comments

@AThilenius
Copy link
Contributor

For the hierarchy implementation I need a way to detect both deleted entities and components (I don't think I need to disambiguate however, just when any Parent or entity that had a Parent is deleted).

The ideal case would be to have a separate deleted filter that would also give me that last set Component value. I could see this being problematic in terms of leaking memory however.

Tagging @jaynus here too.

@TomGillen
Copy link
Collaborator

Would what is outlined in #15 be enough for this, or do you need to be able to read the Parent component before the entity is removed?

@AThilenius
Copy link
Contributor Author

Hmmm. Yeah this is a tricky one. Ideal case is to iterate through (or receive events for) entities with a query like: 'read the PreviousParent components for any deleted entity with a Parent and PreviousParent, or any entity that has a deleted Parent component).

The more I think of it though, the more can-of-worms this gets. If you have an API to provide component data after it has been 'deleted', then the potential to leak memory seems significant. All the user has to do is forget to consume all the events.

Another way to work around this for my use-case (I think Unity ECS might do this too, actually) would be:

  • Collect a set of 'known' entity IDs by querying for all Children components.
  • Iterate through all Parent and PreviousParent components to compare what was removed from the hierarchy.

I don't think that would require remove events at all but might be more costly.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants