From 75a7fe14618a0b7250090a0e0d68f1e7817355af Mon Sep 17 00:00:00 2001 From: Dave Corley Date: Wed, 16 Oct 2024 00:16:06 -0700 Subject: [PATCH] FEAT: Use a hashset for ref indices to ensure no duplicates or overextension --- src/main.rs | 33 ++++++++++++++++++++------------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/src/main.rs b/src/main.rs index 72a99c1..7ea3700 100644 --- a/src/main.rs +++ b/src/main.rs @@ -74,15 +74,20 @@ fn main() { let map_data = MapData::new(map_name); - let mut indices: u32 = 0; - - for cell in plugin.objects_of_type::() { - for ((_mast_idx, ref_idx), _reference) in &cell.references { - if ref_idx > &indices { - indices = *ref_idx - } - } - } + let mut used_indices: HashSet = plugin + .objects_of_type::() + .flat_map(|cell| { + cell.references.iter().filter_map( + |((mast_idx, ref_idx), _reference)| { + if *mast_idx == 0 { + Some(*ref_idx) + } else { + None + } + }, + ) + }) + .collect(); assert!( map_data.geomap.entity_brushes.len() > 0, @@ -157,8 +162,10 @@ fn main() { } }; + let lowest_available_index: u32 = (1..).find(|&n| !used_indices.contains(&n)).unwrap_or(1); + if processed_base_objects.contains(&ref_id.to_string()) { - println!("Placing new instance of {ref_id} as ref {indices}"); + println!("Placing new instance of {ref_id} as ref {lowest_available_index}"); } else { processed_base_objects.insert(ref_id.to_string()); } @@ -241,18 +248,18 @@ fn main() { if let Some(ref mut local_cell) = cell { local_cell.references.insert( - (0 as u32, indices), + (0 as u32, lowest_available_index), esp::Reference { id: ref_id.to_owned(), mast_index: 0 as u32, - refr_index: indices, + refr_index: lowest_available_index, translation: [mesh_distance.x, mesh_distance.y, mesh_distance.z], rotation: [-mesh.mangle[0], -mesh.mangle[1], -mesh.mangle[2]], ..Default::default() }, ); - indices += 1; + used_indices.insert(lowest_available_index); } }