Mentions légales du service

Skip to content
Snippets Groups Projects
François Pottier's avatar
POTTIER Francois authored
f8c53103
History

Sek

This OCaml library offers an efficient implementation of sequences.

This data structure supports all of the standard operations on stacks, queues, deques (e.g. push, pop at either end), catenable sequences (concat, split), and random access sequences (get, set).

Data is stored internally in chunks (fixed-capacity arrays), which is why this data structure is known as a chunk sequence.

This data structure comes in two flavors, namely an ephemeral (mutable) flavor and a persistent (immutable) flavor, and offers constant-time conversions between these flavors.

It is intended to achieve excellent time complexity and memory usage.

Installation

To install the latest released version, type:

  opam update
  opam install sek

To install the latest development version, type:

  git clone git@gitlab.inria.fr:fpottier/sek
  cd sek
  opam pin add sek .

To install the latest development version with debugging assertions enabled, type:

  git clone git@gitlab.inria.fr:fpottier/sek
  cd sek
  make setup
  make install

Documentation

The documentation of the latest released version is available online. Here are shortcuts to the ephemeral sequence API, the persistent sequence API, and the conversion functions.

The documentation is built locally by make doc and can be viewed via make view.

The file play.ml allows playing with the library in the OCaml toplevel loop.

Development Guidelines

To retrieve and compile the source code, type:

  git clone git@gitlab.inria.fr:fpottier/sek
  make setup
  make

To set up an opam switch that allows testing Sek, type this (only once):

  make -C fuzz setup

You must also install AFL.

Then, to test the library using afl-fuzz, type:

  make test
  # This command runs forever; interrupt it with Ctrl+C when you wish