message-io 0.9.2

Easy asynchronous network message library
Documentation
use message_io::network::{Network, NetEvent, Transport};

fn main() {
    let args: Vec<String> = std::env::args().collect();
    let my_name = match args.get(1) {
        Some(name) => name,
        None => return println!("Please choose a name"),
    };

    let (mut event_queue, mut network) = Network::split();

    let addr = "239.255.0.1:3010";
    match network.connect(Transport::Udp, addr) {
        Ok((endpoint, _)) => {
            println!("Notifying on the network");
            network.send(endpoint, my_name.as_bytes());
        }
        Err(_) => return eprintln!("Could not connect to {}", addr),
    }

    // Since the addrs belongs to the multicast range (from 224.0.0.0 to 239.255.255.255)
    // the internal resource will be configured to receive multicast messages.
    network.listen(Transport::Udp, addr).unwrap();

    loop {
        match event_queue.receive() {
            NetEvent::Message(_, data) => {
                println!("{} greets to the network!", String::from_utf8_lossy(&data));
            }
            NetEvent::Connected(_) => (),
            NetEvent::Disconnected(_) => (),
        }
    }
}