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

Source file pid.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
type t = { _id : int64 } [@@unboxed]

let pp ppf pid = Format.fprintf ppf "<0.%s.0>" (Int64.to_string pid._id)
let make _id = { _id }
let zero : t = make 0L
let __current__ = Atomic.make 1L

let rec next () =
  let last = Atomic.get __current__ in
  let current = last |> Int64.succ in
  if Atomic.compare_and_set __current__ last current then make last else next ()

let equal a b = Int64.equal a._id b._id
let compare a b = Int64.compare a._id b._id
let hash t = Int64.hash t._id

let reset () =
  Log.debug (fun f -> f "Resetting Process Ids");
  Atomic.set __current__ 1L
OCaml

Innovation. Community. Security.