Skip to content

darklang/tablecloth-ocaml-base

Repository files navigation

Tablecloth-ocaml-base

CircleCI Opam

Tablecloth is a library that shims over various standard libraries so they have the same function and module names, which using idiomatic types and patterns in each language.

This is the OCaml implementation, which uses Base, pipe-last, keyword arguments, and snake_case.

Tablecloth is alpha-quality software, and is pre-1.0. It is currently undergoing some significant shifts and some libraries listed below are not available yet. Caveat emptor.

Check out the website for our interactive API documentation, or join the community in the Tablecloth Discord.

Installation

Note: these instructions are for the upcoming new version of tablecloth

Install via opam:

opam install tablecloth-ocaml-base

Then add to your dune file:

(libraries (tablecloth-ocaml-base ...))

Usage

The recommended way to use Tablecloth is with a top-level open at the beginning of a file.

This will ensure that all the built-in modules are replaced.

open Tablecloth

let () =
  String.to_list "somestring"
  |> List.map ~f:Char.to_code
  |> List.map ~f:(fun x -> x+1)
  |> List.filter_map ~f:Char.from_code
  |> String.from_list

Supported versions

Tablecloth for native OCaml supports OCaml 4.10-4.14 with Base v0.15.1, and OCaml 4.14 and above with Base v0.16.3/v0.17.1. We are open to supporting other versions:

  • OCaml 4.06 and 4.07 require small tweaks to our build system
  • Base v0.9 to v0.14 require small code changes

Development

When developing Tablecloth, you can test it against different versions of OCaml (native) and Base, using the following commands:

  • TC_BASE_VERSION=v0.16.3 TC_NATIVE_OCAML_SWITCH=5.2.0 make deps

Contributions

The maintainers are warm and friendly, and the project abides by a Code of Conduct.

There are many small tasks to be done - a small change to a single function can be extremely helpful. We also welcome new versions of tablecloth for other languages, or even for the same language but based on other libraries.

Check out the dedicated guide on contributing for more.

Developing

Please refer to the Makefile for a complete list of supported actions. Here is a handful of useful, supported commands:

  • make deps: Install OCaml dependencies.
  • make build: Build the project.
  • make test: Run the test suite. You may need to make build first.
  • make check-format: Check your code is formatted correctly.
  • make format: Format code.
  • cd ocamldoc-json-generator && make deps && make doc: Build model.json for the website (needs to be updated and checked in whenever the APIs change.)

Dependencies

License

Tablecloth uses the MIT license.

Authors

Initially written by Darklang.