Congest the code

This commit is contained in:
Wojciech Kozlowski 2024-10-06 17:48:50 +02:00
parent dde8268eaa
commit 12b27655e3

View File

@ -140,32 +140,27 @@ impl AppMachine<FetchState> {
} }
pub fn app_fetch_next(inner: AppInner, mut fetch: FetchState) -> App { pub fn app_fetch_next(inner: AppInner, mut fetch: FetchState) -> App {
match fetch.try_recv() { loop {
let app: App = match fetch.try_recv() {
Ok(fetch_result) => match fetch_result { Ok(fetch_result) => match fetch_result {
Ok(retval) => Self::handle_mb_api_return(inner, fetch, retval), Ok(MbReturn::Match(next_match)) => {
AppMachine::match_state(inner, MatchState::new(next_match, fetch)).into()
}
Ok(MbReturn::Fetch(_)) => continue,
Err(fetch_err) => { Err(fetch_err) => {
AppMachine::error_state(inner, format!("fetch failed: {fetch_err}")).into() AppMachine::error_state(inner, format!("fetch failed: {fetch_err}")).into()
} }
}, },
Err(recv_err) => match recv_err { Err(TryRecvError::Empty) => AppMachine::fetch_state(inner, fetch).into(),
TryRecvError::Empty => AppMachine::fetch_state(inner, fetch).into(), Err(TryRecvError::Disconnected) => {
TryRecvError::Disconnected => {
if fetch.fetch_rx.is_some() { if fetch.fetch_rx.is_some() {
AppMachine::browse_state(inner).into() AppMachine::browse_state(inner).into()
} else { } else {
Self::app_fetch_new(inner) Self::app_fetch_new(inner)
} }
} }
}, };
} return app;
}
fn handle_mb_api_return(inner: AppInner, fetch: FetchState, retval: MbReturn) -> App {
match retval {
MbReturn::Match(next_match) => {
AppMachine::match_state(inner, MatchState::new(next_match, fetch)).into()
}
MbReturn::Fetch(_) => Self::app_fetch_next(inner, fetch),
} }
} }