package ocamlformat
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=023425e9818f80ea50537b2371a4a766c149a9957d05807e88a004d2d5f441ce
sha512=753b6128be68042895202f99959b360ce954db6f82b19b83b4bb346761a8e9cfdfc2b4b25e2070e60601b555562e78f9ebb02760ff127464e0b66cedbddca304
Description
OCamlFormat is a tool to automatically format OCaml code in a uniform style.
Published: 18 Jul 2022
README
README.md
OCamlFormat
Hello, new user! Welcome! :wave:
If you are here, you are probably interested in using a formatting tool for your code base, so that you do not have to worry about formatting it by hand, and to speed up code review by focusing on the important parts.
OCamlFormat is probably what you are after!
OCamlFormat works by parsing then outputting again the same OCaml source file in a consistent style.
Read the documentation to learn more about OCamlFormat!
Getting started
Installation
OCamlFormat can be installed with opam
:
opam install ocamlformat
Alternatively, see ocamlformat.opam
for manual build instructions.
Formatting code!
Setting up your project to use the default profile and the OCamlFormat version you installed (hopefully the last one) in this .ocamlformat
file is considered good practice:
profile = default
version = 0.24.1
To manually invoke OCamlformat the general command is:
ocamlformat [OPTION]... [SRC]...
See ocamlformat --help
or man ocamlformat
for the detail about options.
You can also view it online.
The most common usecase involves using the dune
build system, once your project is correctly setup (see Dune's manual) you can reformat your project using:
dune build @fmt
Community
See CONTRIBUTING for how to help out.
License
OCamlFormat is MIT-licensed.
Dependencies (19)
-
csexp
>= "1.4.0"
-
uutf
>= "1.0.1"
-
uuseg
>= "10.0.0"
- stdio
-
re
>= "1.7.2"
-
odoc-parser
>= "2.0.0" & < "2.3.0"
- ocp-indent
-
ocaml-version
>= "3.3.0" & < "3.6.0"
-
menhirSdk
>= "20201216"
-
menhirLib
>= "20201216"
-
menhir
>= "20201216"
- fpath
- fix
- either
- dune-build-info
-
dune
>= "2.8"
-
cmdliner
>= "1.1.0"
-
base
>= "v0.12.0" & < "v0.17.0"
-
ocaml
>= "4.08" & < "5.2"
Dev Dependencies (3)
-
odoc
with-doc
-
ocamlformat-rpc-lib
with-test & = version
-
alcotest
with-test
Used by (65)
- ambient-context
- ask
- ask-integrator
- autofonce
- autofonce_config
- autofonce_core
- autofonce_lib
- autofonce_m4
- autofonce_misc
- autofonce_patch
- autofonce_share
- awsm-codegen
-
bastet
< "2.0.0"
- bitpack_serializer
-
data-encoding
>= "1.0.0"
- diff
-
diskuvbox
< "0.1.2"
- drom
- drom_lib
- drom_toml
- dump_ocamlformat
-
ez_cmdliner
>= "0.2.0"
-
ez_config
>= "0.2.0"
-
ez_file
>= "0.2.0"
-
ez_hash
< "0.5.3"
- ez_opam_file
- ez_search
- ez_subst
- fromager
-
guardian
< "0.1.0"
- header-check
-
js_of_ocaml-webgpu
>= "0.2"
-
json-data-encoding
>= "1.0.0"
- jsonschema2atd
-
letters
>= "0.2.0" & != "0.3.1"
- melange-fest
-
melange-json
>= "1.2.0"
-
melange-radix-icons
>= "0.1.0"
-
merge-fmt
>= "0.3"
- mlx
- module-graph
-
noCanren
>= "0.3.0~alpha1"
-
OCanren-ppx
= "0.3.0~alpha1"
-
ocaml-lsp-server
< "1.8.0" | >= "1.15.0-4.14" & < "1.18.0"
- ocp-search
-
ocplib_stuff
>= "0.3.0"
-
opam-bin
>= "0.9.5"
-
opam_bin_lib
>= "0.9.5"
-
opentelemetry
>= "0.6"
-
owi
>= "0.2"
- polars
- polars_async
-
psmt2-frontend
>= "0.3.0"
-
rea
< "0.2.0"
- red-black-tree
-
scaml
>= "1.2.0"
-
sihl
< "0.1.0"
- solidity-alcotest
- solidity-common
- solidity-parser
- solidity-test
- solidity-typechecker
-
spotify_ml
>= "push"
- styled-ppx
- zanuda
Conflicts
None