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
module Action = Functoria.Action
open Functoria.DSL
open Ip
open Misc
type 'a udp = UDP
type udpv4v6 = v4v6 udp
let udp = Functoria.Type.Type UDP
let udpv4v6 : udpv4v6 typ = udp
let udp_direct_func () =
let packages_v = right_tcpip_library ~sublibs:[ "udp" ] "tcpip" in
let connect _ modname = function
| [ ip ] -> code ~pos:__POS__ "%s.connect %s" modname ip
| _ -> connect_err "udp" 1
in
impl ~packages_v ~connect "Udp.Make" (ip @-> udp)
let direct_udp ip = udp_direct_func () $ ip
let udpv4v6_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:[ "udpv4v6-socket" ] "tcpip" in
let configure i =
match get_target i with
| `Unix | `MacOSX -> Action.ok ()
| _ -> Action.error "UDPv4v6 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 "udpv4v6_socket_conf" 4
in
impl ~runtime_args ~packages_v ~configure ~connect "Udpv4v6_socket" udpv4v6