package checked_oint

  1. Overview
  2. Docs
An OCaml library for checked integer arithmetic

Install

Dune Dependency

Authors

Maintainers

Sources

checked_oint-1.0.0.tar.gz
md5=36ea47218cba2e472850378cfe42e961
sha512=6bd8de498fbf2a1a769f31301c22811dd08513f0ebfda488ab6b8c6aac55c3a5c73aefeaf80a4fc4d54cab52bd154b48b614ee5c6bc041824f9164db0ca83d6a

Description

Published: 15 May 2025

README

checked_oint

checked_oint is an OCaml library for checked integer arithmetic. We support the full set of signed and unsigned integers of bitnesses 8, 16, 32, 64, and 128.

Installation

$ opam install checked_oint

Usage

open Checked_oint

let () =
  let x = U8.of_int_exn 50 in
  let y = U8.of_int_exn 70 in
  assert (U8.equal (U8.add_exn x y) (U8.of_int_exn 120));
  assert (Option.is_none (U8.mul x y))

You can find the API documentation here.

Implementation

  • u8, u16, i8, and i16 are represented as int internally.
  • u32 and i32 (resp. u64 and i64) are represented as int32 (resp. int64) internally.
  • u128 and i128 are represented as { high : int64; low : int64 } internally.
  • Operations on integers of 8, 16, 32, and 64 bits are implemented primarily in OCaml, save a small amount of C stub functions.
  • Operations on 128-bit integers are implemented solely in C.

Release procedure

  1. Update the version field in dune-project.
  2. Type dune build to generate checked_oint.opam.
  3. Update CHANGELOG.md.
  4. Release the project in GitHub Releases.

    1. Generate a source code archive and include it in the release:
      git archive HEAD -o checked_oint-<major>.<minor>.<patch>.tar.gz
  5. Type git pull && opam publish.

    1. Specify the correct archive URL and checksums (by running md5sum and sha512sum on the archive).
On the stability of source code archives

Including the output of git archive is needed because GitHub does not guarantee stability of source code archives. With a static asset, we will always get the same checksum, which is crucial for packaging.

Dependencies (6)

  1. alcotest >= "1.7.0"
  2. bisect_ppx
  3. ppx_enumerate
  4. ppx_deriving
  5. dune >= "3.14"
  6. ocaml >= "4.13"

Dev Dependencies (1)

  1. odoc with-doc

Used by

None

Conflicts

None

OCaml

Innovation. Community. Security.