use crate::component::Component;
use crate::entity_id::EntityId;
use crate::views::ViewMut;
pub trait Remove {
type Out;
fn remove(&mut self, entity: EntityId) -> Self::Out;
}
impl Remove for () {
type Out = ();
#[inline]
fn remove(&mut self, _: EntityId) -> Self::Out {}
}
impl<T: Component, TRACK> Remove for ViewMut<'_, T, TRACK> {
type Out = Option<T>;
#[inline]
fn remove(&mut self, entity: EntityId) -> Self::Out {
let current = self.current;
self.dyn_remove(entity, current)
}
}
impl<T: Component, TRACK> Remove for &mut ViewMut<'_, T, TRACK> {
type Out = Option<T>;
#[inline]
fn remove(&mut self, entity: EntityId) -> Self::Out {
let current = self.current;
self.dyn_remove(entity, current)
}
}
macro_rules! impl_remove_component {
($(($storage: ident, $index: tt))+) => {
impl<$($storage: Remove),+> Remove for ($($storage,)+) {
type Out = ($($storage::Out,)+);
#[inline]
fn remove(&mut self, entity: EntityId) -> Self::Out {
($(
self.$index.remove(entity),
)+)
}
}
}
}
macro_rules! remove_component {
($(($storage: ident, $index: tt))+; ($storage1: ident, $index1: tt) $(($queue_type: ident, $queue_index: tt))*) => {
impl_remove_component![$(($storage, $index))*];
remove_component![$(($storage, $index))* ($storage1, $index1); $(($queue_type, $queue_index))*];
};
($(($storage: ident, $index: tt))+;) => {
impl_remove_component![$(($storage, $index))*];
}
}
#[cfg(not(feature = "extended_tuple"))]
remove_component![(ViewA, 0); (ViewB, 1) (ViewC, 2) (ViewD, 3) (ViewE, 4) (ViewF, 5) (ViewG, 6) (ViewH, 7) (ViewI, 8) (ViewJ, 9)];
#[cfg(feature = "extended_tuple")]
remove_component![
(ViewA, 0); (ViewB, 1) (ViewC, 2) (ViewD, 3) (ViewE, 4) (ViewF, 5) (ViewG, 6) (ViewH, 7) (ViewI, 8) (ViewJ, 9)
(ViewK, 10) (ViewL, 11) (ViewM, 12) (ViewN, 13) (ViewO, 14) (ViewP, 15) (ViewQ, 16) (ViewR, 17) (ViewS, 18) (ViewT, 19)
(ViewU, 20) (ViewV, 21) (ViewW, 22) (ViewX, 23) (ViewY, 24) (ViewZ, 25) (ViewAA, 26) (ViewBB, 27) (ViewCC, 28) (ViewDD, 29)
(ViewEE, 30) (ViewFF, 31)
];