mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-10-01 12:20:39 +00:00
signal: Ctrl+C example: quit after 10 signals.
This commit is contained in:
parent
72e2209bd8
commit
934c596133
@ -5,6 +5,9 @@ extern crate tokio_signal;
|
||||
use futures::{Stream, Future};
|
||||
use tokio_core::reactor::Core;
|
||||
|
||||
/// how many signals to handle before exiting
|
||||
const STOP_AFTER: u64 = 10;
|
||||
|
||||
fn main() {
|
||||
// set up a Tokio event loop
|
||||
let mut core = Core::new().unwrap();
|
||||
@ -16,19 +19,32 @@ fn main() {
|
||||
// the `flatten_stream()` convenience method lazily defers that
|
||||
// initialisation, allowing us to use it 'as if' it is already the
|
||||
// stream we want, reducing boilerplate Future-handling.
|
||||
let stream = tokio_signal::ctrl_c(&core.handle()).flatten_stream();
|
||||
let endless_stream = tokio_signal::ctrl_c(&core.handle()).flatten_stream();
|
||||
// don't keep going forever: convert the endless stream to a bounded one.
|
||||
let limited_stream = endless_stream.take(STOP_AFTER);
|
||||
|
||||
println!("This program is now waiting for you to press Ctrl+C
|
||||
// how many Ctrl+C have we received so far?
|
||||
let mut counter = 0;
|
||||
|
||||
println!("This program is now waiting for you to press Ctrl+C {0} times.
|
||||
* If running via `cargo run --example ctrl-c`, Ctrl+C also kills it, \
|
||||
due to https://github.com/rust-lang-nursery/rustup.rs/issues/806
|
||||
* If running the binary directly, the Ctrl+C is properly trapped. \
|
||||
Terminate by opening a second terminal and issue `pkill -sigkil ctrl-c`");
|
||||
* If running the binary directly, the Ctrl+C is properly trapped.
|
||||
Terminate by repeating Ctrl+C {0} times, or ahead of time by \
|
||||
opening a second terminal and issuing `pkill -sigkil ctrl-c`",
|
||||
STOP_AFTER);
|
||||
|
||||
// Stream::for_each is a powerful primitive provided by the Futures crate.
|
||||
// It turns a Stream into a Future that completes after all stream-items
|
||||
// have been completed, or the first time the closure returns an error
|
||||
let future = stream.for_each(|()| {
|
||||
println!("Ctrl+C received!");
|
||||
let future = limited_stream.for_each(|()| {
|
||||
|
||||
// Note how we manipulate the counter without any fancy synchronisation.
|
||||
// The borrowchecker realises there can't be any conflicts, so the closure
|
||||
// can just capture it.
|
||||
counter += 1;
|
||||
println!("Ctrl+C received {} times! {} more before exit",
|
||||
counter, STOP_AFTER-counter);
|
||||
|
||||
// return Ok-result to continue handling the stream
|
||||
Ok(())
|
||||
@ -39,6 +55,5 @@ fn main() {
|
||||
// on our event loop
|
||||
core.run(future).unwrap();
|
||||
|
||||
println!("this won't be printed, because the received Ctrl+C will also kill the program");
|
||||
unreachable!();
|
||||
println!("Stream ended, quiting the program.");
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user