add .include_entity()
helper on query iterators
#16560
Draft
+190
−0
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Objective
Adds a helper method to the
QueryIter
struct called.include_entity()
, which automatically adds(Entity, _)
around whatever is currently being iterated. Since the underlyingEntity
is always tracked anyway, this can be done "for free" at zero additional runtime cost.This helper makes it more ergonomic to evolve systems over time. For example, as we write a complex system, we encounter a case where we need the
Entity
that we're iterating over:Despite the
Entity
already being tracked at runtime, we then need to go back and update multiple lines of code to request it:Of the 5 changed lines, only the last 2 are essential to the change we actually want to make. If we use
include_entity()
instead, then we get the much-more-explicit delta:Why not
(Entity, D)
? Why a newIncludeEntity<D>
type?The underlying query state for the query
(A, B)
is(A::State, B::State)
. This means that for(Entity, D)
the underlying state type is((), D::State))
, notD::State
. Despite looking very similar, these types aren't guaranteed to have the same layout, and so we cannot transmute between them.Testing