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
open Functoria.DSL
open Ip
open Misc
open Functoria.Action
type 'a tcp = TCP
type tcpv4v6 = v4v6 tcp
let tcp = Functoria.Type.Type TCP
let tcpv4v6 : tcpv4v6 typ = tcp
let tcp_direct_func () =
let packages_v = right_tcpip_library ~sublibs:[ "tcp" ] "tcpip" in
let connect _ modname = function
| [ ip ] -> code ~pos:__POS__ "%s.connect %s" modname ip
| _ -> connect_err "tcp" 1
in
impl ~packages_v ~connect "Tcp.Flow.Make" (ip @-> tcp)
let direct_tcp ip = tcp_direct_func () $ ip
let tcpv4v6_socket_conf ~ipv4_only ~ipv6_only ipv4_key ipv6_key =
let v = Runtime_arg.v in
let runtime_args = [ v ipv4_only; v ipv6_only; v ipv4_key; v ipv6_key ] in
let packages_v = right_tcpip_library ~sublibs:[ "tcpv4v6-socket" ] "tcpip" in
let configure i =
match get_target i with
| `Unix | `MacOSX -> ok ()
| _ -> error "TCPv4v6 socket not supported on non-UNIX targets."
in
let connect _ modname = function
| [ ipv4_only; ipv6_only; ipv4_key; ipv6_key ] ->
code ~pos:__POS__ "%s.connect ~ipv4_only:%s ~ipv6_only:%s %s %s" modname
ipv4_only ipv6_only ipv4_key ipv6_key
| _ -> connect_err "tcpv4v6_socket_conf" 4
in
impl ~packages_v ~configure ~runtime_args ~connect "Tcpv4v6_socket" tcpv4v6