parity-tokio-ipc

Crates.ioparity-tokio-ipc
lib.rsparity-tokio-ipc
version0.9.0
sourcesrc
created_at2018-09-26 10:27:54.070702
updated_at2021-07-06 12:13:02.522041
descriptionInterprocess communication library for tokio.
homepagehttps://github.com/paritytech/parity-tokio-ipc
repositoryhttps://github.com/paritytech/parity-tokio-ipc
max_upload_size
id86608
size52,249
Core devs (github:paritytech:core-devs)

documentation

README

parity-tokio-ipc

CI Documentation

This crate abstracts interprocess transport for UNIX/Windows.

It utilizes unix sockets on UNIX (via tokio::net::UnixStream) and named pipes on windows (via tokio::net::windows::named_pipe module).

Endpoint is transport-agnostic interface for incoming connections:

use parity_tokio_ipc::Endpoint;
use futures::stream::StreamExt;

// For testing purposes only - instead, use a path to an actual socket or a pipe
let addr = parity_tokio_ipc::dummy_endpoint();

let server = async move {
    Endpoint::new(addr)
        .incoming()
        .expect("Couldn't set up server")
        .for_each(|conn| async {
            match conn {
                Ok(stream) => println!("Got connection!"),
                Err(e) => eprintln!("Error when receiving connection: {:?}", e),
            }
        });
};

let rt = tokio::runtime::Builder::new_current_thread().enable_all().build().unwrap();
rt.block_on(server);

License

parity-tokio-ipc is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.

See LICENSE-APACHE, and LICENSE-MIT for details.

Commit count: 137

cargo fmt