Source file busy_poller.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
open Core
module type S = Busy_poller_intf.S
module Empty_poller = struct
type t = unit
let poll (_t : t) ~deadline:_ = 0
let kind = Type_equal.Id.create ~name:"empty" [%sexp_of: _]
end
type packed = T : (module S with type t = 'a) * 'a -> packed
let[@inline always] poll (T ((module P), poller)) ~deadline = P.poll poller ~deadline
let create impl poller = T (impl, poller)
let create' f = create (module Extra_poller) f
let empty = create (module Empty_poller) ()