mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-09-28 12:10:37 +00:00

The signal-hook library got split into lower-level and higher-level parts. The tokio-signal uses only API from the lower-level one, so it can depend on it directly. The only effect of this change is smaller amount of compiled (and unused) code during compilation. There's no change in the code actually used.
tokio-signal
Unix signal handling for Tokio.
Usage
First, add this to your Cargo.toml
:
[dependencies]
tokio-signal = "0.2.8"
Next you can use this in conjunction with the tokio
and futures
crates:
extern crate futures;
extern crate tokio;
extern crate tokio_signal;
use futures::{Future, Stream};
fn main() {
// Create an infinite stream of "Ctrl+C" notifications. Each item received
// on this stream may represent multiple ctrl-c signals.
let ctrl_c = tokio_signal::ctrl_c().flatten_stream();
// Process each ctrl-c as it comes in
let prog = ctrl_c.for_each(|()| {
println!("ctrl-c received!");
Ok(())
});
tokio::run(prog.map_err(|err| panic!("{}", err)));
}
License
This project is licensed under the MIT license.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Tokio by you, shall be licensed as MIT, without any additional terms or conditions.