ocaml-opentelemetry/src/core/AList.ml
2023-12-20 15:45:57 -05:00

23 lines
400 B
OCaml

module Atomic = Opentelemetry_atomic.Atomic
type 'a t = 'a list Atomic.t
let make () = Atomic.make []
let get = Atomic.get
let add self x =
while
let old = Atomic.get self in
let l' = x :: old in
not (Atomic.compare_and_set self old l')
do
()
done
let rec pop_all self =
let l = Atomic.get self in
if Atomic.compare_and_set self l [] then
l
else
pop_all self