Don't immediately send heartbeat
All checks were successful
CI / Formatting (push) Successful in 1m11s
All checks were successful
CI / Formatting (push) Successful in 1m11s
This commit is contained in:
parent
591cfee715
commit
e58629c2f1
5 changed files with 50 additions and 46 deletions
|
@ -4,6 +4,7 @@ use bevy::prelude::*;
|
|||
use uuid::Uuid;
|
||||
|
||||
use super::{
|
||||
packet::{InboundPacket, OutboundPacket, Packet},
|
||||
peer::{Peer, PeerChangeEvent, PeerMap, PeerReceiveTiming, PeerSendTiming},
|
||||
queues::{NetworkReceive, NetworkSend},
|
||||
};
|
||||
|
@ -65,11 +66,9 @@ pub fn heartbeat(
|
|||
mut outbound: EventWriter<OutboundPacket>,
|
||||
) {
|
||||
for (peer, last) in peers {
|
||||
if let Some(previous) = last.timestamp() {
|
||||
// Allow for 2 consecutive missed heartbeats without timing out
|
||||
if previous + TIMEOUT / 3 > time.elapsed() {
|
||||
continue;
|
||||
}
|
||||
// Allow for 2 consecutive missed heartbeats without timing out
|
||||
if last.time() + TIMEOUT / 3 > time.elapsed() {
|
||||
continue;
|
||||
}
|
||||
outbound.write(OutboundPacket(Packet::new(Vec::new(), peer.uuid)));
|
||||
}
|
||||
|
@ -81,7 +80,7 @@ pub fn timeouts(
|
|||
mut delete: EventWriter<PeerChangeEvent>,
|
||||
) {
|
||||
for (peer, last) in peers {
|
||||
if let Some(previous) = last.timestamp() {
|
||||
if let Some(previous) = last.time() {
|
||||
if previous + TIMEOUT < time.elapsed() {
|
||||
warn!("Peer {} timed out", peer.uuid);
|
||||
delete.write(PeerChangeEvent::new(peer.uuid, None));
|
||||
|
@ -100,21 +99,3 @@ impl Config {
|
|||
Self { id: Uuid::new_v4() }
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct Packet {
|
||||
pub message: Vec<u8>,
|
||||
pub peer: Uuid,
|
||||
}
|
||||
|
||||
impl Packet {
|
||||
pub fn new(message: Vec<u8>, peer: Uuid) -> Self {
|
||||
Self { peer, message }
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Event)]
|
||||
pub struct OutboundPacket(pub Packet);
|
||||
|
||||
#[derive(Debug, Event)]
|
||||
pub struct InboundPacket(pub Packet);
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
mod io;
|
||||
mod packet;
|
||||
mod peer;
|
||||
mod plugin;
|
||||
mod queues;
|
||||
|
@ -7,7 +8,7 @@ mod thread;
|
|||
|
||||
#[allow(unused_imports)]
|
||||
pub mod prelude {
|
||||
pub use super::io::{InboundPacket, OutboundPacket, Packet};
|
||||
pub use super::packet::{InboundPacket, OutboundPacket, Packet};
|
||||
pub use super::peer::Peer;
|
||||
pub use super::plugin::{NetIOPlugin, NetworkState};
|
||||
}
|
||||
|
|
20
src/net/packet.rs
Normal file
20
src/net/packet.rs
Normal file
|
@ -0,0 +1,20 @@
|
|||
use bevy::prelude::*;
|
||||
use uuid::Uuid;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct Packet {
|
||||
pub message: Vec<u8>,
|
||||
pub peer: Uuid,
|
||||
}
|
||||
|
||||
impl Packet {
|
||||
pub fn new(message: Vec<u8>, peer: Uuid) -> Self {
|
||||
Self { peer, message }
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Event)]
|
||||
pub struct OutboundPacket(pub Packet);
|
||||
|
||||
#[derive(Debug, Event)]
|
||||
pub struct InboundPacket(pub Packet);
|
|
@ -3,40 +3,35 @@ use std::{collections::HashMap, net::SocketAddr, time::Duration};
|
|||
use bevy::prelude::*;
|
||||
use uuid::Uuid;
|
||||
|
||||
#[derive(Debug, Default)]
|
||||
struct Timing {
|
||||
timestamp: Option<Duration>,
|
||||
}
|
||||
use super::packet::{OutboundPacket, Packet};
|
||||
|
||||
#[derive(Component, Debug, Default)]
|
||||
pub struct PeerSendTiming(Timing);
|
||||
pub struct PeerSendTiming(Duration);
|
||||
|
||||
impl PeerSendTiming {
|
||||
pub fn update(&mut self, time: &Res<Time>) {
|
||||
self.0.timestamp = Some(time.elapsed())
|
||||
self.0 = time.elapsed()
|
||||
}
|
||||
|
||||
pub fn timestamp(&self) -> Option<Duration> {
|
||||
self.0.timestamp
|
||||
pub fn time(&self) -> Duration {
|
||||
self.0
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Component, Debug, Default)]
|
||||
pub struct PeerReceiveTiming(Timing);
|
||||
pub struct PeerReceiveTiming(Option<Duration>);
|
||||
|
||||
impl PeerReceiveTiming {
|
||||
pub fn new(time: &Res<Time>) -> Self {
|
||||
Self(Timing {
|
||||
timestamp: Some(time.elapsed()),
|
||||
})
|
||||
Self(Some(time.elapsed()))
|
||||
}
|
||||
|
||||
pub fn update(&mut self, time: &Res<Time>) {
|
||||
self.0.timestamp = Some(time.elapsed())
|
||||
self.0 = Some(time.elapsed())
|
||||
}
|
||||
|
||||
pub fn timestamp(&self) -> Option<Duration> {
|
||||
self.0.timestamp
|
||||
pub fn time(&self) -> Option<Duration> {
|
||||
self.0
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -130,3 +125,12 @@ pub fn handle_peer_change(
|
|||
}
|
||||
Ok(())
|
||||
}
|
||||
|
||||
pub fn handle_new_peer(
|
||||
new_peers: Query<&Peer, Added<Peer>>,
|
||||
mut outbound: EventWriter<OutboundPacket>,
|
||||
) {
|
||||
for peer in new_peers {
|
||||
outbound.write(OutboundPacket(Packet::new(Vec::new(), peer.uuid)));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -4,11 +4,9 @@ use bevy::prelude::*;
|
|||
use uuid::Uuid;
|
||||
|
||||
use super::{
|
||||
io::{
|
||||
Config, InboundPacket, OutboundPacket, handle_network_input, handle_network_output,
|
||||
heartbeat, timeouts,
|
||||
},
|
||||
peer::{Peer, PeerChangeEvent, PeerMap, handle_peer_change},
|
||||
io::{Config, handle_network_input, handle_network_output, heartbeat, timeouts},
|
||||
packet::{InboundPacket, OutboundPacket},
|
||||
peer::{Peer, PeerChangeEvent, PeerMap, handle_new_peer, handle_peer_change},
|
||||
queues::{NetworkReceive, NetworkSend},
|
||||
socket::bind_socket,
|
||||
};
|
||||
|
@ -42,7 +40,7 @@ impl Plugin for NetIOPlugin {
|
|||
)
|
||||
.add_systems(
|
||||
FixedUpdate,
|
||||
(heartbeat, timeouts).run_if(in_state(NetworkState::MultiPlayer)),
|
||||
(heartbeat, timeouts, handle_new_peer).run_if(in_state(NetworkState::MultiPlayer)),
|
||||
)
|
||||
.add_systems(
|
||||
FixedPostUpdate,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue