cargo fmt after updating new toolchain

This commit is contained in:
Marcel Märtens 2023-10-05 20:06:05 +02:00
parent cb25a409d5
commit 8e95cb944d
31 changed files with 163 additions and 168 deletions

View File

@ -1809,18 +1809,16 @@ impl Client {
// significant changes to this code. Here is the approximate order of // significant changes to this code. Here is the approximate order of
// things. Please update it as this code changes. // things. Please update it as this code changes.
// //
// 1) Collect input from the frontend, apply input effects to the state // 1) Collect input from the frontend, apply input effects to the state of the
// of the game // game
// 2) Handle messages from the server // 2) Handle messages from the server
// 3) Go through any events (timer-driven or otherwise) that need handling // 3) Go through any events (timer-driven or otherwise) that need handling and
// and apply them to the state of the game // apply them to the state of the game
// 4) Perform a single LocalState tick (i.e: update the world and entities // 4) Perform a single LocalState tick (i.e: update the world and entities in
// in the world) // the world)
// 5) Go through the terrain update queue and apply all changes // 5) Go through the terrain update queue and apply all changes to the terrain
// to the terrain
// 6) Sync information to the server // 6) Sync information to the server
// 7) Finish the tick, passing actions of the main thread back // 7) Finish the tick, passing actions of the main thread back to the frontend
// to the frontend
// 1) Handle input from frontend. // 1) Handle input from frontend.
// Pass character actions from frontend input to the player's entity. // Pass character actions from frontend input to the player's entity.

View File

@ -118,14 +118,17 @@ pub fn members<'a>(
) -> impl Iterator<Item = (specs::Entity, Role)> + 'a { ) -> impl Iterator<Item = (specs::Entity, Role)> + 'a {
(entities, groups, alignments, uids) (entities, groups, alignments, uids)
.join() .join()
.filter(move |&(_e, g, _a, _u)| (*g == group)).map(|(e, _g, a, u)| ( .filter(move |&(_e, g, _a, _u)| (*g == group))
e, .map(|(e, _g, a, u)| {
if matches!(a, Alignment::Owned(owner) if owner != u) { (
Role::Pet e,
} else { if matches!(a, Alignment::Owned(owner) if owner != u) {
Role::Member Role::Pet
}, } else {
)) Role::Member
},
)
})
} }
// TODO: optimize add/remove for massive NPC groups // TODO: optimize add/remove for massive NPC groups

View File

@ -121,16 +121,8 @@ impl Hands {
Hands::InHands((mainhand, offhand)) => { Hands::InHands((mainhand, offhand)) => {
let mut from_spec = |i: &ItemSpec| i.try_to_item(rng); let mut from_spec = |i: &ItemSpec| i.try_to_item(rng);
let mainhand = mainhand let mainhand = mainhand.as_ref().map(&mut from_spec).transpose()?.flatten();
.as_ref() let offhand = offhand.as_ref().map(&mut from_spec).transpose()?.flatten();
.map(&mut from_spec)
.transpose()?
.flatten();
let offhand = offhand
.as_ref()
.map(&mut from_spec)
.transpose()?
.flatten();
Ok((mainhand, offhand)) Ok((mainhand, offhand))
}, },
Hands::Choice(pairs) => { Hands::Choice(pairs) => {

View File

@ -133,8 +133,12 @@ pub fn distribute_many<T: Copy + Eq + Hash, I>(
let Some(mut give) = participants let Some(mut give) = participants
.iter() .iter()
.map(|participant| (total_item_amount as f32 * participant.weight / total_weight).ceil() as u32 - participant.recieved_count) .map(|participant| {
.min() else { (total_item_amount as f32 * participant.weight / total_weight).ceil() as u32
- participant.recieved_count
})
.min()
else {
tracing::error!("Tried to distribute items to no participants."); tracing::error!("Tried to distribute items to no participants.");
return; return;
}; };
@ -152,8 +156,7 @@ pub fn distribute_many<T: Copy + Eq + Hash, I>(
let participant_count = participants.len(); let participant_count = participants.len();
let Some(winner) = participants let Some(winner) = participants.get_mut(index) else {
.get_mut(index) else {
tracing::error!("Tried to distribute items to no participants."); tracing::error!("Tried to distribute items to no participants.");
return; return;
}; };

View File

@ -380,8 +380,9 @@ impl Link for VolumeMounting {
Volume::Terrain => &*terrain_riders, Volume::Terrain => &*terrain_riders,
Volume::Entity(uid) => { Volume::Entity(uid) => {
let Some(riders) = entity(uid) let Some(riders) = entity(uid)
.filter(|entity| is_alive(*entity)) .filter(|entity| is_alive(*entity))
.and_then(|entity| volume_riders.get(entity)) else { .and_then(|entity| volume_riders.get(entity))
else {
return false; return false;
}; };
riders riders

View File

@ -86,10 +86,10 @@ impl<V, S: VolSize, M> Chunk<V, S, M> {
// //
// Rationales: // Rationales:
// //
// 1. We have code in the implementation that assumes it. In particular, // 1. We have code in the implementation that assumes it. In particular, code
// code using `.count_ones()`. // using `.count_ones()`.
// 2. The maximum group size is `256x256x256`, because there's code that // 2. The maximum group size is `256x256x256`, because there's code that stores
// stores group relative indices as `u8`. // group relative indices as `u8`.
// 3. There's code that stores group indices as `u8`. // 3. There's code that stores group indices as `u8`.
debug_assert!(S::SIZE.x.is_power_of_two()); debug_assert!(S::SIZE.x.is_power_of_two());
debug_assert!(S::SIZE.y.is_power_of_two()); debug_assert!(S::SIZE.y.is_power_of_two());

View File

@ -84,7 +84,9 @@ pub(crate) fn wasi_fd_write(
let Ok(cio) = iov_addr let Ok(cio) = iov_addr
.add_offset(i) .add_offset(i)
.and_then(|p| p.read(&memory.view(&store))) .and_then(|p| p.read(&memory.view(&store)))
else { return Errno::Memviolation as i32; }; else {
return Errno::Memviolation as i32;
};
if let Err(e) = print_impl(env.data(), &store, cio.buf, cio.buf_len) { if let Err(e) = print_impl(env.data(), &store, cio.buf, cio.buf_len) {
return e as i32; return e as i32;
} }

View File

@ -53,27 +53,35 @@ impl<'a> System<'a> for Sys {
// For each mount... // For each mount...
for (entity, is_mount, body) in (&entities, &is_mounts, bodies.maybe()).join() { for (entity, is_mount, body) in (&entities, &is_mounts, bodies.maybe()).join() {
// ...find the rider... // ...find the rider...
let Some((inputs_and_actions, rider)) = id_maps let Some((inputs_and_actions, rider)) =
.uid_entity(is_mount.rider) id_maps.uid_entity(is_mount.rider).and_then(|rider| {
.and_then(|rider| { controllers.get_mut(rider).map(|c| {
controllers (
.get_mut(rider) // Only take inputs and actions from the rider if the mount is not
.map(|c| ( // intelligent (TODO: expand the definition of 'intelligent').
// Only take inputs and actions from the rider if the mount is not intelligent (TODO: expand the definition of 'intelligent').
if !matches!(body, Some(Body::Humanoid(_))) { if !matches!(body, Some(Body::Humanoid(_))) {
let actions = c.actions.extract_if(|action| match action { let actions = c
ControlAction::StartInput { input: i, .. } .actions
| ControlAction::CancelInput(i) => matches!(i, InputKind::Jump | InputKind::Fly | InputKind::Roll), .extract_if(|action| match action {
_ => false ControlAction::StartInput { input: i, .. }
}).collect(); | ControlAction::CancelInput(i) => matches!(
i,
InputKind::Jump | InputKind::Fly | InputKind::Roll
),
_ => false,
})
.collect();
Some((c.inputs.clone(), actions)) Some((c.inputs.clone(), actions))
} else { } else {
None None
}, },
rider, rider,
)) )
})
}) })
else { continue }; else {
continue;
};
// ...apply the mount's position/ori/velocity to the rider... // ...apply the mount's position/ori/velocity to the rider...
let pos = positions.get(entity).copied(); let pos = positions.get(entity).copied();

View File

@ -94,7 +94,9 @@ impl Data {
.faction .faction
.and_then(|f| this.factions.get(f)) .and_then(|f| this.factions.get(f))
.map(|f| f.good_or_evil) .map(|f| f.good_or_evil)
else { continue }; else {
continue;
};
let rand_wpos = |rng: &mut SmallRng, matches_plot: fn(&PlotKind) -> bool| { let rand_wpos = |rng: &mut SmallRng, matches_plot: fn(&PlotKind) -> bool| {
let wpos2d = site2 let wpos2d = site2
@ -257,18 +259,23 @@ impl Data {
let Some(species) = [ let Some(species) = [
Some(comp::body::biped_large::Species::Ogre), Some(comp::body::biped_large::Species::Ogre),
Some(comp::body::biped_large::Species::Cyclops), Some(comp::body::biped_large::Species::Cyclops),
Some(comp::body::biped_large::Species::Wendigo).filter(|_| biome == BiomeKind::Taiga), Some(comp::body::biped_large::Species::Wendigo)
.filter(|_| biome == BiomeKind::Taiga),
Some(comp::body::biped_large::Species::Cavetroll), Some(comp::body::biped_large::Species::Cavetroll),
Some(comp::body::biped_large::Species::Mountaintroll).filter(|_| biome == BiomeKind::Mountain), Some(comp::body::biped_large::Species::Mountaintroll)
Some(comp::body::biped_large::Species::Swamptroll).filter(|_| biome == BiomeKind::Swamp), .filter(|_| biome == BiomeKind::Mountain),
Some(comp::body::biped_large::Species::Swamptroll)
.filter(|_| biome == BiomeKind::Swamp),
Some(comp::body::biped_large::Species::Blueoni), Some(comp::body::biped_large::Species::Blueoni),
Some(comp::body::biped_large::Species::Redoni), Some(comp::body::biped_large::Species::Redoni),
Some(comp::body::biped_large::Species::Tursus).filter(|_| chunk.temp < CONFIG.snow_temp), Some(comp::body::biped_large::Species::Tursus)
.filter(|_| chunk.temp < CONFIG.snow_temp),
] ]
.into_iter() .into_iter()
.flatten() .flatten()
.choose(&mut rng) .choose(&mut rng) else {
else { continue }; continue;
};
this.npcs.create_npc(Npc::new( this.npcs.create_npc(Npc::new(
rng.gen(), rng.gen(),

View File

@ -2924,7 +2924,8 @@ impl<'a> AgentData<'a> {
{ {
agent.action_state.counters[FCounters::SummonThreshold as usize] -= agent.action_state.counters[FCounters::SummonThreshold as usize] -=
SUMMON_THRESHOLD; SUMMON_THRESHOLD;
agent.action_state.conditions[Conditions::AttackToggle as usize] = !agent.action_state.conditions[Conditions::AttackToggle as usize]; agent.action_state.conditions[Conditions::AttackToggle as usize] =
!agent.action_state.conditions[Conditions::AttackToggle as usize];
} }
} else { } else {
// If target is in melee range use flamecrush // If target is in melee range use flamecrush

View File

@ -4,13 +4,7 @@
clippy::needless_pass_by_ref_mut //until we find a better way for specs clippy::needless_pass_by_ref_mut //until we find a better way for specs
)] )]
#![deny(clippy::clone_on_ref_ptr)] #![deny(clippy::clone_on_ref_ptr)]
#![feature( #![feature(box_patterns, let_chains, never_type, option_zip, unwrap_infallible)]
box_patterns,
let_chains,
never_type,
option_zip,
unwrap_infallible
)]
pub mod automod; pub mod automod;
mod character_creator; mod character_creator;
@ -711,22 +705,20 @@ impl Server {
// significant changes to this code. Here is the approximate order of // significant changes to this code. Here is the approximate order of
// things. Please update it as this code changes. // things. Please update it as this code changes.
// //
// 1) Collect input from the frontend, apply input effects to the // 1) Collect input from the frontend, apply input effects to the state of the
// state of the game // game
// 2) Go through any events (timer-driven or otherwise) that need handling // 2) Go through any events (timer-driven or otherwise) that need handling and
// and apply them to the state of the game // apply them to the state of the game
// 3) Go through all incoming client network communications, apply them to // 3) Go through all incoming client network communications, apply them to the
// the game state // game state
// 4) Perform a single LocalState tick (i.e: update the world and entities // 4) Perform a single LocalState tick (i.e: update the world and entities in
// in the world) // the world)
// 5) Go through the terrain update queue and apply all changes to // 5) Go through the terrain update queue and apply all changes to the terrain
// the terrain
// 6) Send relevant state updates to all clients // 6) Send relevant state updates to all clients
// 7) Check for persistence updates related to character data, and message the // 7) Check for persistence updates related to character data, and message the
// relevant entities // relevant entities
// 8) Update Metrics with current data // 8) Update Metrics with current data
// 9) Finish the tick, passing control of the main thread back // 9) Finish the tick, passing control of the main thread back to the frontend
// to the frontend
// 1) Build up a list of events for this frame, to be passed to the frontend. // 1) Build up a list of events for this frame, to be passed to the frontend.
let mut frontend_events = Vec::new(); let mut frontend_events = Vec::new();

View File

@ -875,8 +875,12 @@ impl StateExt for State {
let mut automod = self.ecs().write_resource::<AutoMod>(); let mut automod = self.ecs().write_resource::<AutoMod>();
let client = self.ecs().read_storage::<Client>(); let client = self.ecs().read_storage::<Client>();
let player = self.ecs().read_storage::<Player>(); let player = self.ecs().read_storage::<Player>();
let Some(client) = client.get(entity) else { return true }; let Some(client) = client.get(entity) else {
let Some(player) = player.get(entity) else { return true }; return true;
};
let Some(player) = player.get(entity) else {
return true;
};
match automod.validate_chat_msg( match automod.validate_chat_msg(
player.uuid(), player.uuid(),

View File

@ -885,11 +885,7 @@ fn remembers_fight_with(
// read_data: &ReadData, // read_data: &ReadData,
// agent: &mut Agent, // agent: &mut Agent,
// target: EcsEntity, // target: EcsEntity,
// ) { // ) { rtsim_entity.is_some().then(|| { read_data .stats .get(target)
// rtsim_entity.is_some().then(|| { // .map(|stats| agent.add_fight_to_memory(&stats.name,
// read_data
// .stats
// .get(target)
// .map(|stats| agent.add_fight_to_memory(&stats.name,
// read_data.time.0)) }); // read_data.time.0)) });
// } // }

View File

@ -61,8 +61,8 @@ impl<'a> System<'a> for Sys {
// To update subscriptions // To update subscriptions
// 1. Iterate through clients // 1. Iterate through clients
// 2. Calculate current chunk position // 2. Calculate current chunk position
// 3. If chunk is different (use fuzziness) or the client view distance // 3. If chunk is different (use fuzziness) or the client view distance has
// has changed continue, otherwise return // changed continue, otherwise return
// 4. Iterate through subscribed regions // 4. Iterate through subscribed regions
// 5. Check if region is still in range (use fuzziness) // 5. Check if region is still in range (use fuzziness)
// 6. If not in range // 6. If not in range

View File

@ -83,11 +83,14 @@ impl<'a> System<'a> for Sys {
.join() .join()
{ {
let portal_pos = positions.get(teleporting.portal); let portal_pos = positions.get(teleporting.portal);
let Some(Object::Portal { target, requires_no_aggro, .. }) = objects let Some(Object::Portal {
.get(teleporting.portal) target,
requires_no_aggro,
..
}) = objects.get(teleporting.portal)
else { else {
cancel_teleporting.push(entity); cancel_teleporting.push(entity);
continue continue;
}; };
if portal_pos.map_or(true, |portal_pos| { if portal_pos.map_or(true, |portal_pos| {

View File

@ -1487,9 +1487,7 @@ impl<'a> Widget for Crafting<'a> {
}); });
} }
let can_perform = repair_slot let can_perform = repair_slot.item(self.inventory).map_or(false, can_repair);
.item(self.inventory)
.map_or(false, can_repair);
(repair_slot.slot, None, can_perform) (repair_slot.slot, None, can_perform)
}, },

View File

@ -515,9 +515,7 @@ impl BuffIconKind {
} }
impl PartialOrd for BuffIconKind { impl PartialOrd for BuffIconKind {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> { fn partial_cmp(&self, other: &Self) -> Option<Ordering> { Some(self.cmp(other)) }
Some(self.cmp(other))
}
} }
impl Ord for BuffIconKind { impl Ord for BuffIconKind {

View File

@ -39,7 +39,11 @@ impl Add<Vertex> for Vertex {
fn add(self, other: Self) -> Self::Output { fn add(self, other: Self) -> Self::Output {
Self { Self {
pos: [self.pos[0] + other.pos[0], self.pos[1] + other.pos[1], self.pos[2] + other.pos[2]], pos: [
self.pos[0] + other.pos[0],
self.pos[1] + other.pos[1],
self.pos[2] + other.pos[2],
],
} }
} }
} }

View File

@ -1484,27 +1484,13 @@ impl Renderer {
// _bones: &Consts<figure::BoneData>, // _bones: &Consts<figure::BoneData>,
// _lod: &lod_terrain::LodData, // _lod: &lod_terrain::LodData,
// _locals: &Consts<shadow::Locals>, // _locals: &Consts<shadow::Locals>,
// ) { // ) { // FIXME: Consider reenabling at some point. /* let (point_shadow_maps,
// // FIXME: Consider reenabling at some point. // directed_shadow_maps) = if let Some(shadow_map) = &mut self.shadow_map { (
// /* let (point_shadow_maps, directed_shadow_maps) = // ( shadow_map.point_res.clone(), shadow_map.point_sampler.clone(), ), (
// if let Some(shadow_map) = &mut self.shadow_map { // shadow_map.directed_res.clone(), shadow_map.directed_sampler.clone(), ), )
// ( // } else { ( (self.noise_tex.srv.clone(), self.noise_tex.sampler.clone()),
// ( // (self.noise_tex.srv.clone(), self.noise_tex.sampler.clone()), ) }; let
// shadow_map.point_res.clone(), // model = &model.opaque;
// shadow_map.point_sampler.clone(),
// ),
// (
// shadow_map.directed_res.clone(),
// shadow_map.directed_sampler.clone(),
// ),
// )
// } else {
// (
// (self.noise_tex.srv.clone(), self.noise_tex.sampler.clone()),
// (self.noise_tex.srv.clone(), self.noise_tex.sampler.clone()),
// )
// };
// let model = &model.opaque;
// self.encoder.draw( // self.encoder.draw(
// &gfx::Slice { // &gfx::Slice {

View File

@ -445,7 +445,9 @@ impl<'frame> Drawer<'frame> {
/// pending uploads. /// pending uploads.
fn run_ui_premultiply_passes(&mut self) { fn run_ui_premultiply_passes(&mut self) {
prof_span!("run_ui_premultiply_passes"); prof_span!("run_ui_premultiply_passes");
let Some(premultiply_alpha) = self.borrow.pipelines.premultiply_alpha() else { return }; let Some(premultiply_alpha) = self.borrow.pipelines.premultiply_alpha() else {
return;
};
let encoder = self.encoder.as_mut().unwrap(); let encoder = self.encoder.as_mut().unwrap();
let device = self.borrow.device; let device = self.borrow.device;

View File

@ -1103,7 +1103,7 @@ impl FigureMgr {
&& light_emitter.is_some() && light_emitter.is_some()
&& !(second_tool_hand.is_some() && !(second_tool_hand.is_some()
|| matches!(active_tool_hand, Some(Hands::Two)) || matches!(active_tool_hand, Some(Hands::Two))
&& character.map_or(false, |c| c.is_wield())) && character.map_or(false, |c| c.is_wield()))
&& !character.map_or(false, |c| c.is_using_hands()) && !character.map_or(false, |c| c.is_using_hands())
&& physics.in_liquid().is_none(); && physics.in_liquid().is_none();

View File

@ -59,7 +59,7 @@ impl Interactable {
volume_pos: VolumePos, volume_pos: VolumePos,
interaction: Interaction, interaction: Interaction,
) -> Option<Self> { ) -> Option<Self> {
let block= volume_pos.get_block(terrain, id_maps, colliders)?; let block = volume_pos.get_block(terrain, id_maps, colliders)?;
let block_interaction = match interaction { let block_interaction = match interaction {
Interaction::Collect => { Interaction::Collect => {
// Check if this is an unlockable sprite // Check if this is an unlockable sprite
@ -114,11 +114,11 @@ impl Interactable {
/// interact with if the interact key is pressed /// interact with if the interact key is pressed
/// Selected in the following order: /// Selected in the following order:
/// 1) Targeted items, in order of nearest under cursor: /// 1) Targeted items, in order of nearest under cursor:
/// (a) entity (if within range) /// a) entity (if within range)
/// (b) collectable /// b) collectable
/// (c) can be mined, and is a mine sprite (Air) not a weak rock. /// c) can be mined, and is a mine sprite (Air) not a weak rock.
/// 2) outside of targeted cam ray /// 2) outside of targeted cam ray
/// -> closest of nearest interactable entity/block /// -> closest of nearest interactable entity/block
pub(super) fn select_interactable( pub(super) fn select_interactable(
client: &Client, client: &Client,
collect_target: Option<Target<target::Collectable>>, collect_target: Option<Target<target::Collectable>>,

View File

@ -36,7 +36,7 @@ fn load_map(path: &Path) -> Option<SingleplayerWorld> {
let meta_path = path.join("meta.ron"); let meta_path = path.join("meta.ron");
let Ok(f) = fs::File::open(&meta_path) else { let Ok(f) = fs::File::open(&meta_path) else {
error!("Failed to open {}", meta_path.to_string_lossy()); error!("Failed to open {}", meta_path.to_string_lossy());
return None; return None;
}; };

View File

@ -196,10 +196,7 @@ fn palette(conn: Connection) -> Result<(), Box<dyn Error>> {
let kind = BlockKind::from_str(&row.get::<_, String>(0)?)?; let kind = BlockKind::from_str(&row.get::<_, String>(0)?)?;
let rgb: Rgb<u8> = Rgb::new(row.get(1)?, row.get(2)?, row.get(3)?); let rgb: Rgb<u8> = Rgb::new(row.get(1)?, row.get(2)?, row.get(3)?);
let count: i64 = row.get(4)?; let count: i64 = row.get(4)?;
block_colors block_colors.entry(kind).or_default().push((rgb, count));
.entry(kind)
.or_default()
.push((rgb, count));
} }
for (_, v) in block_colors.iter_mut() { for (_, v) in block_colors.iter_mut() {
v.sort_by(|a, b| b.1.cmp(&a.1)); v.sort_by(|a, b| b.1.cmp(&a.1));

View File

@ -1569,7 +1569,9 @@ fn walk_in_all_dirs(
let adjacents = NEIGHBORS.map(|dir| a + dir); let adjacents = NEIGHBORS.map(|dir| a + dir);
let Some(a_chunk) = sim.get(a) else { return potential }; let Some(a_chunk) = sim.get(a) else {
return potential;
};
let mut chunks = [None; 8]; let mut chunks = [None; 8];
for i in 0..8 { for i in 0..8 {
if loc_suitable_for_walking(sim, adjacents[i]) { if loc_suitable_for_walking(sim, adjacents[i]) {

View File

@ -145,7 +145,9 @@ impl Tunnel {
} }
fn biome_at(&self, wpos: Vec3<i32>, info: &CanvasInfo) -> Biome { fn biome_at(&self, wpos: Vec3<i32>, info: &CanvasInfo) -> Biome {
let Some(col) = info.col_or_gen(wpos.xy()) else { return Biome::default() }; let Some(col) = info.col_or_gen(wpos.xy()) else {
return Biome::default();
};
// Below the ground // Below the ground
let below = ((col.alt - wpos.z as f32) / 120.0).clamped(0.0, 1.0); let below = ((col.alt - wpos.z as f32) / 120.0).clamped(0.0, 1.0);

View File

@ -636,31 +636,31 @@ impl m32 {
/// ///
/// This algorithm does this in four steps: /// This algorithm does this in four steps:
/// ///
/// 1. Sort the nodes in h by height (so the lowest node by altitude is first /// 1. Sort the nodes in h by height (so the lowest node by altitude is first in
/// in the list, and the highest node by altitude is last). /// the list, and the highest node by altitude is last).
/// 2. Iterate through the list in *reverse.* For each node, we compute its /// 2. Iterate through the list in *reverse.* For each node, we compute its
/// drainage area as the sum of the drainage areas of its "children" nodes /// drainage area as the sum of the drainage areas of its "children" nodes
/// (i.e. the nodes with directed edges to this node). To do this /// (i.e. the nodes with directed edges to this node). To do this
/// efficiently, we start with the "leaves" (the highest nodes), which /// efficiently, we start with the "leaves" (the highest nodes), which have
/// have no neighbors higher than them, hence no directed edges to them. /// no neighbors higher than them, hence no directed edges to them. We add
/// We add their area to themselves, and then to all neighbors that they /// their area to themselves, and then to all neighbors that they flow into
/// flow into (their "ancestors" in the flow graph); currently, this just /// (their "ancestors" in the flow graph); currently, this just means the
/// means the node immediately downhill of this node. As we go lower, we /// node immediately downhill of this node. As we go lower, we know that all
/// know that all our "children" already had their areas computed, which /// our "children" already had their areas computed, which means that we can
/// means that we can repeat the process in order to derive all the final /// repeat the process in order to derive all the final areas.
/// areas.
/// 3. Now, iterate through the list in *order.* Whether we used the filling /// 3. Now, iterate through the list in *order.* Whether we used the filling
/// method to compute a "filled" version of each depression, or used the lake /// method to compute a "filled" version of each depression, or used the lake
/// connection algorithm described in [1], each node is guaranteed to have /// connection algorithm described in [1], each node is guaranteed to have
/// zero or one drainage edges out, representing the direction of water flow /// zero or one drainage edges out, representing the direction of water flow
/// for that node. For nodes i with zero drainage edges out (boundary nodes /// for that node. For nodes i with zero drainage edges out (boundary nodes
/// and lake bottoms) we set the slope to 0 (so the change in altitude is /// and lake bottoms) we set the slope to 0 (so the change in altitude is
/// uplift(i)) /// uplift(i)).
/// For nodes with at least one drainage edge out, we take advantage of the ///
/// fact that we are computing new heights in order and rewrite our equation /// For nodes with at least one drainage edge out, we take
/// as (letting j = downhill[i], A[i] be the computed area of point i, /// advantage of the fact that we are computing new heights in order and
/// p(i) be the x-y position of point i, /// rewrite our equation as (letting j = downhill[i], A[i] be the computed
/// flux(i) = k * A[i]^m / ((p(i) - p(j)).magnitude()), and δt = 1): /// area of point i, p(i) be the x-y position of point i, flux(i) = k *
/// A[i]^m / ((p(i) - p(j)).magnitude()), and δt = 1):
/// ///
/// h[i](t + dt) = h[i](t) + δt * (uplift[i] + flux(i) * h[j](t + δt)) / (1 + /// h[i](t + dt) = h[i](t) + δt * (uplift[i] + flux(i) * h[j](t + δt)) / (1 +
/// flux(i) * δt). /// flux(i) * δt).

View File

@ -53,8 +53,8 @@ pub fn map_edge_factor(map_size_lg: MapSizeLg, posi: usize) -> f32 {
/// At some point, we should probably contribute this back to stats-rs. /// At some point, we should probably contribute this back to stats-rs.
/// ///
/// 1. [https://www.r-bloggers.com/sums-of-random-variables/][1], /// 1. [https://www.r-bloggers.com/sums-of-random-variables/][1],
/// 2. Sadooghi-Alvandi, S., A. Nematollahi, & R. Habibi, 2009. /// 2. Sadooghi-Alvandi, S., A. Nematollahi, & R. Habibi, 2009. On the
/// On the Distribution of the Sum of Independent Uniform Random Variables. /// Distribution of the Sum of Independent Uniform Random Variables.
/// Statistical Papers, 50, 171-175. /// Statistical Papers, 50, 171-175.
/// 3. [https://en.wikipedia.org/wiki/Cumulative_distribution_function][3] /// 3. [https://en.wikipedia.org/wiki/Cumulative_distribution_function][3]
/// ///

View File

@ -61,8 +61,9 @@ impl Citadel {
.filter_map(|rpos| Some(grid.get(pos + rpos)?.as_ref()?.alt)) .filter_map(|rpos| Some(grid.get(pos + rpos)?.as_ref()?.alt))
.min() .min()
{ {
let Some(Some(cell)) = grid.get_mut(pos) let Some(Some(cell)) = grid.get_mut(pos) else {
else { continue }; continue;
};
if min_alt < cell.alt { if min_alt < cell.alt {
cell.colonade = Some(min_alt); cell.colonade = Some(min_alt);
} }

View File

@ -294,12 +294,7 @@ impl GnarlingFortification {
.collect::<Vec<_>>(); .collect::<Vec<_>>();
let wall_segments = outer_wall_segments let wall_segments = outer_wall_segments
.into_iter() .into_iter()
.chain( .chain(wall_connections.iter().copied().zip(inner_tower_locs))
wall_connections
.iter()
.copied()
.zip(inner_tower_locs),
)
.collect::<Vec<_>>(); .collect::<Vec<_>>();
Self { Self {

View File

@ -1703,8 +1703,8 @@ impl Structure for House {
//1 => { //1 => {
// painter.prim(Primitive::Aabb(Aabb { // painter.prim(Primitive::Aabb(Aabb {
// min: Vec2::new(stair_origin.x, stair_origin.y // min: Vec2::new(stair_origin.x, stair_origin.y
// + 10).with_z(alt + previous_floor_height), // + 10).with_z(alt + previous_floor_height), max:
// max: Vec2::new(stair_origin.x + stair_width, // Vec2::new(stair_origin.x + stair_width,
// stair_origin.y + 12).with_z(alt + previous_height + // stair_origin.y + 12).with_z(alt + previous_height +
// 1), })) // 1), }))
//}, //},
@ -1719,8 +1719,8 @@ impl Structure for House {
//_ => { //_ => {
// painter.prim(Primitive::Aabb(Aabb { // painter.prim(Primitive::Aabb(Aabb {
// min: Vec2::new(stair_origin.x, stair_origin.y // min: Vec2::new(stair_origin.x, stair_origin.y
// + 10).with_z(alt + previous_floor_height), // + 10).with_z(alt + previous_floor_height), max:
// max: Vec2::new(stair_origin.x + stair_width, // Vec2::new(stair_origin.x + stair_width,
// stair_origin.y + 12).with_z(alt + previous_height + // stair_origin.y + 12).with_z(alt + previous_height +
// 1), })) // 1), }))
//}, //},
@ -1792,7 +1792,7 @@ impl Structure for House {
// painter.prim(Primitive::Aabb(Aabb { // painter.prim(Primitive::Aabb(Aabb {
// min: Vec2::new(stair_origin.x, stair_origin.y // min: Vec2::new(stair_origin.x, stair_origin.y
// + stair_width).with_z(alt + previous_floor_height), // + stair_width).with_z(alt + previous_floor_height),
// max: Vec2::new(stair_origin.x + 2, // max: Vec2::new(stair_origin.x + 2,
// stair_origin.y + 2 * stair_width).with_z(alt + // stair_origin.y + 2 * stair_width).with_z(alt +
// previous_height + 1), })) // previous_height + 1), }))
//}, //},