From: Ian Jackson Date: Sat, 4 Jul 2020 00:21:49 +0000 (+0100) Subject: wip X-Git-Tag: otter-0.2.0~1488 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=8502497d7331962905509377cec9ac6bb66130eb;p=otter.git wip --- diff --git a/src/bin/server.rs b/src/bin/server.rs index bd277408..202efe73 100644 --- a/src/bin/server.rs +++ b/src/bin/server.rs @@ -161,15 +161,20 @@ fn api_grab(form : Json) -> impl response::Responder<'static> { p.gen_before_lastclient = p.gen_lastclient; p.lastclient = client; } - let update = Update { + let json = UpdatePayload::PieceUpdate(piece, p.mk_update()); + let json = serde_json::to_string(&json).expect("convert to json"); + let update = PreparedUpdate { gen, - u : UpdatePayload::PieceUpdate(piece, p.mk_update()), + client, + piece, + client_seq : form.s, + json, }; let update = Arc::new(update); // split vie wthing would go here p.gen_lastclient = gen; for (_tplayer, tplupdates) in &mut g.updates { - tplupdates.log.push_back((client, update.clone())); + tplupdates.log.push_back(update.clone()); tplupdates.cv.notify_all(); } Ok(()) @@ -203,24 +208,20 @@ fn api_move(form : Json) -> impl response::Responder<'static> { "" } -#[derive(Serialize)] -enum XUpdate { - TestCounter { value: usize }, -} - #[get("/_/updates//")] #[throws(E)] -fn updates(ctoken : InstanceAccess, gen: Generation) +fn updates(ctoken : InstanceAccess, gen: u64) -> impl response::Responder<'static> { + let gen = Generation(gen); let iad = ctoken.i; - let content = sse::content(iad); + let content = sse::content(iad, gen)?; let content = response::Stream::chunked(content, 1); const CTYPE : &str = "text/event-stream; charset=utf-8"; let ctype = ContentType::parse_flexible(CTYPE).unwrap(); response::content::Content(ctype,content) } -#[Get("/_/")] +#[get("/_/")] fn resource(leaf : CheckedResourceLeaf) -> io::Result { let template_dir = "templates"; // xxx NamedFile::open(format!("{}/{}", template_dir, leaf.safe)) @@ -242,7 +243,7 @@ fn main() { loading, session, resource, - sse::updates, + updates, api_grab, api_ungrab, api_move, diff --git a/src/gamestate.rs b/src/gamestate.rs index 8d6da5ac..6bf54220 100644 --- a/src/gamestate.rs +++ b/src/gamestate.rs @@ -6,9 +6,9 @@ slotmap::new_key_type!{ } #[derive(Copy,Clone,Debug,Ord,PartialOrd,Eq,PartialEq)] -#[derive(Serialize)] +#[derive(Serialize,Deserialize)] #[serde(transparent)] -pub struct Generation (u64); +pub struct Generation (pub u64); impl Generation { pub fn increment(&mut self) { self.0 += 1 } diff --git a/src/global.rs b/src/global.rs index c81c47e5..c7853034 100644 --- a/src/global.rs +++ b/src/global.rs @@ -32,7 +32,7 @@ pub struct PreparedUpdate { } pub struct PlayerUpdates { - pub log : StableIndexVecDeque, + pub log : StableIndexVecDeque,sse::UpdateId>, pub cv : Arc, } diff --git a/src/sse.rs b/src/sse.rs index 789262ab..51a097be 100644 --- a/src/sse.rs +++ b/src/sse.rs @@ -1,6 +1,4 @@ -#![feature(proc_macro_hygiene, decl_macro)] - use crate::imports::*; #[derive(Copy,Clone,Debug,Eq,PartialEq,Ord,PartialOrd)] @@ -100,7 +98,7 @@ data: {} .map_err(|_| em("poison"))?.0; write!(buf,r#" : keepalive -"#); +"#)?; } } }