From d62db9396ebbe012d7b1c0f373fda084d468227c Mon Sep 17 00:00:00 2001 From: Clement Rey Date: Wed, 11 Dec 2024 09:23:36 +0100 Subject: [PATCH] Rust: more `impl` helpers (#8401) New release, new helpers, as is now customary. These only introduced two breaking changes in all of our examples and snippets, and they look pretty innocuous. Opinions? * Fixes #8398 --- crates/store/re_types_core/src/lib.rs | 108 ++++++++++++++++++ .../all/archetypes/image_send_columns.rs | 8 +- .../all/archetypes/mesh3d_partial_updates.rs | 2 +- 3 files changed, 116 insertions(+), 2 deletions(-) diff --git a/crates/store/re_types_core/src/lib.rs b/crates/store/re_types_core/src/lib.rs index 27a13bc63224..77ded5215d26 100644 --- a/crates/store/re_types_core/src/lib.rs +++ b/crates/store/re_types_core/src/lib.rs @@ -109,6 +109,15 @@ impl AsComponents for [&dyn ComponentBatch; N] { } } +impl AsComponents for [Box; N] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .map(|batch| ComponentBatchCowWithDescriptor::new(&**batch)) + .collect() + } +} + impl AsComponents for &[&dyn ComponentBatch] { #[inline] fn as_component_batches(&self) -> Vec> { @@ -118,6 +127,15 @@ impl AsComponents for &[&dyn ComponentBatch] { } } +impl AsComponents for &[Box] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .map(|batch| ComponentBatchCowWithDescriptor::new(&**batch)) + .collect() + } +} + impl AsComponents for Vec<&dyn ComponentBatch> { #[inline] fn as_component_batches(&self) -> Vec> { @@ -127,6 +145,96 @@ impl AsComponents for Vec<&dyn ComponentBatch> { } } +impl AsComponents for Vec> { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .map(|batch| ComponentBatchCowWithDescriptor::new(&**batch)) + .collect() + } +} + +impl AsComponents for [AS; N] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for [&dyn AsComponents; N] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for [Box; N] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for &[AS] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for &[&dyn AsComponents] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for &[Box] { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for Vec { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for Vec<&dyn AsComponents> { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + +impl AsComponents for Vec> { + #[inline] + fn as_component_batches(&self) -> Vec> { + self.iter() + .flat_map(|as_components| as_components.as_component_batches()) + .collect() + } +} + // --- mod archetype; diff --git a/docs/snippets/all/archetypes/image_send_columns.rs b/docs/snippets/all/archetypes/image_send_columns.rs index 5f0e2c991f81..73ed177259fd 100644 --- a/docs/snippets/all/archetypes/image_send_columns.rs +++ b/docs/snippets/all/archetypes/image_send_columns.rs @@ -23,7 +23,13 @@ fn main() -> Result<(), Box> { // Log the ImageFormat and indicator once, as static. let format = rerun::components::ImageFormat::rgb8([width as _, height as _]); - rec.log_static("images", &[&format as _, &rerun::Image::indicator() as _])?; + rec.log_static( + "images", + &[ + &format as &dyn rerun::ComponentBatch, + &rerun::Image::indicator(), + ], + )?; // Split up the image data into several components referencing the underlying data. let image_size_in_bytes = width * height * 3; diff --git a/docs/snippets/all/archetypes/mesh3d_partial_updates.rs b/docs/snippets/all/archetypes/mesh3d_partial_updates.rs index 1027b254a0bb..791428f62e52 100644 --- a/docs/snippets/all/archetypes/mesh3d_partial_updates.rs +++ b/docs/snippets/all/archetypes/mesh3d_partial_updates.rs @@ -26,7 +26,7 @@ fn main() -> Result<(), Box> { (glam::Vec3::from(vertex_positions[1]) * factor).into(), (glam::Vec3::from(vertex_positions[2]) * factor).into(), ]; - rec.log("triangle", &[&vertex_positions as _])?; + rec.log("triangle", &vertex_positions)?; } Ok(())