(**************************************************************************) (* *) (* Copyright (c) 2014 - 2017. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) (** Imperative Ring Buffer *) (** An imperative ring buffer: a mutable structure that holds at most a fixed number of values of a same type. Values are never removed, once the limit is reached, adding a value replaces the oldest one in the ring buffer. *) type 'a t (** Allocates a ring buffer for a given number of values. *) val create : int -> 'a t (** Adds a value, dropping the oldest present one if full. *) val add : 'a t -> 'a -> unit (** Same as {!add}, but returns the dropped value if any. *) val add_and_return_erased : 'a t -> 'a -> 'a option (** Adds the values of a list, in order. *) val add_list : 'a t -> 'a list -> unit (** Retrieves the most recent value, or [None] when empty. *) val last : 'a t -> 'a option exception Empty (** Same as {!last}, but raises {!Empty} when empty. *) val last_exn : 'a t -> 'a (** Iterates over the elements, oldest to newest. *) val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b) -> 'b (** Retrieves the elements as a list, oldest first.. *) val elements : 'a t -> 'a list