# foundationdb-haskell **Repository Path**: chenyingzi/foundationdb-haskell ## Basic Information - **Project Name**: foundationdb-haskell - **Description**: No description available - **Primary Language**: Unknown - **License**: BSD-3-Clause - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-09-11 - **Last Updated**: 2024-09-11 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README [![GitHub CI](https://github.com/crclark/foundationdb-haskell/workflows/CI/badge.svg)](https://github.com/crclark/foundationdb-haskell/actions) [API Docs](https://crclark.github.io/foundationdb-haskell/) Haskell bindings for the FoundationDB C client. Currently contains FFI bindings to all of the C API, a `Transaction` monad for defining transactions ([example](https://github.com/crclark/foundationdb-haskell/blob/1f8d0ba2c4985d2fe3d8e6fcbc852c01050af9bb/tests/Properties.hs#L48)), and implementations of the standard tuple, subspace and directory layers. I am not using this in a production-like context, but I have exercised the code rather heavily (heavy transaction rates for days at a time) in both local and cloud environments. The major missing component is directory partitions, but I haven't needed them yet. Generally speaking, the directory layer is the least exercised part of the library. ### Supported FoundationDB versions Currently supports 5.2.x through 7.1.x. By default, this package builds assuming that you have installed the latest supported version of FoundationDB. If not, you need to set the appropriate flag when building the library. For example, if you installed FoundationDB 6.0.x, you need to build with `stack build --flag foundationdb-haskell:fdb-version-600` or `cabal configure -f fdb-version-600 && cabal build` ### Development #### Generating options from `fdb.options` FoundationDB provides [a specification](https://github.com/apple/foundationdb/blob/master/fdbclient/vexillographer/fdb.options) of available client options. We generate the `FoundationDB.Options` module from this file with the `generate-options` executable in this project. To build the `generate-options` executable, pass the `with-generate-options` flag when building. For example, when building with `stack`, the command is ``` stack build --flag foundationdb-haskell:with-generate-options ``` You can then invoke it on `fdb.options`. ``` stack exec generate-options -- --file /usr/include/foundationdb/fdb.options ``` this will create a number of files in the current directory, which should be moved to `src/FoundationDB/Options/`. A few of the generated files are redundant with what's already generated by c2hs from the header file, and should be omitted. #### Generating docs/ `stack hoogle --keep-going` copy result to `docs/`