package dunolint-lib
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=1b064927c9e1ef5352a1886ae34a206fef0ce6a913c19a77b0162acc108e0e50
    
    
  sha512=6cbc08ba318bef6584d15a4491e3dde1bf436109ce0f8b7c400a9f91bbcee64c5785bc924df11eafe98243ec2f188a7f92c58c5062729f3e2af1e9977f1a5e67
    
    
  Description
[dunolint] is a set of OCaml libraries and a cli tool to lint and help manage files in (large) dune projects.
[dunolint-lib] is the package you need as a user to define a dunolint config, without pulling all the dependencies required by the linter engine and command line.
It defines a configuration language in which you can express linting invariants for your projects. The tool will enforce these invariants, applying global and systematic changes automatically when able, and help with general ergonomics questions.
For example: "I want for all libs in this subdirectory to enable
bisect_ppx, please go patch my dune files". Or, "I would like all
libraries that verify this particular predicate to supply the ppx flag
-unused-code-warnings=force", and more.
You can setup [dunolint] as part of your CI checks to help enforcing properties and linting checks going forward.
README
dunolint
Introduction
Welcome to dunolint, a project composed of libraries and a CLI designed to assist with maintaining build files typically found in OCaml repos managed by the Dune build system (e.g., files named dune, dune-project, etc.).
Project Goals
The goal of dunolint is to check customizable invariants in your repo and help with ergonomic issues, such as applying systematic changes across many files. It supports things like enabling instrumentation, configuring recurring lint or preprocess flags, sorting libraries alphabetically, and more. You can use it at your convenience during development, and enforce consistency by integrating it into your CI pipeline.
Documentation
Published here.
Current State
It's currently in the early stages of development and there's little code and features at this point. I'm seeking feedback and early discussions about the project next steps.
Get Involved
I would love to hear your thoughts about dunolint. If you're interested in this project and would like to engage in discussions or provide feedback, please feel free to open an issue or start a discussion in the GitHub space of the project.
Thank you for your interest in dunolint!
Acknowledgements
We're very thankful to:
Dependencies (6)
Dev Dependencies (1)
- 
  
    odoc
  
  
    with-doc
Used by (2)
- 
  
    dunolint
  
  
    >= "0.0.20251006"
- dunolint-lib-base
Conflicts
None