ocaml-opentelemetry/src/client/AList.ml
Simon Cruanes b676783100
format
2022-05-05 12:09:19 -04:00

21 lines
378 B
OCaml

module Atomic = Opentelemetry_atomic.Atomic
type 'a t = 'a list Atomic.t
let make () = Atomic.make []
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