diff options
| author | HampusM <hampus@hampusmat.com> | 2024-07-28 19:46:01 +0200 | 
|---|---|---|
| committer | HampusM <hampus@hampusmat.com> | 2024-07-28 19:46:36 +0200 | 
| commit | 4313b5b0bfa79f4eaed25b65c5a7154c16074208 (patch) | |
| tree | 0a68dd567a2bcf1e64f68b59d6b92a0dd33d7c63 /ecs/src/component | |
| parent | 3cdef8ac2a96a91c9ab62a7ca49c128516c44efa (diff) | |
refactor(ecs): move ArchetypeComponentsHash to archetype::Id
Diffstat (limited to 'ecs/src/component')
| -rw-r--r-- | ecs/src/component/storage.rs | 39 | 
1 files changed, 9 insertions, 30 deletions
| diff --git a/ecs/src/component/storage.rs b/ecs/src/component/storage.rs index cff50cf..1db9227 100644 --- a/ecs/src/component/storage.rs +++ b/ecs/src/component/storage.rs @@ -1,8 +1,8 @@  use std::any::type_name;  use std::collections::{HashMap, HashSet}; -use std::hash::{DefaultHasher, Hash, Hasher};  use std::slice::Iter as SliceIter; +use crate::archetype::Id as ArchetypeId;  use crate::component::{Component, Id as ComponentId, IsOptional as ComponentIsOptional};  use crate::lock::Lock;  use crate::type_name::TypeName; @@ -12,7 +12,7 @@ use crate::EntityComponent;  pub struct Storage  {      archetypes: Vec<Archetype>, -    archetype_lookup: HashMap<ArchetypeComponentsHash, Vec<usize>>, +    archetype_lookup: HashMap<ArchetypeId, Vec<usize>>,      pending_archetype_lookup_entries: Vec<Vec<ComponentId>>,  } @@ -34,7 +34,7 @@ impl Storage              });          self.archetype_lookup -            .get(&ArchetypeComponentsHash::new(ids)) +            .get(&ArchetypeId::new(ids))              .map_or_else(ArchetypeRefIter::new_empty, |archetypes_indices| {                  ArchetypeRefIter {                      inner: archetypes_indices.iter(), @@ -58,7 +58,7 @@ impl Storage          let archetype_indices = self              .archetype_lookup -            .entry(ArchetypeComponentsHash::new( +            .entry(ArchetypeId::new(                  components                      .iter()                      .filter(|component| !component.is_optional()) @@ -131,7 +131,7 @@ impl Storage              let archetype_indices = self                  .archetype_lookup -                .entry(ArchetypeComponentsHash::new(pending_entry.into_iter())) +                .entry(ArchetypeId::new(pending_entry.into_iter()))                  .or_default();              archetype_indices.extend(matching_archetype_indices); @@ -185,28 +185,6 @@ impl<'component_storage> Iterator for ArchetypeRefIter<'component_storage>      }  } -#[derive(Debug, Clone, Copy, Hash, PartialEq, Eq)] -struct ArchetypeComponentsHash -{ -    hash: u64, -} - -impl ArchetypeComponentsHash -{ -    fn new(component_ids: impl IntoIterator<Item = ComponentId>) -> Self -    { -        let mut hasher = DefaultHasher::new(); - -        for component_id in component_ids { -            component_id.hash(&mut hasher); -        } - -        let hash = hasher.finish(); - -        Self { hash } -    } -} -  #[cfg(test)]  mod tests  { @@ -214,7 +192,8 @@ mod tests      use ecs_macros::Component; -    use super::{Archetype, ArchetypeComponentsHash, Storage}; +    use super::{Archetype, Storage}; +    use crate::archetype::Id as ArchetypeId;      use crate::component::Id as ComponentId;      use crate::lock::Lock;      use crate::{self as ecs, EntityComponent}; @@ -279,7 +258,7 @@ mod tests          let lookup = component_storage              .archetype_lookup -            .get(&ArchetypeComponentsHash::new([ +            .get(&ArchetypeId::new([                  ComponentId::of::<HealthPotion>(),                  ComponentId::of::<Hookshot>(),              ])) @@ -366,7 +345,7 @@ mod tests          let archetypes = component_storage              .archetype_lookup -            .get(&ArchetypeComponentsHash::new([ +            .get(&ArchetypeId::new([                  ComponentId::of::<IronBoots>(),                  ComponentId::of::<Hookshot>(),              ])) | 
