mirror of
https://github.com/griffi-gh/kubi.git
synced 2025-01-13 15:48:21 -06:00
Fixed timestamps! (use them to fix networking)
This commit is contained in:
parent
76ec9fba32
commit
aeaa3d175f
45
kubi/src/fixed_timestamp.rs
Normal file
45
kubi/src/fixed_timestamp.rs
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
use shipyard::{Workload, WorkloadModificator, Unique, AllStoragesView, UniqueViewMut, IntoWorkload};
|
||||||
|
use hashbrown::HashMap;
|
||||||
|
use std::time::{Duration, Instant};
|
||||||
|
use nohash_hasher::BuildNoHashHasher;
|
||||||
|
|
||||||
|
#[derive(Unique)]
|
||||||
|
#[repr(transparent)]
|
||||||
|
struct FixedTimestampStorage(HashMap<u32, Instant, BuildNoHashHasher<u32>>);
|
||||||
|
impl FixedTimestampStorage {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self(HashMap::with_capacity_and_hasher(16, BuildNoHashHasher::default()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl Default for FixedTimestampStorage {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self::new()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait FixedTimestamp {
|
||||||
|
fn make_fixed(self, rate_millis: u16, unique_id: u16) -> Self;
|
||||||
|
}
|
||||||
|
impl FixedTimestamp for Workload {
|
||||||
|
fn make_fixed(self, rate_millis: u16, unique_id: u16) -> Self {
|
||||||
|
let key = (rate_millis as u32) | ((unique_id as u32) << 16);
|
||||||
|
let duration = Duration::from_millis(rate_millis as u64);
|
||||||
|
(self,).into_workload().run_if(move |mut timestamps: UniqueViewMut<FixedTimestampStorage>| {
|
||||||
|
let Some(t) = timestamps.0.get_mut(&key) else {
|
||||||
|
timestamps.0.insert_unique_unchecked(key, Instant::now());
|
||||||
|
return true
|
||||||
|
};
|
||||||
|
if t.elapsed() >= duration {
|
||||||
|
*t = Instant::now();
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
false
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn init_fixed_timestamp_storage(
|
||||||
|
storages: AllStoragesView
|
||||||
|
) {
|
||||||
|
storages.add_unique(FixedTimestampStorage::new());
|
||||||
|
}
|
|
@ -41,6 +41,7 @@ pub(crate) mod init;
|
||||||
pub(crate) mod color;
|
pub(crate) mod color;
|
||||||
pub(crate) mod loading_screen;
|
pub(crate) mod loading_screen;
|
||||||
pub(crate) mod connecting_screen;
|
pub(crate) mod connecting_screen;
|
||||||
|
pub(crate) mod fixed_timestamp;
|
||||||
|
|
||||||
use world::{
|
use world::{
|
||||||
init_game_world,
|
init_game_world,
|
||||||
|
@ -83,6 +84,7 @@ use init::initialize_from_args;
|
||||||
use gui::{render_gui, init_gui, update_gui};
|
use gui::{render_gui, init_gui, update_gui};
|
||||||
use loading_screen::update_loading_screen;
|
use loading_screen::update_loading_screen;
|
||||||
use connecting_screen::switch_to_loading_if_connected;
|
use connecting_screen::switch_to_loading_if_connected;
|
||||||
|
use fixed_timestamp::init_fixed_timestamp_storage;
|
||||||
|
|
||||||
/// stuff required to init the renderer and other basic systems
|
/// stuff required to init the renderer and other basic systems
|
||||||
fn pre_startup() -> Workload {
|
fn pre_startup() -> Workload {
|
||||||
|
@ -93,6 +95,7 @@ fn pre_startup() -> Workload {
|
||||||
|
|
||||||
fn startup() -> Workload {
|
fn startup() -> Workload {
|
||||||
(
|
(
|
||||||
|
init_fixed_timestamp_storage,
|
||||||
initial_resize_event,
|
initial_resize_event,
|
||||||
init_window_size,
|
init_window_size,
|
||||||
load_prefabs,
|
load_prefabs,
|
||||||
|
@ -119,7 +122,7 @@ fn update() -> Workload {
|
||||||
spawn_player.run_if_storage_empty::<MainPlayer>(),
|
spawn_player.run_if_storage_empty::<MainPlayer>(),
|
||||||
).into_sequential_workload().run_if(is_singleplayer),
|
).into_sequential_workload().run_if(is_singleplayer),
|
||||||
).into_sequential_workload().run_if(is_ingame_or_loading),
|
).into_sequential_workload().run_if(is_ingame_or_loading),
|
||||||
update_networking.run_if(is_multiplayer),
|
update_networking().run_if(is_multiplayer),
|
||||||
(
|
(
|
||||||
switch_to_loading_if_connected
|
switch_to_loading_if_connected
|
||||||
).into_sequential_workload().run_if(is_connecting),
|
).into_sequential_workload().run_if(is_connecting),
|
||||||
|
|
|
@ -14,7 +14,8 @@ use crate::{
|
||||||
events::EventComponent,
|
events::EventComponent,
|
||||||
control_flow::SetControlFlow,
|
control_flow::SetControlFlow,
|
||||||
world::tasks::ChunkTaskManager,
|
world::tasks::ChunkTaskManager,
|
||||||
state::is_ingame_or_loading
|
state::is_ingame_or_loading,
|
||||||
|
fixed_timestamp::FixedTimestamp
|
||||||
};
|
};
|
||||||
|
|
||||||
mod handshake;
|
mod handshake;
|
||||||
|
@ -34,9 +35,11 @@ use world::{
|
||||||
use player::{
|
use player::{
|
||||||
init_client_map,
|
init_client_map,
|
||||||
send_player_movement_events,
|
send_player_movement_events,
|
||||||
|
receive_player_movement_events,
|
||||||
|
receive_player_connect_events
|
||||||
};
|
};
|
||||||
|
|
||||||
use self::player::{receive_player_movement_events, receive_player_connect_events};
|
const NET_TICKRATE: u16 = 33;
|
||||||
|
|
||||||
#[derive(Unique, Clone, Copy, PartialEq, Eq)]
|
#[derive(Unique, Clone, Copy, PartialEq, Eq)]
|
||||||
pub enum GameType {
|
pub enum GameType {
|
||||||
|
@ -119,7 +122,7 @@ pub fn update_networking() -> Workload {
|
||||||
(
|
(
|
||||||
init_client_map.run_if_missing_unique::<ClientIdMap>(),
|
init_client_map.run_if_missing_unique::<ClientIdMap>(),
|
||||||
connect_client.run_if_missing_unique::<UdpClient>(),
|
connect_client.run_if_missing_unique::<UdpClient>(),
|
||||||
poll_client,
|
poll_client.into_workload().make_fixed(NET_TICKRATE, 0),
|
||||||
(
|
(
|
||||||
set_client_join_state_to_connected,
|
set_client_join_state_to_connected,
|
||||||
say_hello,
|
say_hello,
|
||||||
|
@ -147,7 +150,7 @@ pub fn update_networking_late() -> Workload {
|
||||||
send_block_place_events,
|
send_block_place_events,
|
||||||
send_player_movement_events,
|
send_player_movement_events,
|
||||||
).into_workload().run_if(is_join_state::<{ClientJoinState::Joined as u8}>),
|
).into_workload().run_if(is_join_state::<{ClientJoinState::Joined as u8}>),
|
||||||
flush_client,
|
flush_client.into_workload().make_fixed(NET_TICKRATE, 1)
|
||||||
).into_sequential_workload()
|
).into_sequential_workload()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue