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
- Authors
-
- Maintainers
-
Sources
mirage-flow-v3.0.0.tbz
sha256=d70bda6c85ec2747bed88bc4d95f269d2810503b92913f0807be5291696138fc
sha512=2aeb397799621bc0ea2485b68058949c99b3da8d454939d594a9b2d39ef47aa2c16489f06adfa2dea3b34fd15e60a23abc6b8e214dfbc8b7da2e958de7c36b57
Dependencies
Reverse Dependencies
arp
>= "2.3.2"
capnp-rpc-net
>= "0.6.0"
cohttp-mirage
>= "2.4.0"
conduit-mirage
>= "2.0.2"
git
>= "3.0.0"
git-mirage
>= "2.1.2"
git-paf
>= "3.5.0"
git-unix
>= "3.0.0"
h2-mirage
>= "0.4.0"
hvsock
>= "3.0.0"
mirage-channel
>= "4.0.0"
mirage-console
>= "3.0.0"
mirage-console-xen
>= "4.0.0"
mirage-flow-combinators
>= "3.0.0"
mirage-flow-unix
>= "3.0.0"
mirage-protocols
>= "4.0.0" & < "8.0.0"
mirage-types
>= "3.7.1"
protocol-9p
>= "2.0.2"
protocol-9p-unix
>= "2.0.2"
tcpip
>= "5.0.1"
vchan
>= "5.0.0"
vchan-unix
>= "5.0.0"
vchan-xen
>= "5.0.0"