summaryrefslogtreecommitdiffstats
path: root/tokio-signal/examples/sighup-example.rs
blob: e48e23ea369f739bd871304a2fa7e558f84b3d02 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
extern crate futures;
extern crate tokio_core;
extern crate tokio_signal;

use futures::{Future, Stream};
use tokio_core::reactor::Core;
use tokio_signal::unix::{Signal, SIGHUP};

fn main() {
    // set up a Tokio event loop
    let mut core = Core::new().unwrap();

    // on Unix, we can listen to whatever signal we want, in this case: SIGHUP
    let stream = Signal::new(SIGHUP).flatten_stream();

    println!("Waiting for SIGHUPS (Ctrl+C to quit)");
    println!(
        "  TIP: use `pkill -sighup sighup-example` from a second terminal \
         to send a SIGHUP to all processes named 'sighup-example' \
         (i.e. this binary)"
    );

    // 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.
    let future = stream.for_each(|the_signal| {
        println!(
            "*Got signal {:#x}* I should probably reload my config \
             or something",
            the_signal
        );
        Ok(())
    });

    // Up until now, we haven't really DONE anything, just prepared
    // now it's time to actually schedule, and thus execute, the stream
    // on our event loop, and loop forever
    core.run(future).unwrap();
}