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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// [[file:../remote.note::dba9de5e][dba9de5e]]
//! Distributed parallel computing over multiple nodes.
// dba9de5e ends here

// [[file:../remote.note::963f5eb8][963f5eb8]]
use gosh_core::*;
use gut::prelude::*;

use rand::Rng;
use std::path::{Path, PathBuf};
// 963f5eb8 ends here

// [[file:../remote.note::b21b77b4][b21b77b4]]
mod base;
mod client;
mod interactive;
mod scheduler;
mod server;
mod worker;

pub mod cli;
pub mod rest;
pub mod task;
// b21b77b4 ends here

// [[file:../remote.note::5c33a18a][5c33a18a]]
/// Return system host name
fn hostname() -> String {
    let mut buf = [0u8; 512];
    nix::unistd::gethostname(&mut buf)
        .unwrap()
        .to_str()
        .unwrap()
        .to_string()
}
// 5c33a18a ends here

// [[file:../remote.note::92bf67b7][92bf67b7]]
use std::net::{SocketAddr, TcpListener, ToSocketAddrs};

/// Test if `address` available for socket binding
pub fn address_available<A: ToSocketAddrs>(address: A) -> bool {
    match TcpListener::bind(address) {
        Ok(_) => true,
        Err(_) => false,
    }
}

/// Return the address available for binding with the OS assigns port.
pub fn get_free_tcp_address() -> Option<SocketAddr> {
    let host = hostname();
    TcpListener::bind(format!("{host}:0")).ok()?.local_addr().ok()
}

#[test]
fn test_addr() {
    let addr = get_free_tcp_address().unwrap();
    assert!(address_available(dbg!(addr)));
}
// 92bf67b7 ends here

// [[file:../remote.note::0a725e9c][0a725e9c]]
pub use base::LockFile;
// 0a725e9c ends here

// [[file:../remote.note::56d334b5][56d334b5]]
#[cfg(feature = "adhoc")]
/// Docs for local mods
pub mod docs {
    macro_rules! export_doc {
        ($l:ident) => {
            pub mod $l {
                pub use crate::$l::*;
            }
        };
    }

    export_doc!(base);
    export_doc!(interactive);
    export_doc!(worker);
}
// 56d334b5 ends here