re_types/components/
radius.rs1#![allow(unused_braces)]
5#![allow(unused_imports)]
6#![allow(unused_parens)]
7#![allow(clippy::clone_on_copy)]
8#![allow(clippy::cloned_instead_of_copied)]
9#![allow(clippy::map_flatten)]
10#![allow(clippy::needless_question_mark)]
11#![allow(clippy::new_without_default)]
12#![allow(clippy::redundant_closure)]
13#![allow(clippy::too_many_arguments)]
14#![allow(clippy::too_many_lines)]
15
16use ::re_types_core::try_serialize_field;
17use ::re_types_core::SerializationResult;
18use ::re_types_core::{ComponentBatch as _, SerializedComponentBatch};
19use ::re_types_core::{ComponentDescriptor, ComponentType};
20use ::re_types_core::{DeserializationError, DeserializationResult};
21
22#[derive(Clone, Debug, Copy, PartialEq, PartialOrd, bytemuck::Pod, bytemuck::Zeroable)]
31#[repr(transparent)]
32pub struct Radius(pub crate::datatypes::Float32);
33
34impl ::re_types_core::Component for Radius {
35 #[inline]
36 fn name() -> ComponentType {
37 "rerun.components.Radius".into()
38 }
39}
40
41::re_types_core::macros::impl_into_cow!(Radius);
42
43impl ::re_types_core::Loggable for Radius {
44 #[inline]
45 fn arrow_datatype() -> arrow::datatypes::DataType {
46 crate::datatypes::Float32::arrow_datatype()
47 }
48
49 fn to_arrow_opt<'a>(
50 data: impl IntoIterator<Item = Option<impl Into<::std::borrow::Cow<'a, Self>>>>,
51 ) -> SerializationResult<arrow::array::ArrayRef>
52 where
53 Self: Clone + 'a,
54 {
55 crate::datatypes::Float32::to_arrow_opt(data.into_iter().map(|datum| {
56 datum.map(|datum| match datum.into() {
57 ::std::borrow::Cow::Borrowed(datum) => ::std::borrow::Cow::Borrowed(&datum.0),
58 ::std::borrow::Cow::Owned(datum) => ::std::borrow::Cow::Owned(datum.0),
59 })
60 }))
61 }
62
63 fn from_arrow_opt(
64 arrow_data: &dyn arrow::array::Array,
65 ) -> DeserializationResult<Vec<Option<Self>>>
66 where
67 Self: Sized,
68 {
69 crate::datatypes::Float32::from_arrow_opt(arrow_data)
70 .map(|v| v.into_iter().map(|v| v.map(Self)).collect())
71 }
72
73 #[inline]
74 fn from_arrow(arrow_data: &dyn arrow::array::Array) -> DeserializationResult<Vec<Self>>
75 where
76 Self: Sized,
77 {
78 crate::datatypes::Float32::from_arrow(arrow_data).map(bytemuck::cast_vec)
79 }
80}
81
82impl<T: Into<crate::datatypes::Float32>> From<T> for Radius {
83 fn from(v: T) -> Self {
84 Self(v.into())
85 }
86}
87
88impl std::borrow::Borrow<crate::datatypes::Float32> for Radius {
89 #[inline]
90 fn borrow(&self) -> &crate::datatypes::Float32 {
91 &self.0
92 }
93}
94
95impl std::ops::Deref for Radius {
96 type Target = crate::datatypes::Float32;
97
98 #[inline]
99 fn deref(&self) -> &crate::datatypes::Float32 {
100 &self.0
101 }
102}
103
104impl std::ops::DerefMut for Radius {
105 #[inline]
106 fn deref_mut(&mut self) -> &mut crate::datatypes::Float32 {
107 &mut self.0
108 }
109}
110
111impl ::re_byte_size::SizeBytes for Radius {
112 #[inline]
113 fn heap_size_bytes(&self) -> u64 {
114 self.0.heap_size_bytes()
115 }
116
117 #[inline]
118 fn is_pod() -> bool {
119 <crate::datatypes::Float32>::is_pod()
120 }
121}