mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
add7922653
This requires to move `State` into a own crate called `common_state` which depends on `common` and `common_sys`
64 lines
1.9 KiB
Rust
64 lines
1.9 KiB
Rust
use super::SysTimer;
|
|
use crate::client::Client;
|
|
use common::{
|
|
comp::{Player, Pos, Waypoint, WaypointArea},
|
|
msg::{Notification, ServerGeneral},
|
|
resources::Time,
|
|
span,
|
|
};
|
|
use specs::{Entities, Join, Read, ReadStorage, System, Write, WriteStorage};
|
|
|
|
/// Cooldown time (in seconds) for "Waypoint Saved" notifications
|
|
const NOTIFY_TIME: f64 = 10.0;
|
|
|
|
/// This system updates player waypoints
|
|
/// TODO: Make this faster by only considering local waypoints
|
|
pub struct Sys;
|
|
impl<'a> System<'a> for Sys {
|
|
#[allow(clippy::type_complexity)] // TODO: Pending review in #587
|
|
type SystemData = (
|
|
Entities<'a>,
|
|
ReadStorage<'a, Pos>,
|
|
ReadStorage<'a, Player>,
|
|
ReadStorage<'a, WaypointArea>,
|
|
WriteStorage<'a, Waypoint>,
|
|
ReadStorage<'a, Client>,
|
|
Read<'a, Time>,
|
|
Write<'a, SysTimer<Self>>,
|
|
);
|
|
|
|
fn run(
|
|
&mut self,
|
|
(
|
|
entities,
|
|
positions,
|
|
players,
|
|
waypoint_areas,
|
|
mut waypoints,
|
|
clients,
|
|
time,
|
|
mut timer,
|
|
): Self::SystemData,
|
|
) {
|
|
span!(_guard, "run", "waypoint::Sys::run");
|
|
timer.start();
|
|
|
|
for (entity, player_pos, _, client) in (&entities, &positions, &players, &clients).join() {
|
|
for (waypoint_pos, waypoint_area) in (&positions, &waypoint_areas).join() {
|
|
if player_pos.0.distance_squared(waypoint_pos.0) < waypoint_area.radius().powi(2) {
|
|
if let Ok(wp_old) = waypoints.insert(entity, Waypoint::new(player_pos.0, *time))
|
|
{
|
|
if wp_old.map_or(true, |w| w.elapsed(*time) > NOTIFY_TIME) {
|
|
client.send_fallible(ServerGeneral::Notification(
|
|
Notification::WaypointSaved,
|
|
));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
timer.end();
|
|
}
|
|
}
|