diff --git a/crates/valence_block/Cargo.toml b/crates/valence_block/Cargo.toml index 0a315df..c74b46d 100644 --- a/crates/valence_block/Cargo.toml +++ b/crates/valence_block/Cargo.toml @@ -6,6 +6,7 @@ edition.workspace = true [dependencies] valence_core.workspace = true anyhow.workspace = true +glam.workspace = true [build-dependencies] anyhow.workspace = true diff --git a/crates/valence_block/build.rs b/crates/valence_block/build.rs index 14b4d1d..a3d7829 100644 --- a/crates/valence_block/build.rs +++ b/crates/valence_block/build.rs @@ -161,14 +161,10 @@ fn build() -> anyhow::Result { let max_y = s.max_y; let max_z = s.max_z; quote! { - [ - #min_x, - #min_y, - #min_z, - #max_x, - #max_y, - #max_z, - ] + Aabb { + min: dvec3(#min_x, #min_y, #min_z), + max: dvec3(#max_x, #max_y, #max_z), + } } }); @@ -577,6 +573,9 @@ fn build() -> anyhow::Result { let prop_value_count = prop_values.len(); Ok(quote! { + use valence_core::aabb::Aabb; + use glam::dvec3; + /// Represents the state of a block. This does not include block entity data such as /// the text on a sign, the design on a banner, or the content of a spawner. #[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Default, Hash)] @@ -682,11 +681,11 @@ fn build() -> anyhow::Result { } } - const SHAPES: [[f64; 6]; #shape_count] = [ + const SHAPES: [Aabb; #shape_count] = [ #(#shapes,)* ]; - pub fn collision_shapes(self) -> impl ExactSizeIterator + FusedIterator + Clone { + pub fn collision_shapes(self) -> impl ExactSizeIterator + FusedIterator + Clone { let shape_idxs: &'static [u16] = match self.0 { #state_to_collision_shapes_arms _ => &[],