Skip to content

Latest commit

 

History

History
62 lines (53 loc) · 2 KB

README.md

File metadata and controls

62 lines (53 loc) · 2 KB

wormhole-rs

Wormhole is a simple IPC implementation inspired by the channel interface from both Golang and Rust::mspc. The main use case is to allow for continues sequence process (CSP) style multi process programming, similar to how channels are used in multi threaded programing. Here, we use a simple protocol to transmit serialized data through anonimious unix domain socket by prefixing the length of the serialized data.

Inspiration and Design Goal

I found two projects before I decided to implement my own crate for inter-process IPC channel. The first one is tinu-nix-ipc and the second one is ipc-channel. Both of these project is much more complex and offers much more features. The aim of the wormhole-rs project is to have a simplified implementation without any of the complexity. As a result, we decided to only support:

  1. Linux platform
  2. A simple API of send, send_with_fds, recv, and recv_with_fds.
  3. Only JSON encoding for serialization.

Example

#[derive(Debug, Default, Serialize, Deserialize, PartialEq)]
struct TestMessage {
    a: i32,
    b: String,
    c: Vec<i32>,
}

// ....

let (mut sender, mut receiver) =
    channel::<TestMessage>().expect("failed to create channel");
let test_message = TestMessage {
    a: 1776,
    b: String::from("hello world!"),
    c: vec![5, 4, 3, 2, 1],
};

match unsafe { nix::unistd::fork().expect("failed fork") } {
    nix::unistd::ForkResult::Parent { child } => {
        let res = receiver
            .recv()
            .expect("failed to receive from child process");
        wait::waitpid(child, None).expect("failed wait for pid");
        assert_eq!(
            test_message, res,
            "received message doesn't match the send message"
        );
    }
    nix::unistd::ForkResult::Child => {
        sender
            .send(test_message)
            .expect("failed to send from the child process");
        std::process::exit(0);
    }
};