|
|
@ -58,6 +58,7 @@ We use `select` macro for this purpose:
|
|
|
|
|
|
|
|
|
|
|
|
```rust
|
|
|
|
```rust
|
|
|
|
use futures::select;
|
|
|
|
use futures::select;
|
|
|
|
|
|
|
|
use futures::FutureExt;
|
|
|
|
|
|
|
|
|
|
|
|
async fn client_writer(
|
|
|
|
async fn client_writer(
|
|
|
|
messages: &mut Receiver<String>,
|
|
|
|
messages: &mut Receiver<String>,
|
|
|
@ -67,11 +68,11 @@ async fn client_writer(
|
|
|
|
let mut stream = &*stream;
|
|
|
|
let mut stream = &*stream;
|
|
|
|
loop { // 2
|
|
|
|
loop { // 2
|
|
|
|
select! {
|
|
|
|
select! {
|
|
|
|
msg = messages.next() => match msg {
|
|
|
|
msg = messages.next().fuse() => match msg {
|
|
|
|
Some(msg) => stream.write_all(msg.as_bytes()).await?,
|
|
|
|
Some(msg) => stream.write_all(msg.as_bytes()).await?,
|
|
|
|
None => break,
|
|
|
|
None => break,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
void = shutdown.next() => match void {
|
|
|
|
void = shutdown.next().fuse() => match void {
|
|
|
|
Some(void) => match void {}, // 3
|
|
|
|
Some(void) => match void {}, // 3
|
|
|
|
None => break,
|
|
|
|
None => break,
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -105,6 +106,7 @@ use std::{
|
|
|
|
use futures::{
|
|
|
|
use futures::{
|
|
|
|
channel::mpsc,
|
|
|
|
channel::mpsc,
|
|
|
|
SinkExt,
|
|
|
|
SinkExt,
|
|
|
|
|
|
|
|
FutureExt,
|
|
|
|
select,
|
|
|
|
select,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
@ -185,11 +187,11 @@ async fn client_writer(
|
|
|
|
let mut stream = &*stream;
|
|
|
|
let mut stream = &*stream;
|
|
|
|
loop {
|
|
|
|
loop {
|
|
|
|
select! {
|
|
|
|
select! {
|
|
|
|
msg = messages.next() => match msg {
|
|
|
|
msg = messages.next().fuse() => match msg {
|
|
|
|
Some(msg) => stream.write_all(msg.as_bytes()).await?,
|
|
|
|
Some(msg) => stream.write_all(msg.as_bytes()).await?,
|
|
|
|
None => break,
|
|
|
|
None => break,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
void = shutdown.next() => match void {
|
|
|
|
void = shutdown.next().fuse() => match void {
|
|
|
|
Some(void) => match void {},
|
|
|
|
Some(void) => match void {},
|
|
|
|
None => break,
|
|
|
|
None => break,
|
|
|
|
}
|
|
|
|
}
|
|
|
|