package capnp-rpc

  1. Overview
  2. Docs

Module Capnp_rpc.RCSource

A ref-count type that raises an exception on overflow.

Sourcetype t

A number used as a reference count.

Sourceval zero : t
Sourceval one : t
Sourceval leaked : t

leaked is used to represent a ref-count that is invalid because we detected a GC leak.

Sourceval sum : pp:(Format.formatter -> unit) -> t -> int -> t

sum ~pp t d is t + d. Raises an exception (including pp) if this would overflow or become negative, or if t is zero or leaked.

Sourceval succ : pp:(Format.formatter -> unit) -> t -> t

succ ~pp t is add ~pp t 1.

Sourceval pred : pp:(Format.formatter -> unit) -> t -> t

pred ~pp t is add ~pp t (-1).

Sourceval is_zero : t -> bool

is_zero t is true if the ref-count is zero (the resource should be released). is_zero leaked = false, since whatever detected the leak should free it.

Sourceval pp : t Fmt.t
Sourceval check : pp:(Format.formatter -> unit) -> t -> unit

check ~pp t raises an exception (including pp) if t is zero or leaked. Useful in sanity checks.

Sourceval to_int : t -> int option

to_int t is the non-negative integer ref-count, or None if t = leaked.