mirage-flow

Flow implementations and combinators for MirageOS
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
Published
10 Jul 2018
Sources
mirage-flow-1.5.0.tbz
md5=a9e90517457514cc5c46ec46f477d01f
Dependencies
jbuilder
>= "1.0+beta7"
ocaml
>= "4.04.2"
Reverse Dependencies
git
>= "1.5.2" & < "1.10.0"
git-paf
>= "3.5.0"
mirage-console
>= "2.2.0" & < "3.0.0"
mirage-types
>= "3.0.0" & < "3.7.1"
tcpip
= "2.4.2" | = "2.6.1" | = "2.8.0" | >= "3.0.0" & < "4.0.0"
vpnkit
< "0.1.1"