Skip to main content

Quick Start

This is your first introduction to dunolint - a tool that helps you maintain consistent build configurations across OCaml projects. If you're familiar with dune but new to dunolint, this tutorial will show you the core concepts in under a minute.

Simulating an Existing Project

For this mdx tutorial, let's simulate a typical OCaml project with a simple library:

$ mkdir -p src
$ cat dune.txt | tee src/dune
(library
(name mylib))

Creating Your First Dunolint Configuration

Say you want all libraries & executables to have code coverage instrumentation. Create a config file named dunolint:

$ cat dunolint.txt | tee dunolint
(lang dunolint 1.0)

(rule
(enforce (dune (instrumentation (backend bisect_ppx)))))

Seeing Dunolint in Action

Check what needs to be fixed:

$ dunolint lint --dry-run
dry-run: Would edit file "src/dune":
-1,2 +1,4
(library
!| (name mylib)
!| (instrumentation
!| (backend bisect_ppx)))

Apply the fix:

$ dunolint lint --yes
Editing file "src/dune":
-1,2 +1,4
(library
!| (name mylib)
!| (instrumentation
!| (backend bisect_ppx)))

That's it! In under a minute, you've seen how dunolint enforces consistent build configurations across your entire project - both existing code and anything you add later.

Next Steps