mirror of
https://github.com/griffi-gh/kubi.git
synced 2024-11-25 08:18:43 -06:00
world compression (server only for now)
This commit is contained in:
parent
5a75e44beb
commit
f6eef9457b
8
Cargo.lock
generated
8
Cargo.lock
generated
|
@ -939,6 +939,7 @@ dependencies = [
|
||||||
"kubi-logging",
|
"kubi-logging",
|
||||||
"kubi-shared",
|
"kubi-shared",
|
||||||
"log",
|
"log",
|
||||||
|
"lz4_flex",
|
||||||
"nohash-hasher",
|
"nohash-hasher",
|
||||||
"postcard",
|
"postcard",
|
||||||
"rayon",
|
"rayon",
|
||||||
|
@ -968,6 +969,7 @@ dependencies = [
|
||||||
"kubi-logging",
|
"kubi-logging",
|
||||||
"kubi-shared",
|
"kubi-shared",
|
||||||
"log",
|
"log",
|
||||||
|
"lz4_flex",
|
||||||
"nohash-hasher",
|
"nohash-hasher",
|
||||||
"postcard",
|
"postcard",
|
||||||
"rand",
|
"rand",
|
||||||
|
@ -1056,6 +1058,12 @@ dependencies = [
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "lz4_flex"
|
||||||
|
version = "0.10.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "8b8c72594ac26bfd34f2d99dfced2edfaddfe8a476e3ff2ca0eb293d925c4f83"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "mach"
|
name = "mach"
|
||||||
version = "0.3.2"
|
version = "0.3.2"
|
||||||
|
|
|
@ -20,6 +20,7 @@ flume = "0.10"
|
||||||
rand = "0.8"
|
rand = "0.8"
|
||||||
uflow = "0.7"
|
uflow = "0.7"
|
||||||
postcard = { version = "1.0", features = ["alloc"] }
|
postcard = { version = "1.0", features = ["alloc"] }
|
||||||
|
lz4_flex = { version = "0.10", default-features = false, features = ["checked-decode"] }
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = []
|
default = []
|
||||||
|
|
|
@ -7,9 +7,12 @@ use kubi_shared::networking::{
|
||||||
client::Client,
|
client::Client,
|
||||||
};
|
};
|
||||||
use uflow::{
|
use uflow::{
|
||||||
server::Event as ServerEvent,
|
server::{Event as ServerEvent, RemoteClient},
|
||||||
SendMode
|
SendMode
|
||||||
};
|
};
|
||||||
|
use lz4_flex::compress_prepend_size as lz4_compress;
|
||||||
|
use anyhow::Result;
|
||||||
|
use std::{rc::Rc, cell::RefCell};
|
||||||
use crate::{
|
use crate::{
|
||||||
server::{UdpServer, ServerEvents, IsMessageOfType},
|
server::{UdpServer, ServerEvents, IsMessageOfType},
|
||||||
config::ConfigTable,
|
config::ConfigTable,
|
||||||
|
@ -33,8 +36,23 @@ impl ChunkManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
///Sends a compressed chunk packet
|
||||||
|
pub fn send_chunk_compressed(
|
||||||
|
client: &Rc<RefCell<RemoteClient>>,
|
||||||
|
message: &ServerToClientMessage
|
||||||
|
) -> Result<()> {
|
||||||
|
let mut ser_message = postcard::to_allocvec(&message)?;
|
||||||
|
let (_, data) = ser_message.split_at_mut(1);
|
||||||
|
let mut compressed = lz4_compress(&data);
|
||||||
|
ser_message.truncate(1);
|
||||||
|
ser_message.append(&mut compressed);
|
||||||
|
let ser_message = ser_message.into_boxed_slice();
|
||||||
|
client.borrow_mut().send(ser_message, CHANNEL_WORLD, SendMode::Reliable);
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
fn process_chunk_requests(
|
fn process_chunk_requests(
|
||||||
mut server: NonSendSync<UniqueViewMut<UdpServer>>,
|
server: NonSendSync<UniqueView<UdpServer>>,
|
||||||
events: UniqueView<ServerEvents>,
|
events: UniqueView<ServerEvents>,
|
||||||
mut chunk_manager: UniqueViewMut<ChunkManager>,
|
mut chunk_manager: UniqueViewMut<ChunkManager>,
|
||||||
task_manager: UniqueView<ChunkTaskManager>,
|
task_manager: UniqueView<ChunkTaskManager>,
|
||||||
|
@ -73,15 +91,14 @@ fn process_chunk_requests(
|
||||||
chunk.subscriptions.insert(client_id);
|
chunk.subscriptions.insert(client_id);
|
||||||
//TODO Start task here if status is "Nothing"
|
//TODO Start task here if status is "Nothing"
|
||||||
if let Some(blocks) = &chunk.blocks {
|
if let Some(blocks) = &chunk.blocks {
|
||||||
client.borrow_mut().send(
|
send_chunk_compressed(
|
||||||
postcard::to_allocvec(&ServerToClientMessage::ChunkResponse {
|
&client,
|
||||||
|
&ServerToClientMessage::ChunkResponse {
|
||||||
chunk: chunk_position,
|
chunk: chunk_position,
|
||||||
data: blocks.clone(),
|
data: blocks.clone(),
|
||||||
queued: Vec::with_capacity(0)
|
queued: Vec::with_capacity(0)
|
||||||
}).unwrap().into_boxed_slice(),
|
}
|
||||||
CHANNEL_WORLD,
|
).unwrap();
|
||||||
SendMode::Reliable,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let mut chunk = Chunk::new(chunk_position);
|
let mut chunk = Chunk::new(chunk_position);
|
||||||
|
@ -97,13 +114,12 @@ fn process_chunk_requests(
|
||||||
}
|
}
|
||||||
|
|
||||||
fn process_finished_tasks(
|
fn process_finished_tasks(
|
||||||
mut server: NonSendSync<UniqueViewMut<UdpServer>>,
|
server: NonSendSync<UniqueView<UdpServer>>,
|
||||||
task_manager: UniqueView<ChunkTaskManager>,
|
task_manager: UniqueView<ChunkTaskManager>,
|
||||||
mut chunk_manager: UniqueViewMut<ChunkManager>,
|
mut chunk_manager: UniqueViewMut<ChunkManager>,
|
||||||
id_map: UniqueView<ClientIdMap>,
|
id_map: UniqueView<ClientIdMap>,
|
||||||
client_addr: View<ClientAddress>,
|
client_addr: View<ClientAddress>,
|
||||||
) {
|
) {
|
||||||
let mut limit: usize = 8;
|
|
||||||
'outer: while let Some(res) = task_manager.receive() {
|
'outer: while let Some(res) = task_manager.receive() {
|
||||||
let ChunkTaskResponse::ChunkLoaded { chunk_position, blocks, queue } = res;
|
let ChunkTaskResponse::ChunkLoaded { chunk_position, blocks, queue } = res;
|
||||||
let Some(chunk) = chunk_manager.chunks.get_mut(&chunk_position) else {
|
let Some(chunk) = chunk_manager.chunks.get_mut(&chunk_position) else {
|
||||||
|
@ -116,7 +132,15 @@ fn process_finished_tasks(
|
||||||
}
|
}
|
||||||
chunk.state = ChunkState::Loaded;
|
chunk.state = ChunkState::Loaded;
|
||||||
chunk.blocks = Some(blocks.clone());
|
chunk.blocks = Some(blocks.clone());
|
||||||
|
|
||||||
log::debug!("Chunk {chunk_position} loaded, {} subs", chunk.subscriptions.len());
|
log::debug!("Chunk {chunk_position} loaded, {} subs", chunk.subscriptions.len());
|
||||||
|
|
||||||
|
let chunk_packet = &ServerToClientMessage::ChunkResponse {
|
||||||
|
chunk: chunk_position,
|
||||||
|
data: blocks,
|
||||||
|
queued: queue
|
||||||
|
};
|
||||||
|
|
||||||
for &subscriber in &chunk.subscriptions {
|
for &subscriber in &chunk.subscriptions {
|
||||||
let Some(&entity_id) = id_map.0.get(&subscriber) else {
|
let Some(&entity_id) = id_map.0.get(&subscriber) else {
|
||||||
log::error!("Invalid subscriber client id");
|
log::error!("Invalid subscriber client id");
|
||||||
|
@ -130,15 +154,12 @@ fn process_finished_tasks(
|
||||||
log::error!("Client not connected");
|
log::error!("Client not connected");
|
||||||
continue 'outer;
|
continue 'outer;
|
||||||
};
|
};
|
||||||
client.borrow_mut().send(
|
send_chunk_compressed(client, chunk_packet).unwrap();
|
||||||
postcard::to_allocvec(&ServerToClientMessage::ChunkResponse {
|
// client.borrow_mut().send(
|
||||||
chunk: chunk_position,
|
// chunk_packet.clone(),
|
||||||
data: blocks.clone(),
|
// CHANNEL_WORLD,
|
||||||
queued: queue.clone()
|
// SendMode::Reliable,
|
||||||
}).unwrap().into_boxed_slice(),
|
// );
|
||||||
CHANNEL_WORLD,
|
|
||||||
SendMode::Reliable,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,7 @@ use serde::{Serialize, Deserialize};
|
||||||
use crate::{chunk::BlockData, queue::QueuedBlock};
|
use crate::{chunk::BlockData, queue::QueuedBlock};
|
||||||
use super::client::ClientId;
|
use super::client::ClientId;
|
||||||
|
|
||||||
pub const PROTOCOL_ID: u16 = 2;
|
pub const PROTOCOL_ID: u16 = 3;
|
||||||
|
|
||||||
pub const C_CLIENT_HELLO: u8 = 0;
|
pub const C_CLIENT_HELLO: u8 = 0;
|
||||||
pub const C_POSITION_CHANGED: u8 = 1;
|
pub const C_POSITION_CHANGED: u8 = 1;
|
||||||
|
@ -45,6 +45,7 @@ pub enum ServerToClientMessage {
|
||||||
position: Vec3,
|
position: Vec3,
|
||||||
direction: Quat,
|
direction: Quat,
|
||||||
} = S_PLAYER_POSITION_CHANGED,
|
} = S_PLAYER_POSITION_CHANGED,
|
||||||
|
///WARNING: THIS IS COMPRESSED
|
||||||
ChunkResponse {
|
ChunkResponse {
|
||||||
chunk: IVec3,
|
chunk: IVec3,
|
||||||
data: BlockData,
|
data: BlockData,
|
||||||
|
|
|
@ -22,6 +22,7 @@ gilrs = { version = "0.10", default_features = false, features = ["xinput"] }
|
||||||
uflow = "0.7"
|
uflow = "0.7"
|
||||||
postcard = { version = "1.0", features = ["alloc"] }
|
postcard = { version = "1.0", features = ["alloc"] }
|
||||||
serde_json = { version = "1.0", optional = true }
|
serde_json = { version = "1.0", optional = true }
|
||||||
|
lz4_flex = { version = "0.10", default-features = false, features = ["checked-decode"] }
|
||||||
|
|
||||||
[target.'cfg(target_os = "windows")'.dependencies]
|
[target.'cfg(target_os = "windows")'.dependencies]
|
||||||
winapi = { version = "0.3" }
|
winapi = { version = "0.3" }
|
||||||
|
|
Loading…
Reference in a new issue