Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crclark/foundationdb-haskell
Haskell FFI bindings to the FoundationDB C API
https://github.com/crclark/foundationdb-haskell
database ffi-bindings foundationdb
Last synced: about 1 month ago
JSON representation
Haskell FFI bindings to the FoundationDB C API
- Host: GitHub
- URL: https://github.com/crclark/foundationdb-haskell
- Owner: crclark
- License: bsd-3-clause
- Created: 2018-04-23T04:31:16.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-11-12T18:34:16.000Z (about 1 year ago)
- Last Synced: 2024-07-31T20:32:46.288Z (5 months ago)
- Topics: database, ffi-bindings, foundationdb
- Language: Haskell
- Homepage: https://crclark.github.io/foundationdb-haskell/
- Size: 1.17 MB
- Stars: 36
- Watchers: 7
- Forks: 5
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog.md
- License: LICENSE
Awesome Lists containing this project
- awesome-foundationdb - Haskell
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/`