Sending the end file event out to listeners.

This commit is contained in:
Tom Alexander 2022-02-21 18:30:03 -05:00
parent 0dd5cf8fe4
commit 860f5759c1
Signed by: talexander
GPG Key ID: D3A179C9A53C0EDE

View File

@ -88,75 +88,70 @@ impl MpvCtl {
db: &CommandDb, db: &CommandDb,
event_listeners: &EventDb, event_listeners: &EventDb,
) -> Result<(), Box<dyn std::error::Error>> { ) -> Result<(), Box<dyn std::error::Error>> {
match framed_read.read_frame().await { let current_frame = framed_read.read_frame().await.map_err(|e| e.to_string())?;
Ok(Some(frame)) => { if let Some(frame) = current_frame {
println!("Read {}", frame); println!("Read {}", frame);
// check if its an event // check if its an event
let is_event = match &frame { let is_event = match &frame {
serde_json::Value::Object(obj) => obj.contains_key("event"), serde_json::Value::Object(obj) => obj.contains_key("event"),
_ => false, _ => false,
};
if is_event {
let obj = match &frame {
serde_json::Value::Object(obj) => obj,
_ => {
return Err("Got back a json value that wasn't an object.".into());
}
}; };
if is_event { match obj.get("event") {
let obj = match &frame { Some(serde_json::Value::String(s)) => {
serde_json::Value::Object(obj) => obj, println!("Notifying listeners for event {}", s);
_ => { let listeners = {
return Err("Got back a json value that wasn't an object.".into()); let db_handle = event_listeners.lock().unwrap();
} match (*db_handle).get(s) {
}; None => Vec::new(),
match obj.get("event") { Some(listeners) => listeners.to_owned(),
Some(orig @ serde_json::Value::String(s)) => {
println!("Notifying listeners for event {}", s);
let listeners = {
let db_handle = event_listeners.lock().unwrap();
match (*db_handle).get(s) {
None => Vec::new(),
Some(listeners) => listeners.to_owned(),
}
};
for listener in listeners {
listener.send(frame.clone()).await;
} }
} };
_ => return Err("Event with no string value".into()), for listener in listeners {
}; listener.send(frame.clone()).await?;
return Ok(());
}
// get the request id and push the result into the channel
let reqid = {
let obj = match &frame {
serde_json::Value::Object(obj) => obj,
_ => {
return Err("Got back a json value that wasn't an object.".into());
}
};
match obj.get("request_id") {
Some(serde_json::Value::Number(reqid)) if reqid.is_u64() => {
reqid.as_u64().unwrap()
}
_ => {
return Err("Unrecognized request_id".into());
} }
} }
_ => return Err("Event with no string value".into()),
}; };
{
let mut db_handle = db.lock().unwrap();
if let Entry::Occupied(o) = (*db_handle).entry(reqid) {
o.remove()
.send(frame)
.map_err(|e| "Failed to send frame".to_string())?;
} else {
return Err("No entry found for request id".into());
}
}
}
Ok(None) => {
return Ok(()); return Ok(());
} }
Err(e) => { // get the request id and push the result into the channel
return Err("Ran into a problem".into()); let reqid = {
let obj = match &frame {
serde_json::Value::Object(obj) => obj,
_ => {
return Err("Got back a json value that wasn't an object.".into());
}
};
match obj.get("request_id") {
Some(serde_json::Value::Number(reqid)) if reqid.is_u64() => {
reqid.as_u64().unwrap()
}
_ => {
return Err("Unrecognized request_id".into());
}
}
};
{
let mut db_handle = db.lock().unwrap();
if let Entry::Occupied(o) = (*db_handle).entry(reqid) {
o.remove()
.send(frame)
.map_err(|e| "Failed to send frame".to_string())?;
} else {
return Err("No entry found for request id".into());
}
} }
} } else if let None = current_frame {
return Ok(());
};
Ok(()) Ok(())
} }