package eio

  1. Overview
  2. Docs
Effect-based direct-style IO API for OCaml

Install

Dune Dependency

Authors

Maintainers

Sources

eio-1.0.tbz
sha256=da260d9da38b3dde9f316652a20b13a261cf90b85a2498ac669b7d564e61942d
sha512=5886e1159f48ede237769baa1d8b5daafa0310e4192d7fe0e8c32aef70f2b6378cef72d0fbae308457e25d87a69802b9ee83a5e8f23e0591d83086a92d701c46

doc/src/eio.utils/zzz.ml.html

Source file zzz.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
module Key = struct
  type t = Optint.Int63.t
  let compare = Optint.Int63.compare
end

type item =
  | Fiber of unit Suspended.t
  | Fn of (unit -> unit)

module Job = struct
  type t = {
    time : Mtime.t;
    item : item;
  }

  let compare a b = Mtime.compare a.time b.time
end

module Q = Psq.Make(Key)(Job)

type t = {
  mutable sleep_queue: Q.t;
  mutable next_id : Optint.Int63.t;
}

let create () = { sleep_queue = Q.empty; next_id = Optint.Int63.zero }

let add t time item =
  let id = t.next_id in
  t.next_id <- Optint.Int63.succ t.next_id;
  let sleeper = { Job.time; item } in
  t.sleep_queue <- Q.add id sleeper t.sleep_queue;
  id

let remove t id =
  t.sleep_queue <- Q.remove id t.sleep_queue

let pop t ~now =
  match Q.min t.sleep_queue with
  | Some (_, { Job.time; item }) when time <= now ->
    begin
      match item with
      | Fiber k -> Eio.Private.Fiber_context.clear_cancel_fn k.fiber
      | Fn _ -> ()
    end;
    t.sleep_queue <- Option.get (Q.rest t.sleep_queue);
    `Due item
  | Some (_, { Job.time; _ }) -> `Wait_until time
  | None -> `Nothing
OCaml

Innovation. Community. Security.