#![allow(unused_imports)]
#![allow(unused_parens)]
#![allow(clippy::clone_on_copy)]
#![allow(clippy::cloned_instead_of_copied)]
#![allow(clippy::map_flatten)]
#![allow(clippy::needless_question_mark)]
#![allow(clippy::new_without_default)]
#![allow(clippy::redundant_closure)]
#![allow(clippy::too_many_arguments)]
#![allow(clippy::too_many_lines)]
use ::re_types_core::external::arrow2;
use ::re_types_core::ComponentName;
use ::re_types_core::SerializationResult;
use ::re_types_core::{ComponentBatch, MaybeOwnedComponentBatch};
use ::re_types_core::{DeserializationError, DeserializationResult};
#[derive(Clone, Debug, PartialEq)]
pub struct Capsules3D {
pub lengths: Vec<crate::components::Length>,
pub radii: Vec<crate::components::Radius>,
pub translations: Option<Vec<crate::components::PoseTranslation3D>>,
pub rotation_axis_angles: Option<Vec<crate::components::PoseRotationAxisAngle>>,
pub quaternions: Option<Vec<crate::components::PoseRotationQuat>>,
pub colors: Option<Vec<crate::components::Color>>,
pub labels: Option<Vec<crate::components::Text>>,
pub show_labels: Option<crate::components::ShowLabels>,
pub class_ids: Option<Vec<crate::components::ClassId>>,
}
impl ::re_types_core::SizeBytes for Capsules3D {
#[inline]
fn heap_size_bytes(&self) -> u64 {
self.lengths.heap_size_bytes()
+ self.radii.heap_size_bytes()
+ self.translations.heap_size_bytes()
+ self.rotation_axis_angles.heap_size_bytes()
+ self.quaternions.heap_size_bytes()
+ self.colors.heap_size_bytes()
+ self.labels.heap_size_bytes()
+ self.show_labels.heap_size_bytes()
+ self.class_ids.heap_size_bytes()
}
#[inline]
fn is_pod() -> bool {
<Vec<crate::components::Length>>::is_pod()
&& <Vec<crate::components::Radius>>::is_pod()
&& <Option<Vec<crate::components::PoseTranslation3D>>>::is_pod()
&& <Option<Vec<crate::components::PoseRotationAxisAngle>>>::is_pod()
&& <Option<Vec<crate::components::PoseRotationQuat>>>::is_pod()
&& <Option<Vec<crate::components::Color>>>::is_pod()
&& <Option<Vec<crate::components::Text>>>::is_pod()
&& <Option<crate::components::ShowLabels>>::is_pod()
&& <Option<Vec<crate::components::ClassId>>>::is_pod()
}
}
static REQUIRED_COMPONENTS: once_cell::sync::Lazy<[ComponentName; 2usize]> =
once_cell::sync::Lazy::new(|| {
[
"rerun.components.Length".into(),
"rerun.components.Radius".into(),
]
});
static RECOMMENDED_COMPONENTS: once_cell::sync::Lazy<[ComponentName; 3usize]> =
once_cell::sync::Lazy::new(|| {
[
"rerun.components.PoseTranslation3D".into(),
"rerun.components.Color".into(),
"rerun.components.Capsules3DIndicator".into(),
]
});
static OPTIONAL_COMPONENTS: once_cell::sync::Lazy<[ComponentName; 5usize]> =
once_cell::sync::Lazy::new(|| {
[
"rerun.components.PoseRotationAxisAngle".into(),
"rerun.components.PoseRotationQuat".into(),
"rerun.components.Text".into(),
"rerun.components.ShowLabels".into(),
"rerun.components.ClassId".into(),
]
});
static ALL_COMPONENTS: once_cell::sync::Lazy<[ComponentName; 10usize]> =
once_cell::sync::Lazy::new(|| {
[
"rerun.components.Length".into(),
"rerun.components.Radius".into(),
"rerun.components.PoseTranslation3D".into(),
"rerun.components.Color".into(),
"rerun.components.Capsules3DIndicator".into(),
"rerun.components.PoseRotationAxisAngle".into(),
"rerun.components.PoseRotationQuat".into(),
"rerun.components.Text".into(),
"rerun.components.ShowLabels".into(),
"rerun.components.ClassId".into(),
]
});
impl Capsules3D {
pub const NUM_COMPONENTS: usize = 10usize;
}
pub type Capsules3DIndicator = ::re_types_core::GenericIndicatorComponent<Capsules3D>;
impl ::re_types_core::Archetype for Capsules3D {
type Indicator = Capsules3DIndicator;
#[inline]
fn name() -> ::re_types_core::ArchetypeName {
"rerun.archetypes.Capsules3D".into()
}
#[inline]
fn display_name() -> &'static str {
"Capsules 3D"
}
#[inline]
fn indicator() -> MaybeOwnedComponentBatch<'static> {
static INDICATOR: Capsules3DIndicator = Capsules3DIndicator::DEFAULT;
MaybeOwnedComponentBatch::Ref(&INDICATOR)
}
#[inline]
fn required_components() -> ::std::borrow::Cow<'static, [ComponentName]> {
REQUIRED_COMPONENTS.as_slice().into()
}
#[inline]
fn recommended_components() -> ::std::borrow::Cow<'static, [ComponentName]> {
RECOMMENDED_COMPONENTS.as_slice().into()
}
#[inline]
fn optional_components() -> ::std::borrow::Cow<'static, [ComponentName]> {
OPTIONAL_COMPONENTS.as_slice().into()
}
#[inline]
fn all_components() -> ::std::borrow::Cow<'static, [ComponentName]> {
ALL_COMPONENTS.as_slice().into()
}
#[inline]
fn from_arrow_components(
arrow_data: impl IntoIterator<Item = (ComponentName, Box<dyn arrow2::array::Array>)>,
) -> DeserializationResult<Self> {
re_tracing::profile_function!();
use ::re_types_core::{Loggable as _, ResultExt as _};
let arrays_by_name: ::std::collections::HashMap<_, _> = arrow_data
.into_iter()
.map(|(name, array)| (name.full_name(), array))
.collect();
let lengths = {
let array = arrays_by_name
.get("rerun.components.Length")
.ok_or_else(DeserializationError::missing_data)
.with_context("rerun.archetypes.Capsules3D#lengths")?;
<crate::components::Length>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#lengths")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#lengths")?
};
let radii = {
let array = arrays_by_name
.get("rerun.components.Radius")
.ok_or_else(DeserializationError::missing_data)
.with_context("rerun.archetypes.Capsules3D#radii")?;
<crate::components::Radius>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#radii")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#radii")?
};
let translations =
if let Some(array) = arrays_by_name.get("rerun.components.PoseTranslation3D") {
Some({
<crate::components::PoseTranslation3D>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#translations")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#translations")?
})
} else {
None
};
let rotation_axis_angles =
if let Some(array) = arrays_by_name.get("rerun.components.PoseRotationAxisAngle") {
Some({
<crate::components::PoseRotationAxisAngle>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#rotation_axis_angles")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#rotation_axis_angles")?
})
} else {
None
};
let quaternions =
if let Some(array) = arrays_by_name.get("rerun.components.PoseRotationQuat") {
Some({
<crate::components::PoseRotationQuat>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#quaternions")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#quaternions")?
})
} else {
None
};
let colors = if let Some(array) = arrays_by_name.get("rerun.components.Color") {
Some({
<crate::components::Color>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#colors")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#colors")?
})
} else {
None
};
let labels = if let Some(array) = arrays_by_name.get("rerun.components.Text") {
Some({
<crate::components::Text>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#labels")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#labels")?
})
} else {
None
};
let show_labels = if let Some(array) = arrays_by_name.get("rerun.components.ShowLabels") {
<crate::components::ShowLabels>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#show_labels")?
.into_iter()
.next()
.flatten()
} else {
None
};
let class_ids = if let Some(array) = arrays_by_name.get("rerun.components.ClassId") {
Some({
<crate::components::ClassId>::from_arrow_opt(&**array)
.with_context("rerun.archetypes.Capsules3D#class_ids")?
.into_iter()
.map(|v| v.ok_or_else(DeserializationError::missing_data))
.collect::<DeserializationResult<Vec<_>>>()
.with_context("rerun.archetypes.Capsules3D#class_ids")?
})
} else {
None
};
Ok(Self {
lengths,
radii,
translations,
rotation_axis_angles,
quaternions,
colors,
labels,
show_labels,
class_ids,
})
}
}
impl ::re_types_core::AsComponents for Capsules3D {
fn as_component_batches(&self) -> Vec<MaybeOwnedComponentBatch<'_>> {
re_tracing::profile_function!();
use ::re_types_core::Archetype as _;
[
Some(Self::indicator()),
Some((&self.lengths as &dyn ComponentBatch).into()),
Some((&self.radii as &dyn ComponentBatch).into()),
self.translations
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
self.rotation_axis_angles
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
self.quaternions
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
self.colors
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
self.labels
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
self.show_labels
.as_ref()
.map(|comp| (comp as &dyn ComponentBatch).into()),
self.class_ids
.as_ref()
.map(|comp_batch| (comp_batch as &dyn ComponentBatch).into()),
]
.into_iter()
.flatten()
.collect()
}
}
impl ::re_types_core::ArchetypeReflectionMarker for Capsules3D {}
impl Capsules3D {
#[inline]
pub(crate) fn new(
lengths: impl IntoIterator<Item = impl Into<crate::components::Length>>,
radii: impl IntoIterator<Item = impl Into<crate::components::Radius>>,
) -> Self {
Self {
lengths: lengths.into_iter().map(Into::into).collect(),
radii: radii.into_iter().map(Into::into).collect(),
translations: None,
rotation_axis_angles: None,
quaternions: None,
colors: None,
labels: None,
show_labels: None,
class_ids: None,
}
}
#[inline]
pub fn with_translations(
mut self,
translations: impl IntoIterator<Item = impl Into<crate::components::PoseTranslation3D>>,
) -> Self {
self.translations = Some(translations.into_iter().map(Into::into).collect());
self
}
#[inline]
pub fn with_rotation_axis_angles(
mut self,
rotation_axis_angles: impl IntoIterator<
Item = impl Into<crate::components::PoseRotationAxisAngle>,
>,
) -> Self {
self.rotation_axis_angles =
Some(rotation_axis_angles.into_iter().map(Into::into).collect());
self
}
#[inline]
pub fn with_quaternions(
mut self,
quaternions: impl IntoIterator<Item = impl Into<crate::components::PoseRotationQuat>>,
) -> Self {
self.quaternions = Some(quaternions.into_iter().map(Into::into).collect());
self
}
#[inline]
pub fn with_colors(
mut self,
colors: impl IntoIterator<Item = impl Into<crate::components::Color>>,
) -> Self {
self.colors = Some(colors.into_iter().map(Into::into).collect());
self
}
#[inline]
pub fn with_labels(
mut self,
labels: impl IntoIterator<Item = impl Into<crate::components::Text>>,
) -> Self {
self.labels = Some(labels.into_iter().map(Into::into).collect());
self
}
#[inline]
pub fn with_show_labels(
mut self,
show_labels: impl Into<crate::components::ShowLabels>,
) -> Self {
self.show_labels = Some(show_labels.into());
self
}
#[inline]
pub fn with_class_ids(
mut self,
class_ids: impl IntoIterator<Item = impl Into<crate::components::ClassId>>,
) -> Self {
self.class_ids = Some(class_ids.into_iter().map(Into::into).collect());
self
}
}