mirage-flow-lwt

Flow implementations and combinators for MirageOS specialized to lwt
README

This repo contains generic operations over Mirage FLOW implementations.

Please consult the API documentation.

Example usage

In a top-level like utop:

# #require "mirage-flow";;
# #require "mirage-clock-unix";;
# #require "lwt.syntax";;

# let a = Mirage_flow.Fun.(make ~input:(input_string "hellooooo") ());;
val a : Mirage_flow.Fun.flow = <abstr>

# let buffer = String.make 20 ' ';;
val buffer : bytes = "                    "
# let b = Mirage_flow.Fun.(make ~output:(output_string buffer) ());;
val b : Mirage_flow.Fun.flow = <abstr>

# lwt results = Mirage_flow.copy (module Clock) (module Mirage_flow.Fun) a (module Mirage_flow.Fun) b ();;
val results : [ `Error of [ `Msg of bytes ] | `Ok of Mirage_flow.CopyStats.t ] =  `Ok {Mirage_flow.CopyStats.read_bytes = 9L; read_ops = 1L; write_bytes = 9L; write_ops = 1L; duration = 6.9141387939453125e-06}
# buffer;;
- : bytes = "hellooooo           "
Install
Sources
mirage-flow-v1.6.0.tbz
sha256=d6596e9bd2442023a3b2222db0a36fd6a97318e06853162c9938d9fab8cc63d3
sha512=2666268cb4e7208357083a733565e5f07e15ca77bd35b1a00c7fd1562b7abc8e1eb8ec1a5bd5782240993621e6bcaa7003f6143d77b8da09491e5c38b645faeb
Dependencies
mirage-flow
>= "1.2.0" & < "2.0.0"
mirage-clock
>= "1.2.0" & < "3.0.0"
cstruct
>= "2.0.0" & < "6.1.0"
dune
>= "1.0"
ocaml
>= "4.04.2"
Reverse Dependencies
capnp-rpc-lwt
< "0.5.0"
capnp-rpc-net
< "0.6.0"
cohttp-mirage
< "2.4.0"
datakit-server
>= "0.10.0" & < "0.11.0"
dns-forward
>= "0.9.0"
git-mirage
< "2.1.2"
hvsock
>= "0.14.0" & < "3.0.0"
mirage-conduit
< "2.0.0" | >= "2.3.0"
mirage-http
>= "3.0.0"
mirage-types-lwt
>= "3.0.0" & < "3.7.1"
protocol-9p
>= "0.9.0" & < "2.0.2"
vchan
>= "2.3.0" & < "5.0.0"
vchan-unix
< "5.0.0"
vchan-xen
< "5.0.0"
vpnkit
>= "0.1.1"