From 4f299038104fb8062d395eae4887338303b08184 Mon Sep 17 00:00:00 2001 From: Clement Rey Date: Fri, 7 Jul 2023 13:18:00 +0200 Subject: [PATCH] codegen --- crates/re_types/source_hash.txt | 2 +- crates/re_types/src/archetypes/fuzzy.rs | 682 +++++- crates/re_types/src/components/fuzzy.rs | 2130 +++++++++++++++++ crates/re_types/src/components/mod.rs | 6 +- crates/re_types/src/datatypes/fuzzy.rs | 1797 ++++++++++++++ crates/re_types/src/datatypes/mod.rs | 2 +- .../rerun/_rerun2/archetypes/fuzzy.py | 72 + .../rerun/_rerun2/components/__init__.py | 34 + .../rerun/_rerun2/components/fuzzy.py | 480 ++++ .../rerun/_rerun2/datatypes/__init__.py | 20 + .../rerun/_rerun2/datatypes/fuzzy.py | 323 +++ 11 files changed, 5540 insertions(+), 8 deletions(-) diff --git a/crates/re_types/source_hash.txt b/crates/re_types/source_hash.txt index 110c8e2e9d472..0a6a9ddcf0453 100644 --- a/crates/re_types/source_hash.txt +++ b/crates/re_types/source_hash.txt @@ -1,4 +1,4 @@ # This is a sha256 hash for all direct and indirect dependencies of this crate's build script. # It can be safely removed at anytime to force the build script to run again. # Check out build.rs to see how it's computed. -e2fe09d197c4d6639e8e0025f54510043f32bc4c269bcb772f9196027de1ff8e \ No newline at end of file +ad9cf165b8bd298ef904c187aeb29a93a1d5681fe58ab93c278f73ce1684db20 \ No newline at end of file diff --git a/crates/re_types/src/archetypes/fuzzy.rs b/crates/re_types/src/archetypes/fuzzy.rs index 22609bed9f1b8..5fe8cdac01546 100644 --- a/crates/re_types/src/archetypes/fuzzy.rs +++ b/crates/re_types/src/archetypes/fuzzy.rs @@ -24,6 +24,10 @@ pub struct AffixFuzzer1 { pub fuzz1011: crate::components::AffixFuzzer11, pub fuzz1012: crate::components::AffixFuzzer12, pub fuzz1013: crate::components::AffixFuzzer13, + pub fuzz1014: crate::components::AffixFuzzer14, + pub fuzz1016: crate::components::AffixFuzzer16, + pub fuzz1017: crate::components::AffixFuzzer17, + pub fuzz1018: crate::components::AffixFuzzer18, pub fuzz1101: Vec, pub fuzz1102: Vec, pub fuzz1103: Vec, @@ -37,6 +41,10 @@ pub struct AffixFuzzer1 { pub fuzz1111: Vec, pub fuzz1112: Vec, pub fuzz1113: Vec, + pub fuzz1114: Vec, + pub fuzz1116: Vec, + pub fuzz1117: Vec, + pub fuzz1118: Vec, pub fuzz2001: Option, pub fuzz2002: Option, pub fuzz2003: Option, @@ -50,6 +58,10 @@ pub struct AffixFuzzer1 { pub fuzz2011: Option, pub fuzz2012: Option, pub fuzz2013: Option, + pub fuzz2014: Option, + pub fuzz2016: Option, + pub fuzz2017: Option, + pub fuzz2018: Option, pub fuzz2101: Option>, pub fuzz2102: Option>, pub fuzz2103: Option>, @@ -63,10 +75,14 @@ pub struct AffixFuzzer1 { pub fuzz2111: Option>, pub fuzz2112: Option>, pub fuzz2113: Option>, + pub fuzz2114: Option>, + pub fuzz2116: Option>, + pub fuzz2117: Option>, + pub fuzz2118: Option>, } impl AffixFuzzer1 { - pub const REQUIRED_COMPONENTS: [crate::ComponentName; 26usize] = [ + pub const REQUIRED_COMPONENTS: [crate::ComponentName; 34usize] = [ crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -80,6 +96,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -93,11 +113,15 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), ]; pub const RECOMMENDED_COMPONENTS: [crate::ComponentName; 0usize] = []; - pub const OPTIONAL_COMPONENTS: [crate::ComponentName; 26usize] = [ + pub const OPTIONAL_COMPONENTS: [crate::ComponentName; 34usize] = [ crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -111,6 +135,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -124,9 +152,13 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), ]; - pub const ALL_COMPONENTS: [crate::ComponentName; 52usize] = [ + pub const ALL_COMPONENTS: [crate::ComponentName; 68usize] = [ crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -140,6 +172,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -153,6 +189,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -166,6 +206,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer1"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer2"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer3"), @@ -179,6 +223,10 @@ impl AffixFuzzer1 { crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer11"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer12"), crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer13"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17"), + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18"), ]; } @@ -445,6 +493,78 @@ impl crate::Archetype for AffixFuzzer1 { }) .transpose()? }, + { + Some({ + let array = + ::try_to_arrow([&self.fuzz1014], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer14".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer14".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1014", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = + ::try_to_arrow([&self.fuzz1016], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer16".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer16".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1016", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = + ::try_to_arrow([&self.fuzz1017], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer17".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer17".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1017", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = + ::try_to_arrow([&self.fuzz1018], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer18".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer18".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1018", datatype, false), + array, + ) + }) + }) + .transpose()? + }, { Some({ let array = @@ -687,6 +807,86 @@ impl crate::Archetype for AffixFuzzer1 { }) .transpose()? }, + { + Some({ + let array = ::try_to_arrow( + self.fuzz1114.iter(), + None, + ); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer14".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer14".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1114", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = ::try_to_arrow( + self.fuzz1116.iter(), + None, + ); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer16".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer16".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1116", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = ::try_to_arrow( + self.fuzz1117.iter(), + None, + ); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer17".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer17".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1117", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + Some({ + let array = ::try_to_arrow( + self.fuzz1118.iter(), + None, + ); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer18".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer18".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz1118", datatype, false), + array, + ) + }) + }) + .transpose()? + }, { self.fuzz2001 .as_ref() @@ -938,6 +1138,86 @@ impl crate::Archetype for AffixFuzzer1 { }) .transpose()? }, + { + self.fuzz2014 + .as_ref() + .map(|single| { + let array = + ::try_to_arrow([single], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer14".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer14".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2014", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2016 + .as_ref() + .map(|single| { + let array = + ::try_to_arrow([single], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer16".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer16".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2016", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2017 + .as_ref() + .map(|single| { + let array = + ::try_to_arrow([single], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer17".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer17".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2017", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2018 + .as_ref() + .map(|single| { + let array = + ::try_to_arrow([single], None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer18".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer18".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2018", datatype, false), + array, + ) + }) + }) + .transpose()? + }, { self.fuzz2101 .as_ref() @@ -1198,6 +1478,86 @@ impl crate::Archetype for AffixFuzzer1 { }) .transpose()? }, + { + self.fuzz2114 + .as_ref() + .map(|many| { + let array = + ::try_to_arrow(many.iter(), None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer14".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer14".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2114", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2116 + .as_ref() + .map(|many| { + let array = + ::try_to_arrow(many.iter(), None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer16".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer16".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2116", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2117 + .as_ref() + .map(|many| { + let array = + ::try_to_arrow(many.iter(), None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer17".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer17".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2117", datatype, false), + array, + ) + }) + }) + .transpose()? + }, + { + self.fuzz2118 + .as_ref() + .map(|many| { + let array = + ::try_to_arrow(many.iter(), None); + array.map(|array| { + let datatype = ::arrow2::datatypes::DataType::Extension( + "rerun.testing.components.AffixFuzzer18".into(), + Box::new(array.data_type().clone()), + Some("rerun.testing.components.AffixFuzzer18".into()), + ); + ( + ::arrow2::datatypes::Field::new("fuzz2118", datatype, false), + array, + ) + }) + }) + .transpose()? + }, ] .into_iter() .flatten() @@ -1395,6 +1755,62 @@ impl crate::Archetype for AffixFuzzer1 { datatype: ::arrow2::datatypes::DataType::Null, })? }; + let fuzz1014 = { + let array = arrays_by_name.get("fuzz1014").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })? + }; + let fuzz1016 = { + let array = arrays_by_name.get("fuzz1016").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })? + }; + let fuzz1017 = { + let array = arrays_by_name.get("fuzz1017").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })? + }; + let fuzz1018 = { + let array = arrays_by_name.get("fuzz1018").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })? + }; let fuzz1101 = { let array = arrays_by_name.get("fuzz1101").ok_or_else(|| { crate::DeserializationError::MissingData { @@ -1590,6 +2006,66 @@ impl crate::Archetype for AffixFuzzer1 { }) .collect::>>()? }; + let fuzz1114 = { + let array = arrays_by_name.get("fuzz1114").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()? + }; + let fuzz1116 = { + let array = arrays_by_name.get("fuzz1116").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()? + }; + let fuzz1117 = { + let array = arrays_by_name.get("fuzz1117").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()? + }; + let fuzz1118 = { + let array = arrays_by_name.get("fuzz1118").ok_or_else(|| { + crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + } + })?; + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()? + }; let fuzz2001 = if let Some(array) = arrays_by_name.get("fuzz2001") { Some( ::try_from_arrow_opt(&**array)? @@ -1759,6 +2235,58 @@ impl crate::Archetype for AffixFuzzer1 { } else { None }; + let fuzz2014 = if let Some(array) = arrays_by_name.get("fuzz2014") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })?, + ) + } else { + None + }; + let fuzz2016 = if let Some(array) = arrays_by_name.get("fuzz2016") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })?, + ) + } else { + None + }; + let fuzz2017 = if let Some(array) = arrays_by_name.get("fuzz2017") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })?, + ) + } else { + None + }; + let fuzz2018 = if let Some(array) = arrays_by_name.get("fuzz2018") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .next() + .flatten() + .ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + })?, + ) + } else { + None + }; let fuzz2101 = if let Some(array) = arrays_by_name.get("fuzz2101") { Some( ::try_from_arrow_opt(&**array)? @@ -1941,6 +2469,62 @@ impl crate::Archetype for AffixFuzzer1 { } else { None }; + let fuzz2114 = if let Some(array) = arrays_by_name.get("fuzz2114") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()?, + ) + } else { + None + }; + let fuzz2116 = if let Some(array) = arrays_by_name.get("fuzz2116") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()?, + ) + } else { + None + }; + let fuzz2117 = if let Some(array) = arrays_by_name.get("fuzz2117") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()?, + ) + } else { + None + }; + let fuzz2118 = if let Some(array) = arrays_by_name.get("fuzz2118") { + Some( + ::try_from_arrow_opt(&**array)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: ::arrow2::datatypes::DataType::Null, + }) + }) + .collect::>>()?, + ) + } else { + None + }; Ok(Self { fuzz1001, fuzz1002, @@ -1955,6 +2539,10 @@ impl crate::Archetype for AffixFuzzer1 { fuzz1011, fuzz1012, fuzz1013, + fuzz1014, + fuzz1016, + fuzz1017, + fuzz1018, fuzz1101, fuzz1102, fuzz1103, @@ -1968,6 +2556,10 @@ impl crate::Archetype for AffixFuzzer1 { fuzz1111, fuzz1112, fuzz1113, + fuzz1114, + fuzz1116, + fuzz1117, + fuzz1118, fuzz2001, fuzz2002, fuzz2003, @@ -1981,6 +2573,10 @@ impl crate::Archetype for AffixFuzzer1 { fuzz2011, fuzz2012, fuzz2013, + fuzz2014, + fuzz2016, + fuzz2017, + fuzz2018, fuzz2101, fuzz2102, fuzz2103, @@ -1994,6 +2590,10 @@ impl crate::Archetype for AffixFuzzer1 { fuzz2111, fuzz2112, fuzz2113, + fuzz2114, + fuzz2116, + fuzz2117, + fuzz2118, }) } } @@ -2013,6 +2613,10 @@ impl AffixFuzzer1 { fuzz1011: impl Into, fuzz1012: impl Into, fuzz1013: impl Into, + fuzz1014: impl Into, + fuzz1016: impl Into, + fuzz1017: impl Into, + fuzz1018: impl Into, fuzz1101: impl IntoIterator>, fuzz1102: impl IntoIterator>, fuzz1103: impl IntoIterator>, @@ -2026,6 +2630,10 @@ impl AffixFuzzer1 { fuzz1111: impl IntoIterator>, fuzz1112: impl IntoIterator>, fuzz1113: impl IntoIterator>, + fuzz1114: impl IntoIterator>, + fuzz1116: impl IntoIterator>, + fuzz1117: impl IntoIterator>, + fuzz1118: impl IntoIterator>, ) -> Self { Self { fuzz1001: fuzz1001.into(), @@ -2041,6 +2649,10 @@ impl AffixFuzzer1 { fuzz1011: fuzz1011.into(), fuzz1012: fuzz1012.into(), fuzz1013: fuzz1013.into(), + fuzz1014: fuzz1014.into(), + fuzz1016: fuzz1016.into(), + fuzz1017: fuzz1017.into(), + fuzz1018: fuzz1018.into(), fuzz1101: fuzz1101.into_iter().map(Into::into).collect(), fuzz1102: fuzz1102.into_iter().map(Into::into).collect(), fuzz1103: fuzz1103.into_iter().map(Into::into).collect(), @@ -2054,6 +2666,10 @@ impl AffixFuzzer1 { fuzz1111: fuzz1111.into_iter().map(Into::into).collect(), fuzz1112: fuzz1112.into_iter().map(Into::into).collect(), fuzz1113: fuzz1113.into_iter().map(Into::into).collect(), + fuzz1114: fuzz1114.into_iter().map(Into::into).collect(), + fuzz1116: fuzz1116.into_iter().map(Into::into).collect(), + fuzz1117: fuzz1117.into_iter().map(Into::into).collect(), + fuzz1118: fuzz1118.into_iter().map(Into::into).collect(), fuzz2001: None, fuzz2002: None, fuzz2003: None, @@ -2067,6 +2683,10 @@ impl AffixFuzzer1 { fuzz2011: None, fuzz2012: None, fuzz2013: None, + fuzz2014: None, + fuzz2016: None, + fuzz2017: None, + fuzz2018: None, fuzz2101: None, fuzz2102: None, fuzz2103: None, @@ -2080,6 +2700,10 @@ impl AffixFuzzer1 { fuzz2111: None, fuzz2112: None, fuzz2113: None, + fuzz2114: None, + fuzz2116: None, + fuzz2117: None, + fuzz2118: None, } } @@ -2148,6 +2772,26 @@ impl AffixFuzzer1 { self } + pub fn with_fuzz2014(mut self, fuzz2014: impl Into) -> Self { + self.fuzz2014 = Some(fuzz2014.into()); + self + } + + pub fn with_fuzz2016(mut self, fuzz2016: impl Into) -> Self { + self.fuzz2016 = Some(fuzz2016.into()); + self + } + + pub fn with_fuzz2017(mut self, fuzz2017: impl Into) -> Self { + self.fuzz2017 = Some(fuzz2017.into()); + self + } + + pub fn with_fuzz2018(mut self, fuzz2018: impl Into) -> Self { + self.fuzz2018 = Some(fuzz2018.into()); + self + } + pub fn with_fuzz2101( mut self, fuzz2101: impl IntoIterator>, @@ -2251,4 +2895,36 @@ impl AffixFuzzer1 { self.fuzz2113 = Some(fuzz2113.into_iter().map(Into::into).collect()); self } + + pub fn with_fuzz2114( + mut self, + fuzz2114: impl IntoIterator>, + ) -> Self { + self.fuzz2114 = Some(fuzz2114.into_iter().map(Into::into).collect()); + self + } + + pub fn with_fuzz2116( + mut self, + fuzz2116: impl IntoIterator>, + ) -> Self { + self.fuzz2116 = Some(fuzz2116.into_iter().map(Into::into).collect()); + self + } + + pub fn with_fuzz2117( + mut self, + fuzz2117: impl IntoIterator>, + ) -> Self { + self.fuzz2117 = Some(fuzz2117.into_iter().map(Into::into).collect()); + self + } + + pub fn with_fuzz2118( + mut self, + fuzz2118: impl IntoIterator>, + ) -> Self { + self.fuzz2118 = Some(fuzz2118.into_iter().map(Into::into).collect()); + self + } } diff --git a/crates/re_types/src/components/fuzzy.rs b/crates/re_types/src/components/fuzzy.rs index 92d070bd0bd55..86dce356d09da 100644 --- a/crates/re_types/src/components/fuzzy.rs +++ b/crates/re_types/src/components/fuzzy.rs @@ -2333,3 +2333,2133 @@ impl crate::Component for AffixFuzzer13 { .collect::>>>()?) } } + +#[derive(Debug, Clone, PartialEq)] +pub struct AffixFuzzer14 { + pub single_required_union: crate::datatypes::AffixFuzzer3, +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer14> { + #[inline] + fn from(value: AffixFuzzer14) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer14> for ::std::borrow::Cow<'a, AffixFuzzer14> { + #[inline] + fn from(value: &'a AffixFuzzer14) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Component for AffixFuzzer14 { + #[inline] + fn name() -> crate::ComponentName { + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer14") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let (somes, single_required_union): (Vec<_>, Vec<_>) = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + let datum = datum.map(|datum| { + let Self { + single_required_union, + } = datum.into_owned(); + single_required_union + }); + (datum.is_some(), datum) + }) + .unzip(); + let single_required_union_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + _ = single_required_union_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + single_required_union, + Some("rerun.testing.components.AffixFuzzer14"), + )? + } + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok(crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: data.data_type().clone(), + }) + }) + .map(|res| { + res.map(|single_required_union| { + Some(Self { + single_required_union, + }) + }) + }) + .collect::>>>()?) + } +} + +#[derive(Debug, Clone, PartialEq)] +pub struct AffixFuzzer16 { + pub many_required_unions: Vec, +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer16> { + #[inline] + fn from(value: AffixFuzzer16) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer16> for ::std::borrow::Cow<'a, AffixFuzzer16> { + #[inline] + fn from(value: &'a AffixFuzzer16) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Component for AffixFuzzer16 { + #[inline] + fn name() -> crate::ComponentName { + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer16") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + })) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let (somes, many_required_unions): (Vec<_>, Vec<_>) = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + let datum = datum.map(|datum| { + let Self { + many_required_unions, + } = datum.into_owned(); + many_required_unions + }); + (datum.is_some(), datum) + }) + .unzip(); + let many_required_unions_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let many_required_unions_inner_data: Vec<_> = many_required_unions + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let many_required_unions_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = many_required_unions_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + many_required_unions_inner_data + .iter() + .map(|v| v.is_some()) + .collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + many_required_unions + .iter() + .map(|opt| opt.as_ref().map(|datum| datum.len()).unwrap_or_default()), + ) + .unwrap() + .into(); + ListArray::new( + { + _ = extension_wrapper; + DataType::Extension( + "rerun.testing.components.AffixFuzzer16".to_owned(), + Box::new(DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + )), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + }))), + None, + ) + .to_logical_type() + .clone() + }, + offsets, + { + _ = many_required_unions_inner_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + many_required_unions_inner_data, + Some("rerun.testing.components.AffixFuzzer16"), + )? + }, + many_required_unions_bitmap, + ) + .boxed() + } + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: data.data_type().clone(), + }) + }) + .map(|res| { + res.map(|many_required_unions| { + Some(Self { + many_required_unions, + }) + }) + }) + .collect::>>>()?) + } +} + +#[derive(Debug, Clone, PartialEq)] +pub struct AffixFuzzer17 { + pub many_optional_unions: Option>, +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer17> { + #[inline] + fn from(value: AffixFuzzer17) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer17> for ::std::borrow::Cow<'a, AffixFuzzer17> { + #[inline] + fn from(value: &'a AffixFuzzer17) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Component for AffixFuzzer17 { + #[inline] + fn name() -> crate::ComponentName { + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer17") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let (somes, many_optional_unions): (Vec<_>, Vec<_>) = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + let datum = datum + .map(|datum| { + let Self { + many_optional_unions, + } = datum.into_owned(); + many_optional_unions + }) + .flatten(); + (datum.is_some(), datum) + }) + .unzip(); + let many_optional_unions_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let many_optional_unions_inner_data: Vec<_> = many_optional_unions + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let many_optional_unions_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = many_optional_unions_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + many_optional_unions_inner_data + .iter() + .map(|v| v.is_some()) + .collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + many_optional_unions + .iter() + .map(|opt| opt.as_ref().map(|datum| datum.len()).unwrap_or_default()), + ) + .unwrap() + .into(); + ListArray::new( + { + _ = extension_wrapper; + DataType::Extension( + "rerun.testing.components.AffixFuzzer17".to_owned(), + Box::new(DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + )), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + }))), + None, + ) + .to_logical_type() + .clone() + }, + offsets, + { + _ = many_optional_unions_inner_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + many_optional_unions_inner_data, + Some("rerun.testing.components.AffixFuzzer17"), + )? + }, + many_optional_unions_bitmap, + ) + .boxed() + } + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .map(Ok) + .map(|res| { + res.map(|many_optional_unions| { + Some(Self { + many_optional_unions, + }) + }) + }) + .collect::>>>()?) + } +} + +#[derive(Debug, Clone, PartialEq)] +pub struct AffixFuzzer18 { + pub many_optional_unions: Option>, +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer18> { + #[inline] + fn from(value: AffixFuzzer18) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer18> for ::std::borrow::Cow<'a, AffixFuzzer18> { + #[inline] + fn from(value: &'a AffixFuzzer18) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Component for AffixFuzzer18 { + #[inline] + fn name() -> crate::ComponentName { + crate::ComponentName::Borrowed("rerun.testing.components.AffixFuzzer18") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "single_required".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let (somes, many_optional_unions): (Vec<_>, Vec<_>) = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + let datum = datum + .map(|datum| { + let Self { + many_optional_unions, + } = datum.into_owned(); + many_optional_unions + }) + .flatten(); + (datum.is_some(), datum) + }) + .unzip(); + let many_optional_unions_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let many_optional_unions_inner_data: Vec<_> = many_optional_unions + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let many_optional_unions_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = many_optional_unions_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + many_optional_unions_inner_data + .iter() + .map(|v| v.is_some()) + .collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + many_optional_unions + .iter() + .map(|opt| opt.as_ref().map(|datum| datum.len()).unwrap_or_default()), + ) + .unwrap() + .into(); + ListArray :: new ({ _ = extension_wrapper ; DataType :: Extension ("rerun.testing.components.AffixFuzzer18" . to_owned () , Box :: new (DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Union (vec ! [Field { name : "single_required" . to_owned () , data_type : DataType :: Union (vec ! [Field { name : "degrees" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "radians" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "craziness" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "single_float_optional" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "single_string_required" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "single_string_optional" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_floats_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_strings_required" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + , Field { name : "many_strings_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "flattened_scalar" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "almost_flattened_scalar" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "value" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + ,] , None , UnionMode :: Dense) , is_nullable : false , metadata : [] . into () , } + + , Field { name : "many_required" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Union (vec ! [Field { name : "degrees" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "radians" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "craziness" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "single_float_optional" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "single_string_required" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "single_string_optional" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_floats_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_strings_required" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + , Field { name : "many_strings_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "flattened_scalar" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "almost_flattened_scalar" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "value" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + ,] , None , UnionMode :: Dense) , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + , Field { name : "many_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Union (vec ! [Field { name : "degrees" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "radians" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "craziness" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "single_float_optional" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "single_string_required" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "single_string_optional" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_floats_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Float32 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "many_strings_required" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + , Field { name : "many_strings_optional" . to_owned () , data_type : DataType :: List (Box :: new (Field { name : "item" . to_owned () , data_type : DataType :: Utf8 , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : true , metadata : [] . into () , } + + , Field { name : "flattened_scalar" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + , Field { name : "almost_flattened_scalar" . to_owned () , data_type : DataType :: Struct (vec ! [Field { name : "value" . to_owned () , data_type : DataType :: Float32 , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + + ,]) , is_nullable : false , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + ,] , None , UnionMode :: Dense) , is_nullable : true , metadata : [] . into () , } + +)) , is_nullable : false , metadata : [] . into () , } + + ,] , None , UnionMode :: Dense) , is_nullable : true , metadata : [] . into () , } + +))) , None) . to_logical_type () . clone () } + + , offsets , { _ = many_optional_unions_inner_bitmap ; _ = extension_wrapper ; crate :: datatypes :: AffixFuzzer4 :: try_to_arrow_opt (many_optional_unions_inner_data , Some ("rerun.testing.components.AffixFuzzer18")) ? } + + , many_optional_unions_bitmap ,) . boxed () + } + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer4::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Union( + vec![ + Field { + name: "single_required".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional" + .to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required" + .to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + )), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional" + .to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar" + .to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional" + .to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: + DataType::Float32, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }), + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar" + .to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "value".to_owned(), + data_type: + DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional" + .to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: + DataType::Float32, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }), + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar" + .to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "value".to_owned(), + data_type: + DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .map(Ok) + .map(|res| { + res.map(|many_optional_unions| { + Some(Self { + many_optional_unions, + }) + }) + }) + .collect::>>>()?) + } +} diff --git a/crates/re_types/src/components/mod.rs b/crates/re_types/src/components/mod.rs index c78f73fde1c8b..2270c64ddc685 100644 --- a/crates/re_types/src/components/mod.rs +++ b/crates/re_types/src/components/mod.rs @@ -22,9 +22,9 @@ pub use self::class_id::ClassId; pub use self::color::Color; pub use self::draw_order::DrawOrder; pub use self::fuzzy::{ - AffixFuzzer1, AffixFuzzer10, AffixFuzzer11, AffixFuzzer12, AffixFuzzer13, AffixFuzzer2, - AffixFuzzer3, AffixFuzzer4, AffixFuzzer5, AffixFuzzer6, AffixFuzzer7, AffixFuzzer8, - AffixFuzzer9, + AffixFuzzer1, AffixFuzzer10, AffixFuzzer11, AffixFuzzer12, AffixFuzzer13, AffixFuzzer14, + AffixFuzzer16, AffixFuzzer17, AffixFuzzer18, AffixFuzzer2, AffixFuzzer3, AffixFuzzer4, + AffixFuzzer5, AffixFuzzer6, AffixFuzzer7, AffixFuzzer8, AffixFuzzer9, }; pub use self::instance_key::InstanceKey; pub use self::keypoint_id::KeypointId; diff --git a/crates/re_types/src/datatypes/fuzzy.rs b/crates/re_types/src/datatypes/fuzzy.rs index 8498243f1c7d6..dfbbe5b6c8ded 100644 --- a/crates/re_types/src/datatypes/fuzzy.rs +++ b/crates/re_types/src/datatypes/fuzzy.rs @@ -1150,3 +1150,1800 @@ impl crate::Datatype for AffixFuzzer2 { .collect::>>>()?) } } + +#[derive(Debug, Clone, PartialEq)] +pub enum AffixFuzzer3 { + Degrees(f32), + Radians(Option), + Craziness(Vec), +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer3> { + #[inline] + fn from(value: AffixFuzzer3) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer3> for ::std::borrow::Cow<'a, AffixFuzzer3> { + #[inline] + fn from(value: &'a AffixFuzzer3) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Datatype for AffixFuzzer3 { + #[inline] + fn name() -> crate::DatatypeName { + crate::DatatypeName::Borrowed("rerun.testing.datatypes.AffixFuzzer3") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let data: Vec<_> = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + datum + }) + .collect(); + UnionArray::new( + (if let Some(ext) = extension_wrapper { + DataType::Extension( + ext.to_owned(), + Box::new(::to_arrow_datatype()), + None, + ) + } else { + ::to_arrow_datatype() + }) + .to_logical_type() + .clone(), + { + data.iter() + .flatten() + .map(|v| match **v { + AffixFuzzer3::Degrees(_) => 0i8, + AffixFuzzer3::Radians(_) => 1i8, + AffixFuzzer3::Craziness(_) => 2i8, + }) + .collect() + }, + vec![ + { + let (somes, degrees): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer3::Degrees(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer3::Degrees(v) => Some(v.clone()), + _ => None, + }; + (datum.is_some(), datum) + }) + .unzip(); + let degrees_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + PrimitiveArray::new( + { + _ = extension_wrapper; + DataType::Float32.to_logical_type().clone() + }, + degrees.into_iter().map(|v| v.unwrap_or_default()).collect(), + degrees_bitmap, + ) + .boxed() + }, + { + let (somes, radians): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer3::Radians(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer3::Radians(v) => Some(v.clone()), + _ => None, + } + .flatten(); + (datum.is_some(), datum) + }) + .unzip(); + let radians_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + PrimitiveArray::new( + { + _ = extension_wrapper; + DataType::Float32.to_logical_type().clone() + }, + radians.into_iter().map(|v| v.unwrap_or_default()).collect(), + radians_bitmap, + ) + .boxed() + }, + { + let (somes, craziness): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer3::Craziness(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer3::Craziness(v) => Some(v.clone()), + _ => None, + }; + (datum.is_some(), datum) + }) + .unzip(); + let craziness_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let craziness_inner_data: Vec<_> = craziness + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let craziness_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = craziness_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + craziness_inner_data.iter().map(|v| v.is_some()).collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + craziness.iter().map(|opt| { + opt.as_ref().map(|datum| datum.len()).unwrap_or_default() + }), + ) + .unwrap() + .into(); + ListArray::new( + { + _ = extension_wrapper; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })) + .to_logical_type() + .clone() + }, + offsets, + { + _ = craziness_inner_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer1::try_to_arrow_opt( + craziness_inner_data, + None::<&str>, + )? + }, + craziness_bitmap, + ) + .boxed() + } + }, + ], + Some({ + let mut degrees_offset = 0; + let mut radians_offset = 0; + let mut craziness_offset = 0; + data.iter() + .flatten() + .map(|v| match **v { + AffixFuzzer3::Degrees(_) => { + let offset = degrees_offset; + degrees_offset += 1; + offset + } + + AffixFuzzer3::Radians(_) => { + let offset = radians_offset; + radians_offset += 1; + offset + } + + AffixFuzzer3::Craziness(_) => { + let offset = craziness_offset; + craziness_offset += 1; + offset + } + }) + .collect() + }), + ) + .boxed() + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let data = data + .as_any() + .downcast_ref::<::arrow2::array::UnionArray>() + .ok_or_else(|| crate::DeserializationError::SchemaMismatch { + expected: data.data_type().clone(), + got: data.data_type().clone(), + })?; + let (data_types, data_arrays, data_offsets) = + (data.types(), data.fields(), data.offsets().unwrap()); + let degrees = { + let data = &*data_arrays[0usize]; + + data.as_any() + .downcast_ref::() + .unwrap() + .into_iter() + .map(|v| v.copied()) + .collect::>() + }; + let radians = { + let data = &*data_arrays[1usize]; + + data.as_any() + .downcast_ref::() + .unwrap() + .into_iter() + .map(|v| v.copied()) + .collect::>() + }; + let craziness = { + let data = &*data_arrays[2usize]; + + { + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer1::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| { + crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + } + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .collect::>() + }; + data_types + .iter() + .enumerate() + .map(|(i, typ)| { + let offset = data_offsets[i]; + + Ok(Some(match typ { + 0i8 => AffixFuzzer3::Degrees( + degrees + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: degrees.len(), + datatype: data.data_type().clone(), + })? + .clone() + .unwrap(), + ), + 1i8 => AffixFuzzer3::Radians( + radians + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: radians.len(), + datatype: data.data_type().clone(), + })? + .clone(), + ), + 2i8 => AffixFuzzer3::Craziness( + craziness + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: craziness.len(), + datatype: data.data_type().clone(), + })? + .clone() + .unwrap(), + ), + _ => unreachable!(), + })) + }) + .collect::>>()? + }) + } +} + +#[derive(Debug, Clone, PartialEq)] +pub enum AffixFuzzer4 { + SingleRequired(crate::datatypes::AffixFuzzer3), + ManyRequired(Vec), + ManyOptional(Option>), +} + +impl<'a> From for ::std::borrow::Cow<'a, AffixFuzzer4> { + #[inline] + fn from(value: AffixFuzzer4) -> Self { + std::borrow::Cow::Owned(value) + } +} + +impl<'a> From<&'a AffixFuzzer4> for ::std::borrow::Cow<'a, AffixFuzzer4> { + #[inline] + fn from(value: &'a AffixFuzzer4) -> Self { + std::borrow::Cow::Borrowed(value) + } +} + +impl crate::Datatype for AffixFuzzer4 { + #[inline] + fn name() -> crate::DatatypeName { + crate::DatatypeName::Borrowed("rerun.testing.datatypes.AffixFuzzer4") + } + + #[allow(unused_imports, clippy::wildcard_imports)] + #[inline] + fn to_arrow_datatype() -> arrow2::datatypes::DataType { + use ::arrow2::datatypes::*; + DataType::Union( + vec![ + Field { + name: "single_required".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + })), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_to_arrow_opt<'a>( + data: impl IntoIterator>>>, + extension_wrapper: Option<&str>, + ) -> crate::SerializationResult> + where + Self: Clone + 'a, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let data: Vec<_> = data + .into_iter() + .map(|datum| { + let datum: Option<::std::borrow::Cow<'a, Self>> = datum.map(Into::into); + datum + }) + .collect(); + UnionArray::new( + (if let Some(ext) = extension_wrapper { + DataType::Extension( + ext.to_owned(), + Box::new(::to_arrow_datatype()), + None, + ) + } else { + ::to_arrow_datatype() + }) + .to_logical_type() + .clone(), + { + data.iter() + .flatten() + .map(|v| match **v { + AffixFuzzer4::SingleRequired(_) => 0i8, + AffixFuzzer4::ManyRequired(_) => 1i8, + AffixFuzzer4::ManyOptional(_) => 2i8, + }) + .collect() + }, + vec![ + { + let (somes, single_required): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer4::SingleRequired(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer4::SingleRequired(v) => Some(v.clone()), + _ => None, + }; + (datum.is_some(), datum) + }) + .unzip(); + let single_required_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + _ = single_required_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + single_required, + None::<&str>, + )? + } + }, + { + let (somes, many_required): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer4::ManyRequired(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer4::ManyRequired(v) => Some(v.clone()), + _ => None, + }; + (datum.is_some(), datum) + }) + .unzip(); + let many_required_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let many_required_inner_data: Vec<_> = many_required + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let many_required_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = + many_required_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + many_required_inner_data + .iter() + .map(|v| v.is_some()) + .collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + many_required.iter().map(|opt| { + opt.as_ref().map(|datum| datum.len()).unwrap_or_default() + }), + ) + .unwrap() + .into(); + ListArray::new( + { + _ = extension_wrapper; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional" + .to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: + DataType::Float32, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }), + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar" + .to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "value".to_owned(), + data_type: + DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: false, + metadata: [].into(), + })) + .to_logical_type() + .clone() + }, + offsets, + { + _ = many_required_inner_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + many_required_inner_data, + None::<&str>, + )? + }, + many_required_bitmap, + ) + .boxed() + } + }, + { + let (somes, many_optional): (Vec<_>, Vec<_>) = data + .iter() + .flatten() + .filter(|datum| matches!(***datum, AffixFuzzer4::ManyOptional(_))) + .map(|datum| { + let datum = match &**datum { + AffixFuzzer4::ManyOptional(v) => Some(v.clone()), + _ => None, + } + .flatten(); + (datum.is_some(), datum) + }) + .unzip(); + let many_optional_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = somes.iter().any(|some| !*some); + any_nones.then(|| somes.into()) + }; + { + use arrow2::{buffer::Buffer, offset::OffsetsBuffer}; + let many_optional_inner_data: Vec<_> = many_optional + .iter() + .flatten() + .flatten() + .map(ToOwned::to_owned) + .map(Some) + .collect(); + let many_optional_inner_bitmap: Option<::arrow2::bitmap::Bitmap> = { + let any_nones = + many_optional_inner_data.iter().any(|v| v.is_none()); + any_nones.then(|| { + many_optional_inner_data + .iter() + .map(|v| v.is_some()) + .collect() + }) + }; + let offsets = ::arrow2::offset::Offsets::::try_from_lengths( + many_optional.iter().map(|opt| { + opt.as_ref().map(|datum| datum.len()).unwrap_or_default() + }), + ) + .unwrap() + .into(); + ListArray::new( + { + _ = extension_wrapper; + DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional" + .to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional" + .to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: + DataType::Float32, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }), + ), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional" + .to_owned(), + data_type: DataType::List( + Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }), + ), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar" + .to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "value".to_owned(), + data_type: + DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + is_nullable: true, + metadata: [].into(), + })) + .to_logical_type() + .clone() + }, + offsets, + { + _ = many_optional_inner_bitmap; + _ = extension_wrapper; + crate::datatypes::AffixFuzzer3::try_to_arrow_opt( + many_optional_inner_data, + None::<&str>, + )? + }, + many_optional_bitmap, + ) + .boxed() + } + }, + ], + Some({ + let mut single_required_offset = 0; + let mut many_required_offset = 0; + let mut many_optional_offset = 0; + data.iter() + .flatten() + .map(|v| match **v { + AffixFuzzer4::SingleRequired(_) => { + let offset = single_required_offset; + single_required_offset += 1; + offset + } + + AffixFuzzer4::ManyRequired(_) => { + let offset = many_required_offset; + many_required_offset += 1; + offset + } + + AffixFuzzer4::ManyOptional(_) => { + let offset = many_optional_offset; + many_optional_offset += 1; + offset + } + }) + .collect() + }), + ) + .boxed() + }) + } + + #[allow(unused_imports, clippy::wildcard_imports)] + fn try_from_arrow_opt( + data: &dyn ::arrow2::array::Array, + ) -> crate::DeserializationResult>> + where + Self: Sized, + { + use crate::{Component as _, Datatype as _}; + use ::arrow2::{array::*, datatypes::*}; + Ok({ + let data = data + .as_any() + .downcast_ref::<::arrow2::array::UnionArray>() + .ok_or_else(|| crate::DeserializationError::SchemaMismatch { + expected: data.data_type().clone(), + got: data.data_type().clone(), + })?; + let (data_types, data_arrays, data_offsets) = + (data.types(), data.fields(), data.offsets().unwrap()); + let single_required = { + let data = &*data_arrays[0usize]; + + crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .collect::>() + }; + let many_required = { + let data = &*data_arrays[1usize]; + + { + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + )), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| { + crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + } + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .collect::>() + }; + let many_optional = { + let data = &*data_arrays[2usize]; + + { + let datatype = data.data_type(); + let data = data + .as_any() + .downcast_ref::<::arrow2::array::ListArray>() + .unwrap(); + let bitmap = data.validity().cloned(); + let offsets = { + let offsets = data.offsets(); + offsets.iter().copied().zip(offsets.iter().copied().skip(1)) + }; + let data = &**data.values(); + let data = crate::datatypes::AffixFuzzer3::try_from_arrow_opt(data)? + .into_iter() + .map(|v| { + v.ok_or_else(|| crate::DeserializationError::MissingData { + datatype: DataType::Union( + vec![ + Field { + name: "degrees".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "radians".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "craziness".to_owned(), + data_type: DataType::List(Box::new(Field { + name: "item".to_owned(), + data_type: DataType::Struct(vec![ + Field { + name: "single_float_optional".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "single_string_required".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "single_string_optional".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_floats_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Float32, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "many_strings_required".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: false, + metadata: [].into(), + }, + )), + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "many_strings_optional".to_owned(), + data_type: DataType::List(Box::new( + Field { + name: "item".to_owned(), + data_type: DataType::Utf8, + is_nullable: true, + metadata: [].into(), + }, + )), + is_nullable: true, + metadata: [].into(), + }, + Field { + name: "flattened_scalar".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }, + Field { + name: "almost_flattened_scalar".to_owned(), + data_type: DataType::Struct(vec![Field { + name: "value".to_owned(), + data_type: DataType::Float32, + is_nullable: false, + metadata: [].into(), + }]), + is_nullable: false, + metadata: [].into(), + }, + ]), + is_nullable: false, + metadata: [].into(), + })), + is_nullable: false, + metadata: [].into(), + }, + ], + None, + UnionMode::Dense, + ), + }) + }) + .collect::>>()?; + offsets + .enumerate() + .map(move |(i, (start, end))| { + bitmap + .as_ref() + .map_or(true, |bitmap| bitmap.get_bit(i)) + .then(|| { + Ok(data + .get(start as usize..end as usize) + .ok_or_else(|| { + crate::DeserializationError::OffsetsMismatch { + bounds: (start as usize, end as usize), + len: data.len(), + datatype: datatype.clone(), + } + })? + .to_vec()) + }) + .transpose() + }) + .collect::>>>()? + .into_iter() + } + .collect::>() + }; + data_types + .iter() + .enumerate() + .map(|(i, typ)| { + let offset = data_offsets[i]; + + Ok(Some(match typ { + 0i8 => AffixFuzzer4::SingleRequired( + single_required + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: single_required.len(), + datatype: data.data_type().clone(), + })? + .clone() + .unwrap(), + ), + 1i8 => AffixFuzzer4::ManyRequired( + many_required + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: many_required.len(), + datatype: data.data_type().clone(), + })? + .clone() + .unwrap(), + ), + 2i8 => AffixFuzzer4::ManyOptional( + many_optional + .get(offset as usize) + .ok_or_else(|| crate::DeserializationError::OffsetsMismatch { + bounds: (offset as usize, offset as usize), + len: many_optional.len(), + datatype: data.data_type().clone(), + })? + .clone(), + ), + _ => unreachable!(), + })) + }) + .collect::>>()? + }) + } +} diff --git a/crates/re_types/src/datatypes/mod.rs b/crates/re_types/src/datatypes/mod.rs index 57ee71907bf6c..6cd583697d699 100644 --- a/crates/re_types/src/datatypes/mod.rs +++ b/crates/re_types/src/datatypes/mod.rs @@ -6,6 +6,6 @@ mod point2d_ext; mod vec2d; mod vec2d_ext; -pub use self::fuzzy::{AffixFuzzer1, AffixFuzzer2, FlattenedScalar}; +pub use self::fuzzy::{AffixFuzzer1, AffixFuzzer2, AffixFuzzer3, AffixFuzzer4, FlattenedScalar}; pub use self::point2d::Point2D; pub use self::vec2d::Vec2D; diff --git a/rerun_py/rerun_sdk/rerun/_rerun2/archetypes/fuzzy.py b/rerun_py/rerun_sdk/rerun/_rerun2/archetypes/fuzzy.py index ce6276757eaa4..1546e3cbffdfe 100644 --- a/rerun_py/rerun_sdk/rerun/_rerun2/archetypes/fuzzy.py +++ b/rerun_py/rerun_sdk/rerun/_rerun2/archetypes/fuzzy.py @@ -66,6 +66,22 @@ class AffixFuzzer1(Archetype): metadata={"component": "primary"}, converter=components.AffixFuzzer13Array.from_similar, # type: ignore[misc] ) + fuzz1014: components.AffixFuzzer14Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer14Array.from_similar, # type: ignore[misc] + ) + fuzz1016: components.AffixFuzzer16Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer16Array.from_similar, # type: ignore[misc] + ) + fuzz1017: components.AffixFuzzer17Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer17Array.from_similar, # type: ignore[misc] + ) + fuzz1018: components.AffixFuzzer18Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer18Array.from_similar, # type: ignore[misc] + ) fuzz1101: components.AffixFuzzer1Array = field( metadata={"component": "primary"}, converter=components.AffixFuzzer1Array.from_similar, # type: ignore[misc] @@ -118,6 +134,22 @@ class AffixFuzzer1(Archetype): metadata={"component": "primary"}, converter=components.AffixFuzzer13Array.from_similar, # type: ignore[misc] ) + fuzz1114: components.AffixFuzzer14Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer14Array.from_similar, # type: ignore[misc] + ) + fuzz1116: components.AffixFuzzer16Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer16Array.from_similar, # type: ignore[misc] + ) + fuzz1117: components.AffixFuzzer17Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer17Array.from_similar, # type: ignore[misc] + ) + fuzz1118: components.AffixFuzzer18Array = field( + metadata={"component": "primary"}, + converter=components.AffixFuzzer18Array.from_similar, # type: ignore[misc] + ) fuzz2001: components.AffixFuzzer1Array | None = field( metadata={"component": "secondary"}, default=None, @@ -183,6 +215,26 @@ class AffixFuzzer1(Archetype): default=None, converter=components.AffixFuzzer13Array.from_similar, # type: ignore[misc] ) + fuzz2014: components.AffixFuzzer14Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer14Array.from_similar, # type: ignore[misc] + ) + fuzz2016: components.AffixFuzzer16Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer16Array.from_similar, # type: ignore[misc] + ) + fuzz2017: components.AffixFuzzer17Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer17Array.from_similar, # type: ignore[misc] + ) + fuzz2018: components.AffixFuzzer18Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer18Array.from_similar, # type: ignore[misc] + ) fuzz2101: components.AffixFuzzer1Array | None = field( metadata={"component": "secondary"}, default=None, @@ -248,5 +300,25 @@ class AffixFuzzer1(Archetype): default=None, converter=components.AffixFuzzer13Array.from_similar, # type: ignore[misc] ) + fuzz2114: components.AffixFuzzer14Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer14Array.from_similar, # type: ignore[misc] + ) + fuzz2116: components.AffixFuzzer16Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer16Array.from_similar, # type: ignore[misc] + ) + fuzz2117: components.AffixFuzzer17Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer17Array.from_similar, # type: ignore[misc] + ) + fuzz2118: components.AffixFuzzer18Array | None = field( + metadata={"component": "secondary"}, + default=None, + converter=components.AffixFuzzer18Array.from_similar, # type: ignore[misc] + ) __str__ = Archetype.__str__ __repr__ = Archetype.__repr__ diff --git a/rerun_py/rerun_sdk/rerun/_rerun2/components/__init__.py b/rerun_py/rerun_sdk/rerun/_rerun2/components/__init__.py index 2f3c5b4701d45..e3fb8b3e5be71 100644 --- a/rerun_py/rerun_sdk/rerun/_rerun2/components/__init__.py +++ b/rerun_py/rerun_sdk/rerun/_rerun2/components/__init__.py @@ -53,6 +53,23 @@ AffixFuzzer13ArrayLike, AffixFuzzer13Like, AffixFuzzer13Type, + AffixFuzzer14Array, + AffixFuzzer14Type, + AffixFuzzer16, + AffixFuzzer16Array, + AffixFuzzer16ArrayLike, + AffixFuzzer16Like, + AffixFuzzer16Type, + AffixFuzzer17, + AffixFuzzer17Array, + AffixFuzzer17ArrayLike, + AffixFuzzer17Like, + AffixFuzzer17Type, + AffixFuzzer18, + AffixFuzzer18Array, + AffixFuzzer18ArrayLike, + AffixFuzzer18Like, + AffixFuzzer18Type, ) from .instance_key import InstanceKey, InstanceKeyArray, InstanceKeyArrayLike, InstanceKeyLike, InstanceKeyType from .keypoint_id import KeypointId, KeypointIdArray, KeypointIdArrayLike, KeypointIdLike, KeypointIdType @@ -81,6 +98,23 @@ "AffixFuzzer13ArrayLike", "AffixFuzzer13Like", "AffixFuzzer13Type", + "AffixFuzzer14Array", + "AffixFuzzer14Type", + "AffixFuzzer16", + "AffixFuzzer16Array", + "AffixFuzzer16ArrayLike", + "AffixFuzzer16Like", + "AffixFuzzer16Type", + "AffixFuzzer17", + "AffixFuzzer17Array", + "AffixFuzzer17ArrayLike", + "AffixFuzzer17Like", + "AffixFuzzer17Type", + "AffixFuzzer18", + "AffixFuzzer18Array", + "AffixFuzzer18ArrayLike", + "AffixFuzzer18Like", + "AffixFuzzer18Type", "AffixFuzzer1Array", "AffixFuzzer1Type", "AffixFuzzer2Array", diff --git a/rerun_py/rerun_sdk/rerun/_rerun2/components/fuzzy.py b/rerun_py/rerun_sdk/rerun/_rerun2/components/fuzzy.py index 734bce377269c..738cd66f05c1f 100644 --- a/rerun_py/rerun_sdk/rerun/_rerun2/components/fuzzy.py +++ b/rerun_py/rerun_sdk/rerun/_rerun2/components/fuzzy.py @@ -41,6 +41,23 @@ "AffixFuzzer13ArrayLike", "AffixFuzzer13Like", "AffixFuzzer13Type", + "AffixFuzzer14Array", + "AffixFuzzer14Type", + "AffixFuzzer16", + "AffixFuzzer16Array", + "AffixFuzzer16ArrayLike", + "AffixFuzzer16Like", + "AffixFuzzer16Type", + "AffixFuzzer17", + "AffixFuzzer17Array", + "AffixFuzzer17ArrayLike", + "AffixFuzzer17Like", + "AffixFuzzer17Type", + "AffixFuzzer18", + "AffixFuzzer18Array", + "AffixFuzzer18ArrayLike", + "AffixFuzzer18Like", + "AffixFuzzer18Type", "AffixFuzzer1Array", "AffixFuzzer1Type", "AffixFuzzer2Array", @@ -464,3 +481,466 @@ def _native_to_pa_array(data: AffixFuzzer13ArrayLike, data_type: pa.DataType) -> # TODO(cmc): bring back registration to pyarrow once legacy types are gone # pa.register_extension_type(AffixFuzzer13Type()) + + +class AffixFuzzer14Type(BaseDelegatingExtensionType): + _TYPE_NAME = "rerun.testing.components.AffixFuzzer14" + _DELEGATED_EXTENSION_TYPE = datatypes.AffixFuzzer3Type + + +class AffixFuzzer14Array(BaseDelegatingExtensionArray[datatypes.AffixFuzzer3ArrayLike]): + _EXTENSION_NAME = "rerun.testing.components.AffixFuzzer14" + _EXTENSION_TYPE = AffixFuzzer14Type + _DELEGATED_ARRAY_TYPE = datatypes.AffixFuzzer3Array + + +AffixFuzzer14Type._ARRAY_TYPE = AffixFuzzer14Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer14Type()) + + +@define +class AffixFuzzer16: + many_required_unions: list[datatypes.AffixFuzzer3] = field() + + +AffixFuzzer16Like = AffixFuzzer16 +AffixFuzzer16ArrayLike = Union[ + AffixFuzzer16, + Sequence[AffixFuzzer16Like], +] + + +# --- Arrow support --- + + +class AffixFuzzer16Type(BaseExtensionType): + def __init__(self) -> None: + pa.ExtensionType.__init__( + self, + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + "rerun.testing.components.AffixFuzzer16", + ) + + +class AffixFuzzer16Array(BaseExtensionArray[AffixFuzzer16ArrayLike]): + _EXTENSION_NAME = "rerun.testing.components.AffixFuzzer16" + _EXTENSION_TYPE = AffixFuzzer16Type + + @staticmethod + def _native_to_pa_array(data: AffixFuzzer16ArrayLike, data_type: pa.DataType) -> pa.Array: + raise NotImplementedError + + +AffixFuzzer16Type._ARRAY_TYPE = AffixFuzzer16Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer16Type()) + + +@define +class AffixFuzzer17: + many_optional_unions: list[datatypes.AffixFuzzer3] | None = field(default=None) + + +AffixFuzzer17Like = AffixFuzzer17 +AffixFuzzer17ArrayLike = Union[ + AffixFuzzer17, + Sequence[AffixFuzzer17Like], +] + + +# --- Arrow support --- + + +class AffixFuzzer17Type(BaseExtensionType): + def __init__(self) -> None: + pa.ExtensionType.__init__( + self, + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + True, + {}, + ) + ), + "rerun.testing.components.AffixFuzzer17", + ) + + +class AffixFuzzer17Array(BaseExtensionArray[AffixFuzzer17ArrayLike]): + _EXTENSION_NAME = "rerun.testing.components.AffixFuzzer17" + _EXTENSION_TYPE = AffixFuzzer17Type + + @staticmethod + def _native_to_pa_array(data: AffixFuzzer17ArrayLike, data_type: pa.DataType) -> pa.Array: + raise NotImplementedError + + +AffixFuzzer17Type._ARRAY_TYPE = AffixFuzzer17Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer17Type()) + + +@define +class AffixFuzzer18: + many_optional_unions: list[datatypes.AffixFuzzer4] | None = field(default=None) + + +AffixFuzzer18Like = AffixFuzzer18 +AffixFuzzer18ArrayLike = Union[ + AffixFuzzer18, + Sequence[AffixFuzzer18Like], +] + + +# --- Arrow support --- + + +class AffixFuzzer18Type(BaseExtensionType): + def __init__(self) -> None: + pa.ExtensionType.__init__( + self, + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field( + "single_required", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + False, + {}, + ), + pa.field( + "many_required", + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field( + "single_float_optional", pa.float32(), True, {} + ), + pa.field( + "single_string_required", pa.utf8(), False, {} + ), + pa.field( + "single_string_optional", pa.utf8(), True, {} + ), + pa.field( + "many_floats_optional", + pa.list_( + pa.field("item", pa.float32(), True, {}) + ), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_( + pa.field("item", pa.utf8(), False, {}) + ), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field( + "flattened_scalar", pa.float32(), False, {} + ), + pa.field( + "almost_flattened_scalar", + pa.struct( + [pa.field("value", pa.float32(), False, {})] + ), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + pa.field( + "many_optional", + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field( + "single_float_optional", pa.float32(), True, {} + ), + pa.field( + "single_string_required", pa.utf8(), False, {} + ), + pa.field( + "single_string_optional", pa.utf8(), True, {} + ), + pa.field( + "many_floats_optional", + pa.list_( + pa.field("item", pa.float32(), True, {}) + ), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_( + pa.field("item", pa.utf8(), False, {}) + ), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field( + "flattened_scalar", pa.float32(), False, {} + ), + pa.field( + "almost_flattened_scalar", + pa.struct( + [pa.field("value", pa.float32(), False, {})] + ), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + True, + {}, + ) + ), + False, + {}, + ), + ] + ), + True, + {}, + ) + ), + "rerun.testing.components.AffixFuzzer18", + ) + + +class AffixFuzzer18Array(BaseExtensionArray[AffixFuzzer18ArrayLike]): + _EXTENSION_NAME = "rerun.testing.components.AffixFuzzer18" + _EXTENSION_TYPE = AffixFuzzer18Type + + @staticmethod + def _native_to_pa_array(data: AffixFuzzer18ArrayLike, data_type: pa.DataType) -> pa.Array: + raise NotImplementedError + + +AffixFuzzer18Type._ARRAY_TYPE = AffixFuzzer18Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer18Type()) diff --git a/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/__init__.py b/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/__init__.py index 6881e833958a8..a841548e06bd4 100644 --- a/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/__init__.py +++ b/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/__init__.py @@ -13,6 +13,16 @@ AffixFuzzer2ArrayLike, AffixFuzzer2Like, AffixFuzzer2Type, + AffixFuzzer3, + AffixFuzzer3Array, + AffixFuzzer3ArrayLike, + AffixFuzzer3Like, + AffixFuzzer3Type, + AffixFuzzer4, + AffixFuzzer4Array, + AffixFuzzer4ArrayLike, + AffixFuzzer4Like, + AffixFuzzer4Type, FlattenedScalar, FlattenedScalarArray, FlattenedScalarArrayLike, @@ -33,6 +43,16 @@ "AffixFuzzer2ArrayLike", "AffixFuzzer2Like", "AffixFuzzer2Type", + "AffixFuzzer3", + "AffixFuzzer3Array", + "AffixFuzzer3ArrayLike", + "AffixFuzzer3Like", + "AffixFuzzer3Type", + "AffixFuzzer4", + "AffixFuzzer4Array", + "AffixFuzzer4ArrayLike", + "AffixFuzzer4Like", + "AffixFuzzer4Type", "FlattenedScalar", "FlattenedScalarArray", "FlattenedScalarArrayLike", diff --git a/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/fuzzy.py b/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/fuzzy.py index 6a69a09ed79a6..9428ae131a660 100644 --- a/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/fuzzy.py +++ b/rerun_py/rerun_sdk/rerun/_rerun2/datatypes/fuzzy.py @@ -29,6 +29,16 @@ "AffixFuzzer2ArrayLike", "AffixFuzzer2Like", "AffixFuzzer2Type", + "AffixFuzzer3", + "AffixFuzzer3Array", + "AffixFuzzer3ArrayLike", + "AffixFuzzer3Like", + "AffixFuzzer3Type", + "AffixFuzzer4", + "AffixFuzzer4Array", + "AffixFuzzer4ArrayLike", + "AffixFuzzer4Like", + "AffixFuzzer4Type", "FlattenedScalar", "FlattenedScalarArray", "FlattenedScalarArrayLike", @@ -175,3 +185,316 @@ def _native_to_pa_array(data: AffixFuzzer2ArrayLike, data_type: pa.DataType) -> # TODO(cmc): bring back registration to pyarrow once legacy types are gone # pa.register_extension_type(AffixFuzzer2Type()) + + +@define +class AffixFuzzer4: + single_required: datatypes.AffixFuzzer3 | None = None + many_required: list[datatypes.AffixFuzzer3] | None = None + many_optional: list[datatypes.AffixFuzzer3] | None = None + + +AffixFuzzer4Like = AffixFuzzer4 +AffixFuzzer4ArrayLike = Union[ + AffixFuzzer4, + Sequence[AffixFuzzer4Like], +] + + +# --- Arrow support --- + + +class AffixFuzzer4Type(BaseExtensionType): + def __init__(self) -> None: + pa.ExtensionType.__init__( + self, + pa.dense_union( + [ + pa.field( + "single_required", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + False, + {}, + ), + pa.field( + "many_required", + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + pa.field( + "many_optional", + pa.list_( + pa.field( + "item", + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + True, + {}, + ) + ), + False, + {}, + ), + ] + ), + "rerun.testing.datatypes.AffixFuzzer4", + ) + + +class AffixFuzzer4Array(BaseExtensionArray[AffixFuzzer4ArrayLike]): + _EXTENSION_NAME = "rerun.testing.datatypes.AffixFuzzer4" + _EXTENSION_TYPE = AffixFuzzer4Type + + @staticmethod + def _native_to_pa_array(data: AffixFuzzer4ArrayLike, data_type: pa.DataType) -> pa.Array: + raise NotImplementedError + + +AffixFuzzer4Type._ARRAY_TYPE = AffixFuzzer4Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer4Type()) + + +@define +class AffixFuzzer3: + degrees: float | None = None + radians: float | None = None + craziness: list[datatypes.AffixFuzzer1] | None = None + + +AffixFuzzer3Like = AffixFuzzer3 +AffixFuzzer3ArrayLike = Union[ + AffixFuzzer3, + Sequence[AffixFuzzer3Like], +] + + +# --- Arrow support --- + + +class AffixFuzzer3Type(BaseExtensionType): + def __init__(self) -> None: + pa.ExtensionType.__init__( + self, + pa.dense_union( + [ + pa.field("degrees", pa.float32(), False, {}), + pa.field("radians", pa.float32(), False, {}), + pa.field( + "craziness", + pa.list_( + pa.field( + "item", + pa.struct( + [ + pa.field("single_float_optional", pa.float32(), True, {}), + pa.field("single_string_required", pa.utf8(), False, {}), + pa.field("single_string_optional", pa.utf8(), True, {}), + pa.field( + "many_floats_optional", + pa.list_(pa.field("item", pa.float32(), True, {})), + True, + {}, + ), + pa.field( + "many_strings_required", + pa.list_(pa.field("item", pa.utf8(), False, {})), + False, + {}, + ), + pa.field( + "many_strings_optional", + pa.list_(pa.field("item", pa.utf8(), True, {})), + True, + {}, + ), + pa.field("flattened_scalar", pa.float32(), False, {}), + pa.field( + "almost_flattened_scalar", + pa.struct([pa.field("value", pa.float32(), False, {})]), + False, + {}, + ), + ] + ), + False, + {}, + ) + ), + False, + {}, + ), + ] + ), + "rerun.testing.datatypes.AffixFuzzer3", + ) + + +class AffixFuzzer3Array(BaseExtensionArray[AffixFuzzer3ArrayLike]): + _EXTENSION_NAME = "rerun.testing.datatypes.AffixFuzzer3" + _EXTENSION_TYPE = AffixFuzzer3Type + + @staticmethod + def _native_to_pa_array(data: AffixFuzzer3ArrayLike, data_type: pa.DataType) -> pa.Array: + raise NotImplementedError + + +AffixFuzzer3Type._ARRAY_TYPE = AffixFuzzer3Array + +# TODO(cmc): bring back registration to pyarrow once legacy types are gone +# pa.register_extension_type(AffixFuzzer3Type())