package riot

  1. Overview
  2. Docs
An actor-model multi-core scheduler for OCaml 5

Install

Dune Dependency

Authors

Maintainers

Sources

riot-0.0.5.tbz
sha256=01b7b82ccc656b12b7315960d9df17eb4682b8f1af68e9fee33171fee1f9cf88
sha512=d8831d8a75fe43a7e8d16d2c0bb7d27f6d975133e17c5dd89ef7e575039c59d27c1ab74fbadcca81ddfbc0c74d1e46c35baba35ef825b36ac6c4e49d7a41d0c2

doc/src/riot.core/mailbox.ml.html

Source file mailbox.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
open Util

type t = { size : int Atomic.t; queue : Message.envelope Lf_queue.t }

let create () = { size = Atomic.make 0; queue = Lf_queue.create () }

let queue t msg =
  Atomic.incr t.size;
  Lf_queue.push t.queue msg

let next (t : t) =
  match Lf_queue.pop t.queue with
  | Some msg ->
      Atomic.decr t.size;
      Some msg
  | None ->
      Atomic.set t.size 0;
      None

let size (t : t) = Atomic.get t.size
let is_empty (t : t) = Lf_queue.is_empty t.queue
OCaml

Innovation. Community. Security.