package ocamlformat

  1. Overview
  2. Docs
Auto-formatter for OCaml code

Install

Dune Dependency

Authors

Maintainers

Sources

ocamlformat-0.23.0.tbz
sha256=9bd3e3cfb0da1b2f75eccd468f27ea1b92e6e677bb6129491764957031dedfed
sha512=6da6f56cb4c605a87020dd7511c99b0114d844d7e26c727ffef521390265bc8f1e8a86e0e4ac916d27df56734941957468aa3462ae01991b522e75c42b392597

Description

OCamlFormat is a tool to automatically format OCaml code in a uniform style.

Published: 07 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.23.0

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)

  1. csexp >= "1.4.0"
  2. uutf >= "1.0.1"
  3. uuseg >= "10.0.0"
  4. stdio
  5. re >= "1.7.2"
  6. odoc-parser >= "1.0.0" & < "2.0.0"
  7. ocp-indent
  8. ocaml-version >= "3.3.0" & < "3.6.0"
  9. menhirSdk >= "20201216"
  10. menhirLib >= "20201216"
  11. menhir >= "20201216"
  12. fpath
  13. fix
  14. either
  15. dune-build-info
  16. dune >= "2.8"
  17. cmdliner >= "1.1.0"
  18. base >= "v0.12.0" & < "v0.17.0"
  19. ocaml >= "4.08" & < "5.2"

Dev Dependencies (4)

  1. odoc with-doc
  2. ocamlformat-rpc-lib with-test & post & = version
  3. dune with-test & < "3.0"
  4. alcotest with-test

Used by (61)

  1. ask
  2. ask-integrator
  3. autofonce
  4. autofonce_config
  5. autofonce_core
  6. autofonce_lib
  7. autofonce_m4
  8. autofonce_misc
  9. autofonce_patch
  10. autofonce_share
  11. awsm-codegen
  12. bastet < "2.0.0"
  13. bitpack_serializer
  14. diff
  15. diskuvbox < "0.1.2"
  16. drom
  17. drom_lib
  18. drom_toml
  19. dump_ocamlformat
  20. ez_cmdliner >= "0.2.0"
  21. ez_config >= "0.2.0"
  22. ez_file >= "0.2.0"
  23. ez_hash < "0.5.3"
  24. ez_opam_file
  25. ez_search
  26. ez_subst
  27. fromager
  28. header-check
  29. js_of_ocaml-webgpu >= "0.2"
  30. letters >= "0.2.0" & != "0.3.1"
  31. melange-fest
  32. melange-json >= "1.2.0"
  33. melange-radix-icons >= "0.1.0"
  34. mlx
  35. module-graph
  36. noCanren >= "0.3.0~alpha1"
  37. OCanren-ppx = "0.3.0~alpha1"
  38. ocaml-lsp-server < "1.8.0"
  39. ocp-search
  40. ocplib_stuff >= "0.3.0"
  41. opam-bin >= "0.9.5"
  42. opam_bin_lib >= "0.9.5"
  43. owi >= "0.2"
  44. polars
  45. polars_async
  46. ppx_deriving_jsonschema
  47. psmt2-frontend >= "0.3.0"
  48. pyml_bindgen >= "0.4.1"
  49. rea < "0.2.0"
  50. red-black-tree
  51. scaml >= "1.2.0"
  52. sihl < "0.1.0"
  53. solidity-alcotest
  54. solidity-common
  55. solidity-parser
  56. solidity-test
  57. solidity-typechecker
  58. spotify_ml >= "push"
  59. styled-ppx
  60. yocaml >= "2.0.0"
  61. zanuda

Conflicts

None

OCaml

Innovation. Community. Security.