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/proc_queue.ml.html

Source file proc_queue.ml

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

type t = { alive : Proc_set.t; queue : Process.t Lf_queue.t }

let create () = { queue = Lf_queue.create (); alive = Proc_set.create () }
let size t = Proc_set.size t.alive

let queue t proc =
  if Proc_set.contains t.alive proc then ()
  else (
    Proc_set.add t.alive proc;
    Lf_queue.push t.queue proc)

let next t =
  match Lf_queue.pop t.queue with
  | Some proc ->
      Proc_set.remove t.alive proc;
      Some proc
  | None -> None
OCaml

Innovation. Community. Security.