summaryrefslogtreecommitdiff
path: root/src/util.ml
blob: b37ae4f417011eac023adc10df19653e9cfc15d2 (plain) (blame)
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
open Unix

let (@@) a b = a b

type id = int * int
let new_id () : id = (Random.int 100000, Random.int 100000)
let id_str (a, b) = Format.sprintf "%d.%d" a b

(* make_addr : string -> int -> sockaddr *)
let make_addr host port =
	let host = gethostbyname host in
	ADDR_INET(host.h_addr_list.(Random.int (Array.length host.h_addr_list)), port)


(* Unmarshal ONE message from a file descriptor, and DO NOT buffer more data *)
let read_one_msg fd =
	let hdr = String.create Marshal.header_size in
	assert (read fd hdr 0 Marshal.header_size = Marshal.header_size);
	let dlen = Marshal.data_size hdr 0 in
	let data = String.create dlen in
    let rl = ref 0 in
    while !rl < dlen do
       rl := !rl + read fd data !rl (dlen - !rl)
    done;
	Marshal.from_string (hdr ^ data) 0