A repository of Fathom-related binary parsing experiments.
- bidi-combinators: A library of bidirectional binary format combinators.
- ll1-combinators: Linear-time parser combinators based on Neel Krishnaswami’s blog post.
- ll1-dsl: Linear-time parser combinators implemented as an external DSL.
- ll1-dsl2: Linear-time parser combinators implemented as an external DSL, using a more traditional elaborator.
- llk-simple: LL(k) parser DSL.
- simple-ddl: A simply typed binary format DSL that compiles to a recursive descent parser.
Using Nix is not required, but can be useful for setting up a development shell with the required packages and tools used in this project. If you choose to use Nix, ensure you have it installed, with the Nix flakes feature enabled.
nix-direnv can be used to load development tools into your shell automatically. Once it’s installed, run the following commands to enable it in the project directory:
echo "use flake" > .envrc
direnv allow
The .envrc.sample
file contains some additional commands to
watch opam files and load compiled executables onto the PATH. To use it instead,
run the following commands in your shell:
echo "source_env .envrc.sample" > .envrc
direnv allow
You’ll want to locally exclude the .envrc
, or add it to your global gitignore.
After that, dune can be used to build, test, and run the projects:
dune build --display=short
dune test --display=short
To enable IDE support with the OCaml Platform extension, add the following to
your ./.vscode/settings.json
file:
{
// https://github.com/ocamllabs/vscode-ocaml-platform/issues/984
"ocaml.sandbox": {
"kind": "custom",
"template": "nix develop ${firstWorkspaceFolder} --command $prog $args",
},
}
Alternatively, opam package definitions are provided in the ./opam
directory. They drive the Nix flake, so should be up to date. I don’t use opam
however, so I’m not sure what the workflow is.