package eio
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Effect-based direct-style IO API for OCaml
Install
dune-project
Dependency
Authors
Maintainers
Sources
eio-1.1.tbz
sha256=346104884077f140b3574e1daccc02212960c6efeb793c803e3e6b8bafea0fab
sha512=18abde418c56b1ceed3e8f075cb94e5c951b5cfea967ec4cb5f8e1e4d635b801b3c9e6ec61f89483490dbec143c33b9b76d947bff1183d44e6e0e01d93821dfb
doc/src/eio/process.ml.html
Source file process.ml
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 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160open Std type exit_status = [ | `Exited of int | `Signaled of int ] type status = [ exit_status | `Stopped of int ] let pp_status ppf = function | `Exited i -> Format.fprintf ppf "Exited (code %i)" i | `Signaled i -> Format.fprintf ppf "Exited (signal %a)" Fmt.Dump.signal i | `Stopped i -> Format.fprintf ppf "Stopped (signal %a)" Fmt.Dump.signal i type error = | Executable_not_found of string | Child_error of exit_status type Exn.err += E of error let err e = Exn.create (E e) let () = Exn.register_pp (fun f -> function | E e -> Fmt.string f "Process "; begin match e with | Executable_not_found e -> Fmt.pf f "Executable %S not found" e; | Child_error e -> Fmt.pf f "Child_error %a" pp_status e; end; true | _ -> false ) type 'tag ty = [ `Process | `Platform of 'tag ] type 'a t = ([> [> `Generic] ty] as 'a) r type 'tag mgr_ty = [ `Process_mgr | `Platform of 'tag ] type 'a mgr = 'a r constraint 'a = [> [> `Generic] mgr_ty] module Pi = struct module type PROCESS = sig type t type tag val pid : t -> int val await : t -> exit_status val signal : t -> int -> unit end type (_, _, _) Resource.pi += | Process : ('t, (module PROCESS with type t = 't and type tag = 'tag), [> 'tag ty]) Resource.pi let process (type t tag) (module X : PROCESS with type t = t and type tag = tag) = Resource.handler [ H (Process, (module X)); ] module type MGR = sig type tag type t val pipe : t -> sw:Switch.t -> [Flow.source_ty | Resource.close_ty] r * [Flow.sink_ty | Resource.close_ty] r val spawn : t -> sw:Switch.t -> ?cwd:Fs.dir_ty Path.t -> ?stdin:Flow.source_ty r -> ?stdout:Flow.sink_ty r -> ?stderr:Flow.sink_ty r -> ?env:string array -> ?executable:string -> string list -> tag ty r end type (_, _, _) Resource.pi += | Mgr : ('t, (module MGR with type t = 't and type tag = 'tag), [> 'tag mgr_ty]) Resource.pi let mgr (type t tag) (module X : MGR with type t = t and type tag = tag) = Resource.handler [ H (Mgr, (module X)); ] end let bad_char = function | ' ' | '"' | '\'' | '\\' -> true | c -> let c = Char.code c in c <= 32 || c >= 127 let pp_arg f x = if x = "" || String.exists bad_char x then Fmt.pf f "%S" x else Fmt.string f x let pp_args = Fmt.hbox (Fmt.list ~sep:Fmt.sp pp_arg) let await (type tag) ((Resource.T (v, ops)) : [> tag ty] r) = let module X = (val (Resource.get ops Pi.Process)) in X.await v let await_exn ?(is_success = Int.equal 0) proc = match await proc with | `Exited code when is_success code -> () | status -> raise (err (Child_error status)) let pid (type tag) (t : [> tag ty] r) = let (Resource.T (v, ops)) = t in let module X = (val (Resource.get ops Pi.Process)) in X.pid v let signal (type tag) (t : [> tag ty] r) s = let (Resource.T (v, ops)) = t in let module X = (val (Resource.get ops Pi.Process)) in X.signal v s let spawn (type tag) ~sw (t : [> tag mgr_ty] r) ?cwd ?stdin ?stdout ?stderr ?env ?executable args : tag ty r = let (Resource.T (v, ops)) = t in let module X = (val (Resource.get ops Pi.Mgr)) in X.spawn v ~sw ?cwd:(cwd :> Fs.dir_ty Path.t option) ?env ?executable args ?stdin:(stdin :> Flow.source_ty r option) ?stdout:(stdout :> Flow.sink_ty r option) ?stderr:(stderr :> Flow.sink_ty r option) let run t ?cwd ?stdin ?stdout ?stderr ?(is_success = Int.equal 0) ?env ?executable args = Switch.run ~name:"Process.run" @@ fun sw -> let child = spawn ~sw t ?cwd ?stdin ?stdout ?stderr ?env ?executable args in match await child with | `Exited code when is_success code -> () | status -> let ex = err (Child_error status) in raise (Exn.add_context ex "running command: %a" pp_args args) let pipe (type tag) ~sw ((Resource.T (v, ops)) : [> tag mgr_ty] r) = let module X = (val (Resource.get ops Pi.Mgr)) in X.pipe v ~sw let parse_out (type tag) (t : [> tag mgr_ty] r) parse ?cwd ?stdin ?stderr ?is_success ?env ?executable args = Switch.run ~name:"Process.parse_out" @@ fun sw -> let r, w = pipe t ~sw in try let child = spawn ~sw t ?cwd ?stdin ~stdout:w ?stderr ?env ?executable args in Flow.close w; let output = Buf_read.parse_exn parse r ~max_size:max_int in Flow.close r; await_exn ?is_success child; output with Exn.Io _ as ex -> let bt = Printexc.get_raw_backtrace () in Exn.reraise_with_context ex bt "running command: %a" pp_args args
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>