2018-11-25 16:34:28 +03:00
|
|
|
|
# Ormolu
|
|
|
|
|
|
2018-11-25 17:09:03 +03:00
|
|
|
|
[![CircleCI](https://circleci.com/gh/tweag/ormolu/tree/master.svg?style=svg&circle-token=cfd37a39265561eb44e608f97cf953cb2a394c03)](https://circleci.com/gh/tweag/ormolu/tree/master)
|
|
|
|
|
|
2019-07-02 22:29:07 +03:00
|
|
|
|
Ormolu is a formatter for Haskell source code. The project was created with
|
2019-05-10 17:36:51 +03:00
|
|
|
|
the following features in mind:
|
|
|
|
|
|
|
|
|
|
* Using GHC's own parser to avoid parsing problems caused by
|
|
|
|
|
[`haskell-src-exts`][haskell-src-exts].
|
2019-05-23 16:58:07 +03:00
|
|
|
|
* Let some whitespace be programmable. The layout of the input
|
|
|
|
|
influence the layout choices in the output. This means that the
|
|
|
|
|
choices between single-line/multi-line layouts in each particular
|
|
|
|
|
situation are made by the user, not by an algorithm. This makes the
|
|
|
|
|
implementation simpler and leaves some control to the user while
|
|
|
|
|
still guaranteeing that the formatted code is stylistically
|
|
|
|
|
consistent.
|
2019-05-16 19:45:45 +03:00
|
|
|
|
* Writing code in such a way so it's easy to modify and maintain. Roughly,
|
2019-05-10 17:36:51 +03:00
|
|
|
|
it means that the project follows the path of [`hindent`][hindent] and is
|
|
|
|
|
very much about printing AST in a particular way.
|
|
|
|
|
* Implementing one “true” formatting style which admits no configuration.
|
2019-05-17 13:18:01 +03:00
|
|
|
|
* That formatting style aims to result in minimal diffs while still
|
|
|
|
|
remaining very close to “conventional” Haskell formatting people use.
|
2019-05-10 17:36:51 +03:00
|
|
|
|
* Idempotency: formatting already formatted code doesn't change it.
|
|
|
|
|
* Be well-tested and robust to the point that it can be used in large
|
|
|
|
|
projects without exposing unfortunate, disappointing bugs here and there.
|
|
|
|
|
|
2019-05-30 14:56:42 +03:00
|
|
|
|
## Building
|
|
|
|
|
|
2019-05-31 15:37:41 +03:00
|
|
|
|
The easiest way to build the project is with Nix:
|
2019-05-30 14:56:42 +03:00
|
|
|
|
|
2019-05-31 15:37:41 +03:00
|
|
|
|
```console
|
|
|
|
|
$ nix-build
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Or with `cabal-install` from the Nix shell:
|
|
|
|
|
|
|
|
|
|
```console
|
|
|
|
|
$ nix-shell --run "cabal new-build"
|
2019-05-30 14:56:42 +03:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Alternatively, `stack` could be used with a `stack.yaml` file as follows.
|
2019-05-31 15:37:41 +03:00
|
|
|
|
|
|
|
|
|
```console
|
2019-05-30 14:56:42 +03:00
|
|
|
|
$ cat stack.yaml
|
2019-05-31 15:37:41 +03:00
|
|
|
|
resolver: lts-13.19
|
2019-05-30 14:56:42 +03:00
|
|
|
|
packages:
|
|
|
|
|
- '.'
|
2019-05-30 15:19:03 +03:00
|
|
|
|
|
|
|
|
|
$ stack build
|
2019-05-30 14:56:42 +03:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
|
|
The following will print the formatted output to the standard output.
|
2019-05-31 15:37:41 +03:00
|
|
|
|
|
|
|
|
|
```console
|
2019-05-30 14:56:42 +03:00
|
|
|
|
$ ormolu Module.hs
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Add `--mode inplace` to replace the contents of the input file with the
|
|
|
|
|
formatted output.
|
2019-05-31 15:37:41 +03:00
|
|
|
|
|
|
|
|
|
```console
|
2019-05-30 14:56:42 +03:00
|
|
|
|
$ ormolu --mode inplace Module.hs
|
|
|
|
|
```
|
|
|
|
|
|
2019-07-14 02:01:02 +03:00
|
|
|
|
## Running on Hackage
|
|
|
|
|
|
|
|
|
|
It's possible to try Ormolu on arbitrary packages from Hackage. For that
|
|
|
|
|
execute:
|
|
|
|
|
|
|
|
|
|
```console
|
|
|
|
|
$ nix-build -A hackage.<package>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Then inspect `result/log.txt` for possible problems. The derivation will
|
2019-07-14 13:24:35 +03:00
|
|
|
|
also contain formatted `.hs` files for inspection and original inputs with
|
|
|
|
|
`.hs-original` extension (those are with CPP dropped, exactly what is fed
|
|
|
|
|
into Ormolu).
|
2019-07-14 02:01:02 +03:00
|
|
|
|
|
2019-05-31 16:27:42 +03:00
|
|
|
|
## Contributing
|
2019-05-10 17:36:51 +03:00
|
|
|
|
|
2019-05-31 16:27:42 +03:00
|
|
|
|
See [CONTRIBUTING.md](./CONTRIBUTING.md).
|
2018-11-25 16:34:28 +03:00
|
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
2019-05-31 16:27:42 +03:00
|
|
|
|
See [LICENSE.md](./LICENSE.md).
|
2019-05-23 16:58:07 +03:00
|
|
|
|
|
2019-07-02 22:27:45 +03:00
|
|
|
|
Copyright © 2018–present Tweag I/O
|
2019-05-10 17:36:51 +03:00
|
|
|
|
|
|
|
|
|
[haskell-src-exts]: https://hackage.haskell.org/package/haskell-src-exts
|
|
|
|
|
[hindent]: https://hackage.haskell.org/package/hindent
|