summaryrefslogtreecommitdiff
path: root/src/main.rs
blob: 037cacba561f1950fe7e26db10f13c02368a7996 (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#![feature(hash_drain_filter)]

mod gfx;
mod net;

use cgmath::{Deg, Point3};
use std::collections::HashMap;
use tokio::sync::mpsc;

#[derive(Debug, Clone)]
pub enum GfxEvent {
    Close,
    Media(HashMap<String, Vec<u8>>, bool),
    NodeDefs(HashMap<u16, mt_net::NodeDef>),
    MapBlock(Point3<i16>, Box<mt_net::MapBlock>),
    PlayerPos(Point3<f32>, Deg<f32>, Deg<f32>),
    MovementSpeed(f32),
}

#[derive(Debug, Clone)]
pub enum NetEvent {
    PlayerPos(Point3<f32>, Deg<f32>, Deg<f32>),
    Ready,
}

fn main() {
    println!(include_str!("../assets/ascii-art.txt"));
    println!("Early WIP. Expect breakage. Trans rights <3");

    let (net_tx, net_rx) = mpsc::unbounded_channel();
    let event_loop = winit::event_loop::EventLoopBuilder::<GfxEvent>::with_user_event().build();
    let event_loop_proxy = event_loop.create_proxy();

    let runtime = tokio::runtime::Builder::new_multi_thread()
        .enable_io()
        .enable_time()
        .thread_name("network")
        .build()
        .unwrap();

    let net_thread = runtime.spawn(net::run(event_loop_proxy.clone(), net_rx));
    let net_recover_thread = std::thread::spawn(move || {
        runtime.block_on(net_thread).ok();
        event_loop_proxy.send_event(GfxEvent::Close).ok(); // tell graphics to shut down
    });

    // graphics code is pseudo async: the winit event loop is blocking
    // so we can't really use async capabilities
    futures::executor::block_on(gfx::run(event_loop, net_tx));

    // wait for net to finish
    net_recover_thread.join().unwrap();
}