mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
cargo fmt after updating new toolchain
This commit is contained in:
parent
cb25a409d5
commit
8e95cb944d
@ -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.
|
||||||
|
@ -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
|
||||||
|
@ -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) => {
|
||||||
|
@ -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;
|
||||||
};
|
};
|
||||||
|
@ -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
|
||||||
|
@ -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());
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
@ -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(),
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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(),
|
||||||
|
@ -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)) });
|
||||||
// }
|
// }
|
||||||
|
@ -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
|
||||||
|
@ -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| {
|
||||||
|
@ -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)
|
||||||
},
|
},
|
||||||
|
@ -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 {
|
||||||
|
@ -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],
|
||||||
|
],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
|
||||||
|
@ -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>>,
|
||||||
|
@ -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));
|
||||||
|
@ -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]) {
|
||||||
|
@ -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);
|
||||||
|
@ -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).
|
||||||
|
@ -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]
|
||||||
///
|
///
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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), }))
|
||||||
//},
|
//},
|
||||||
|
Loading…
Reference in New Issue
Block a user