From 3881d2ea381af0dfe86fb56d753e83163965ff8e Mon Sep 17 00:00:00 2001 From: Joshua Barretto Date: Mon, 9 May 2022 11:53:59 +0100 Subject: [PATCH] Fixed i16 underflow --- world/src/lib.rs | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/world/src/lib.rs b/world/src/lib.rs index 173a2b52ab..bcb98fed2e 100644 --- a/world/src/lib.rs +++ b/world/src/lib.rs @@ -484,20 +484,27 @@ impl World { .filter(|col| layer::tree::tree_valid_at(col, attr.seed)) .zip(Some(attr)) }) - .map(|(col, tree)| lod::Object { + .filter_map(|(col, tree)| Some(lod::Object { kind: match tree.forest_kind { all::ForestKind::Oak => lod::ObjectKind::Oak, all::ForestKind::Pine | all::ForestKind::Frostpine=> lod::ObjectKind::Pine, _ => lod::ObjectKind::Oak, }, - pos: (tree.pos - min_wpos) - .map(|e| e as u16) - .with_z(self.sim().get_alt_approx(tree.pos).unwrap_or(0.0) as u16), + pos: { + let rpos = tree.pos - min_wpos; + if rpos.is_any_negative() { + return None + } else { + rpos + .map(|e| e as u16) + .with_z(self.sim().get_alt_approx(tree.pos).unwrap_or(0.0) as u16) + } + }, flags: lod::Flags::empty() | if col.snow_cover { lod::Flags::SNOW_COVERED } else { lod::Flags::empty() } , - }) + })) .collect()); lod::Zone { objects }