Book fixes

tosocketaddrs
Florian Gilcher 5 years ago
parent e8e82c6b71
commit 9b583b358a
No known key found for this signature in database
GPG Key ID: E7B51D33F8EBF61B

@ -17,7 +17,7 @@
- [Connecting Readers and Writers](./tutorial/connecting_readers_and_writers.md) - [Connecting Readers and Writers](./tutorial/connecting_readers_and_writers.md)
- [All Together](./tutorial/all_together.md) - [All Together](./tutorial/all_together.md)
- [Clean Shutdown](./tutorial/clean_shutdown.md) - [Clean Shutdown](./tutorial/clean_shutdown.md)
- [Handling Disconnections](./tutorial/handling_disconnections.md) - [Handling Disconnection](./tutorial/handling_disconnection.md)
- [Implementing a Client](./tutorial/implementing_a_client.md) - [Implementing a Client](./tutorial/implementing_a_client.md)
- [TODO: Async Patterns](./patterns.md) - [TODO: Async Patterns](./patterns.md)
- [TODO: Collected Small Patterns](./patterns/small-patterns.md) - [TODO: Collected Small Patterns](./patterns/small-patterns.md)

@ -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,
} }

@ -20,6 +20,7 @@ With async, we can just use the `select!` macro.
use std::net::ToSocketAddrs; use std::net::ToSocketAddrs;
use futures::select; use futures::select;
use futures::FutureExt;
use async_std::{ use async_std::{
prelude::*, prelude::*,
@ -45,14 +46,14 @@ async fn try_main(addr: impl ToSocketAddrs) -> Result<()> {
let mut lines_from_stdin = futures::StreamExt::fuse(stdin.lines()); // 2 let mut lines_from_stdin = futures::StreamExt::fuse(stdin.lines()); // 2
loop { loop {
select! { // 3 select! { // 3
line = lines_from_server.next() => match line { line = lines_from_server.next().fuse() => match line {
Some(line) => { Some(line) => {
let line = line?; let line = line?;
println!("{}", line); println!("{}", line);
}, },
None => break, None => break,
}, },
line = lines_from_stdin.next() => match line { line = lines_from_stdin.next().fuse() => match line {
Some(line) => { Some(line) => {
let line = line?; let line = line?;
writer.write_all(line.as_bytes()).await?; writer.write_all(line.as_bytes()).await?;

Loading…
Cancel
Save