forked from ocaml-ppx/ocamlformat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathocamlformat-help.txt
682 lines (545 loc) · 30.2 KB
/
ocamlformat-help.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
NAME
ocamlformat - A tool to format OCaml code.
SYNOPSIS
ocamlformat [OPTION]… [SRC]…
DESCRIPTION
ocamlformat automatically formats OCaml code.
OPTIONS (CODE FORMATTING STYLE)
Unless otherwise noted, any option --option=VAL detailed in this
section can be set in many ways, its value is determined in the
following order (of increasing priority): the default value is used if
no other value is specified. The value of a boolean option --foo or
--no-foo can be modified in an .ocamlformat configuration file with
'foo = {true,false}', it can be done for any other option with an
'option = VAL' line (*), or using the OCAMLFORMAT environment
variable: OCAMLFORMAT=option=VAL,...,option=VAL, or as an optional
parameter on the command line, or with a global [@@@ocamlformat
"option=VAL"] attribute in the processed file, or with an
[@@ocamlformat "option=VAL"] attribute on expression in the processed
file.
(*) .ocamlformat files in current and all ancestor directories for
each input file are used, applied from top to bottom, overriding the
settings each time a file is applied, stopping at the project root. If
no project root and no ocamlformat file has been found, and if the
option enable-outside-detected-project is set, the global ocamlformat
file defined in $XDG_CONFIG_HOME (or in $HOME/.config if
$XDG_CONFIG_HOME is undefined) is used.
If the disable option is not set, an .ocamlformat-ignore file
specifies files that OCamlFormat should ignore. Each line in an
.ocamlformat-ignore file specifies a filename relative to the
directory containing the .ocamlformat-ignore file. Shell-style regular
expressions are supported. Lines starting with # are ignored and can
be used as comments.
If the disable option is set, an .ocamlformat-enable file specifies
files that OCamlFormat should format even when the disable option is
set. Each line in an .ocamlformat-enable file specifies a filename
relative to the directory containing the .ocamlformat-enable file.
Shell-style regular expressions are supported. Lines starting with #
are ignored and can be used as comments.
--assignment-operator={end-line|begin-line}
Position of the assignment operator. end-line positions assignment
operators (`:=` and `<-`) at the end of the line and breaks after
it if the whole assignment expression does not fit on a single
line. begin-line positions assignment operators (`:=` and `<-`) at
the beginning of the line and breaks before it if the whole
assignment expression does not fit on a single line. The default
value is end-line.
--break-before-in={fit-or-vertical|auto}
Whether the line should break before the in keyword of a let
binding. fit-or-vertical will always break the line before the in
keyword if the whole let binding does not fit on a single line.
auto will only break the line if the in keyword does not fit on
the previous line. The default value is fit-or-vertical.
--break-cases={fit|nested|toplevel|fit-or-vertical|vertical|all}
Break pattern match cases. Specifying fit lets pattern matches
break at the margin naturally. nested forces a break after nested
or-patterns to highlight the case body. Note that with nested, the
indicate-nested-or-patterns option is not needed, and so ignored.
toplevel forces top-level cases (i.e. not nested or-patterns) to
break across lines, otherwise break naturally at the margin.
fit-or-vertical tries to fit all or-patterns on the same line,
otherwise breaks. vertical vertically breaks branches. all forces
all pattern matches to break across lines. The default value is
fit.
--break-collection-expressions={fit-or-vertical|wrap}
Break collection expressions (lists and arrays) elements by
elements. fit-or-vertical vertically breaks expressions if they do
not fit on a single line. wrap will group simple expressions and
try to format them in a single line. The default value is
fit-or-vertical.
--break-colon={after|before}
Break before or after colon in value binding declarations and type
constraints. after breaks after the colon. before breaks before
the colon. The default value is after.
--break-fun-decl={wrap|fit-or-vertical|smart}
Style for function declarations and types. wrap breaks only if
necessary. fit-or-vertical vertically breaks arguments if they do
not fit on a single line. smart is like fit-or-vertical but try to
fit arguments on their line if they fit. The default value is
wrap.
--break-fun-sig={wrap|fit-or-vertical|smart}
Style for function signatures. wrap breaks only if necessary.
fit-or-vertical vertically breaks arguments if they do not fit on
a single line. smart is like fit-or-vertical but try to fit
arguments on their line if they fit. The default value is wrap.
--break-infix={wrap|fit-or-vertical|wrap-or-vertical}
Break sequence of infix operators. wrap will group simple
expressions and try to format them in a single line.
fit-or-vertical vertically breaks expressions if they do not fit
on a single line. wrap-or-vertical behaves like wrap for high
precedence operators and behaves like fit-or-vertical for low
precedence operators. The default value is wrap.
--break-infix-before-func
Break infix operators whose right arguments are anonymous
functions specially: do not break after the operator so that the
first line of the function appears docked at the end of line after
the operator. The flag is unset by default.
--break-separators={after|before}
Break before or after separators such as `;` in list or record
expressions. after breaks the expressions after the separator.
before breaks the expressions before the separator. The default
value is after.
--break-sequences
Force sequence expressions to break irrespective of margin. The
flag is set by default.
--break-string-literals={auto|never}
Break string literals. auto mode breaks lines at newlines and
wraps string literals at the margin. never mode formats string
literals as they are parsed, in particular, with escape sequences
expanded. The default value is auto.
--break-struct={force|natural}
Break struct-end module items. force will break struct-end phrases
unconditionally. natural will break struct-end phrases naturally
at the margin. The default value is force.
--cases-exp-indent=COLS
Indentation of cases expressions (COLS columns). See also the
cases-matching-exp-indent and nested-match options. The default
value is 4. Cannot be set in attributes.
--cases-matching-exp-indent={normal|compact}
Indentation of cases right-hand sides which are `match` or `try`
expressions. normal indents as it would any other expression.
compact forces an indentation of 2, unless nested-match is set to
align and we're on the last case. The default value is normal.
--disambiguate-non-breaking-match
Add parentheses around matching constructs that fit on a single
line. The flag is unset by default.
--doc-comments={after-when-possible|before-except-val|before}
Doc comments position. after-when-possible puts doc comments after
the corresponding code. This option has no effect on variant
declarations because that would change their meaning and on
structures, signatures and objects for readability.
before-except-val puts doc comments before the corresponding code,
but puts doc comments of val and external declarations after the
corresponding declarations. before puts comments before the
corresponding code. The default value is after-when-possible.
--doc-comments-padding=PADDING
Add PADDING spaces before doc comments in type declarations. The
default value is 2.
--doc-comments-tag-only={default|fit}
Position of doc comments with only tags. default means no special
treatment. fit puts doc comments on the same line. The default
value is default.
--dock-collection-brackets
Dock the brackets of lists, arrays and records, so that when the
collection does not fit on a single line the brackets are opened
on the preceding line and closed on the following line. The flag
is set by default.
--exp-grouping={parens|preserve}
Style of expression grouping. parens groups expressions using
parentheses. preserve preserves the original grouping syntax
(parentheses or begin/end). The default value is parens. Cannot be
set in attributes.
--extension-indent=COLS
Indentation of items inside extension nodes (COLS columns). The
default value is 2.
--field-space={loose|tight|tight-decl}
Whether or not to use a space between a field name and the
punctuation symbol (`:` or `=`) preceding the rhs. This option
affects records and objects. loose uses a space. tight does not
use a space. tight-decl is tight for declarations and loose for
instantiations. The default value is loose.
--function-indent=COLS
Indentation of function cases (COLS columns). The default value is
2.
--function-indent-nested={never|always|auto}
Whether the function-indent parameter should be applied even when
in a sub-block. never only applies function-indent if the function
block starts a line. always always apply function-indent. auto
applies function-indent when seen fit. The default value is never.
--if-then-else={compact|fit-or-vertical|vertical|keyword-first|k-r}
If-then-else formatting. compact tries to format an if-then-else
expression on a single line. fit-or-vertical vertically breaks
branches if they do not fit on a single line. vertical always
vertically breaks branches. keyword-first formats if-then-else
expressions such that the if-then-else keywords are the first on
the line. k-r formats if-then-else expressions with parentheses
that match the K&R style. The default value is compact.
--indent-after-in=COLS
Indentation (COLS columns) after `let ... in`, unless followed by
another `let`. The default value is 0. Cannot be set in
attributes.
--indicate-multiline-delimiters={no|space|closing-on-separate-line}
How to indicate that two matching delimiters live on different
lines. no doesn't do anything special to indicate the closing
delimiter. space prints a space inside the delimiter to indicate
the matching one is on a different line. closing-on-separate-line
makes sure that the closing delimiter is on its own line. The
default value is no.
--indicate-nested-or-patterns={unsafe-no|space}
Control whether or not to indicate nested or-pattern using
indentation. unsafe-no does not indicate nested or-patterns.
Warning: this can produce confusing code where a short body of a
match case is visually hidden by surrounding long patterns,
leading to misassociation between patterns and body expressions.
space starts lines of nested or-patterns with " |" rather than "|
". The default value is unsafe-no.
--infix-precedence={indent|parens}
Use indentation or also discretionary parentheses to explicitly
disambiguate precedences of infix operators. indent uses
indentation to explicitly disambiguate precedences of infix
operators. parens uses parentheses to explicitly disambiguate
precedences of infix operators. The default value is indent.
--leading-nested-match-parens
Nested match parens formatting. The flag is unset by default.
Cannot be set in attributes.
--let-and={compact|sparse}
Style of let_and. compact will try to format `let p = e and p = e`
in a single line. sparse will always break between them. The
default value is compact.
--let-binding-indent=COLS
Indentation of let binding expressions (COLS columns) if they do
not fit on a single line. The default value is 2. Cannot be set in
attributes.
--let-binding-spacing={compact|sparse|double-semicolon}
Spacing between let binding. compact spacing separates adjacent
let bindings in a module according to module-item-spacing. sparse
places two open lines between a multi-line module-level let
binding and the next. double-semicolon places double semicolons
and an open line between a multi-line module-level let binding and
the next. The default value is compact.
--let-module={compact|sparse}
Module binding formatting. compact does not break a line after the
let module ... = and before the in if the module declaration does
not fit on a single line. sparse breaks a line after let module
... = and before the in if the module declaration does not fit on
a single line. The default value is compact.
--line-endings={lf|crlf}
Line endings used. lf uses Unix line endings. crlf uses Windows
line endings. The default value is lf. Cannot be set in
attributes.
-m COLS, --margin=COLS
Format code to fit within COLS columns. The default value is 80.
Cannot be set in attributes.
--match-indent=COLS
Indentation of match/try cases (COLS columns). The default value
is 0.
--match-indent-nested={never|always|auto}
Whether the match-indent parameter should be applied even when in
a sub-block. never only applies match-indent if the match block
starts a line. always always apply match-indent. auto applies
match-indent when seen fit. The default value is never.
--max-indent=COLS
Maximum offset (COLS columns) added to a new line in addition to
the offset of the previous line. The default value is 68. Cannot
be set in attributes.
--module-item-spacing={compact|sparse|preserve}
Spacing between items of structures and signatures. compact will
not leave open lines between one-liners of similar sorts. sparse
will always break a line between two items. preserve will not
leave open lines between one-liners of similar sorts unless there
is an open line in the input. The default value is compact.
--nested-match={wrap|align}
Style of a pattern-matching nested in the last case of another
pattern-matching. wrap wraps the nested pattern-matching with
parentheses and adds indentation. align vertically aligns the
nested pattern-matching under the encompassing pattern-matching.
The default value is wrap.
--no-break-infix-before-func
Unset break-infix-before-func.
--no-break-sequences
Unset break-sequences.
--no-disambiguate-non-breaking-match
Unset disambiguate-non-breaking-match.
--no-dock-collection-brackets
Unset dock-collection-brackets.
--no-leading-nested-match-parens
Unset leading-nested-match-parens.
--no-ocp-indent-compat
Unset ocp-indent-compat.
--no-parens-ite
Unset parens-ite.
--no-parse-docstrings
Unset parse-docstrings.
--no-parse-toplevel-phrases
Unset parse-toplevel-phrases.
--no-space-around-arrays
Unset space-around-arrays.
--no-space-around-lists
Unset space-around-lists.
--no-space-around-records
Unset space-around-records.
--no-space-around-variants
Unset space-around-variants.
--no-wrap-comments
Unset wrap-comments.
--no-wrap-fun-args
Unset wrap-fun-args.
--ocp-indent-compat
Attempt to generate output which does not change (much) when
post-processing with ocp-indent. The flag is unset by default.
-p {default|conventional|ocamlformat|janestreet},
--profile={default|conventional|ocamlformat|janestreet}
Select a preset profile which sets all options, overriding lower
priority configuration. default is an alias for the conventional
profile. The conventional profile aims to be as familiar and
"conventional" appearing as the available options allow. The
ocamlformat profile aims to take advantage of the strengths of a
parsetree-based auto-formatter, and to limit the consequences of
the weaknesses imposed by the current implementation. This is a
style which optimizes for what the formatter can do best, rather
than to match the style of any existing code. General guidelines
that have directed the design include: Legibility, in the sense of
making it as hard as possible for quick visual parsing to give the
wrong interpretation, is of highest priority; Whenever possible
the high-level structure of the code should be obvious by looking
only at the left margin, in particular, it should not be necessary
to visually jump from left to right hunting for critical keywords,
tokens, etc; All else equal compact code is preferred as reading
without scrolling is easier, so indentation or white space is
avoided unless it helps legibility; Attention has been given to
making some syntactic gotchas visually obvious. The janestreet
profile is used at Jane Street. The default value is default.
--parens-ite
Uses parentheses around if-then-else branches that spread across
multiple lines. The flag is unset by default.
--parens-tuple={always|multi-line-only}
Parens tuple expressions. always always uses parentheses around
tuples. multi-line-only mode will try to skip parens for
single-line tuples. The default value is always.
--parens-tuple-patterns={multi-line-only|always}
Parens tuple patterns. multi-line-only mode will try to skip
parens for single-line tuple patterns. always always uses
parentheses around tuples patterns. The default value is
multi-line-only.
--parse-docstrings
Parse and format docstrings. The flag is unset by default.
--parse-toplevel-phrases
Parse and format toplevel phrases and their output. The flag is
unset by default.
--sequence-blank-line={preserve-one|compact}
Blank line between expressions of a sequence. preserve will keep a
blank line between two expressions of a sequence if the input
contains at least one. compact will not keep any blank line
between expressions of a sequence. The default value is
preserve-one.
--sequence-style={terminator|separator|before}
Style of sequence. terminator only puts spaces after semicolons.
separator puts spaces before and after semicolons. before breaks
the sequence before semicolons. The default value is terminator.
--single-case={compact|sparse}
Style of pattern matching expressions with only a single case.
compact will try to format a single case on a single line. sparse
will always break the line before a single case. The default value
is compact.
--space-around-arrays
Add a space inside the delimiters of arrays. The flag is set by
default.
--space-around-lists
Add a space inside the delimiters of lists. The flag is set by
default.
--space-around-records
Add a space inside the delimiters of records. The flag is set by
default.
--space-around-variants
Add a space inside the delimiters of variants. The flag is set by
default.
--stritem-extension-indent=COLS
Indentation of structure items inside extension nodes (COLS
columns). The default value is 0.
--type-decl={compact|sparse}
Style of type declaration. compact will try to format constructors
and records definition in a single line. sparse will always break
between constructors and record fields. The default value is
compact.
--type-decl-indent=COLS
Indentation of type declarations (COLS columns) if they do not fit
on a single line. The default value is 2. Cannot be set in
attributes.
--wrap-comments
Wrap comments and docstrings. Comments and docstrings are divided
into paragraphs by open lines (two or more consecutive newlines),
and each paragraph is wrapped at the margin. Multi-line comments
with vertically-aligned asterisks on the left margin are not
wrapped. Consecutive comments with both left and right margin
aligned are not wrapped either. The flag is unset by default.
--wrap-fun-args
Style for function call. The flag is set by default.
OPTIONS (REMOVED)
--align-cases=VAL
This option has been removed in version 0.22.
--align-constructors-decl=VAL
This option has been removed in version 0.22.
--align-variants-decl=VAL
This option has been removed in version 0.22.
--disable-outside-detected-project=VAL
This option has been removed in version 0.22. OCamlFormat is
disabled outside of a detected project by default, to enable the
opposite behavior use `enable-outside-detected-project`.
--doc-comments-val=VAL
This option has been removed in version 0.16. If you are using
`doc-comments-val=before` in combination with
`doc-comments=before` then only `doc-comments=before` is now
required to achive the same behavior. If you are using
`doc-comments-val=before` in combination with `doc-comments=after`
this behavior is not available anymore. If you are using
`doc-comments-val=after` in combination with `doc-comments=before`
please now use `doc-comments=before-except-val`. If you are using
`doc-comments-val=after` in combination with `doc-comments=after`
then only `doc-comments=after-when-possible` is now required to
achieve the same behavior. If you are using
`doc-comments-val=unset` the same behavior can now be achieved by
setting `doc-comments` only.
--escape-chars=VAL
This option has been removed in version 0.16. Concrete syntax will
now always be preserved.
--escape-strings=VAL
This option has been removed in version 0.16. Concrete syntax will
now always be preserved.
--extension-sugar=VAL
This option has been removed in version 0.17. Concrete syntax will
now always be preserved.
--let-open=VAL
This option has been removed in version 0.17. Concrete syntax will
now always be preserved.
OPTIONS
Unless mentioned otherwise non-formatting options cannot be set in
attributes or .ocamlformat files.
-c VAL, --config=VAL (absent OCAMLFORMAT env)
Aggregate options. Options are specified as a comma-separated list
of pairs: option=VAL,...,option=VAL.
--check
Check whether the input files already are formatted. Mutually
exclusive with --inplace and --output.
--comment-check
Control whether to check comments and documentation comments.
Unsafe to turn off. May be set in .ocamlformat. The flag is set by
default.
--disable
Disable ocamlformat. This is used in attributes to locally disable
automatic code formatting. One can also use [@@@ocamlformat
"enable"] instead of [@@@ocamlformat "disable=false"]. The flag is
unset by default.
--disable-conf-attrs
Disable configuration in attributes. The flag is unset by default.
--disable-conf-files
Disable .ocamlformat configuration files.
--doc
Parse input as an odoc documentation.
--enable-outside-detected-project
Read .ocamlformat config files outside the current project when no
project root has been detected for the input file. The project
root of an input file is taken to be the nearest ancestor
directory that contains a .git or .hg or dune-project file. If
.ocamlformat config files are located in the same directory or
parents they are applied, if no .ocamlformat file is found then
the global configuration defined in $XDG_CONFIG_HOME/.ocamlformat
(or in $HOME/.config/.ocamlformat if $XDG_CONFIG_HOME is
undefined) is applied.
-g, --debug
Generate debugging output. The flag is unset by default.
-i, --inplace
Format in-place, overwriting input file(s).
--ignore-invalid-option
Ignore invalid options (e.g. in .ocamlformat).
--impl
Parse input as an implementation.
--intf
Parse input as an interface.
--margin-check
Emit a warning if the formatted output exceeds the margin. The
flag is unset by default.
-n N, --max-iters=N
Fail if output of formatting does not stabilize within N
iterations. May be set in .ocamlformat. The default value is 10.
--name=NAME
Name of input file for use in error reporting and starting point
when searching for '.ocamlformat' files. Defaults to the input
file name. Some options can be specified in configuration files
named '.ocamlformat' in the same or a parent directory of NAME,
see documentation of other options for details.
--no-comment-check
Unset comment-check.
--no-debug
Unset debug.
--no-disable
Unset disable.
--no-disable-conf-attrs
Unset disable-conf-attrs.
--no-margin-check
Unset margin-check.
--no-quiet
Unset quiet.
--no-version-check
Unset version-check.
--numeric
Instead of re-formatting the file, output one integer per line
corresponding to the indentation value, printing as many values as
lines in the document.
-o DST, --output=DST
Output file. Mutually exclusive with --inplace. Write to stdout if
omitted.
--ocaml-version=V
Version of OCaml syntax of the output. The default value is
4.04.0.
--ocp-indent-config
Read .ocp-indent configuration files. base is an alias for
let-binding-indent. type is an alias for type-decl-indent. in is
an alias for indent-after-in. with sets function-indent and
match-indent. match_clause is an alias for cases-exp-indent.
ppx_stritem_ext is an alias for stritem-extension-indent.
max_indent is an alias for max-indent. strict_with sets
function-indent-nested and match-indent-nested.
--print-config
Print the configuration determined by the environment variable,
the configuration files, preset profiles and command line.
Attributes are not considered. If many input files are specified,
only print the configuration for the first file. If no input file
is specified, print the configuration for the root directory if
specified, or for the current working directory otherwise.
-q, --quiet
Quiet. May be set in .ocamlformat. The flag is unset by default.
--range=X-Y
Apply the formatting to a range of lines. Must be included between
1 and the number of lines of the input. If a range is invalid the
whole input is considered. Warning: only supported in conbination
with `--numeric` for now. The default value is <whole input>.
--repl-file
Parse input as toplevel phrases with their output.
--root=DIR
Root of the project. If specified, only take into account
.ocamlformat configuration files inside DIR and its
subdirectories.
--use-file
Deprecated. Same as impl.
--version-check
Check that the version matches the one specified in .ocamlformat.
The flag is set by default.
SRC Input files. At least one is required, and exactly one without
--inplace. If - is passed, will read from stdin.
COMMON OPTIONS
--help[=FMT] (default=auto)
Show this help in format FMT. The value FMT must be one of auto,
pager, groff or plain. With auto, the format is pager or plain
whenever the TERM env var is dumb or undefined.
--version
Show version information.
EXIT STATUS
ocamlformat exits with the following status:
0 on success.
123 on indiscriminate errors reported on standard error.
124 on command line parsing errors.
125 on unexpected internal errors (bugs).
ENVIRONMENT
These environment variables affect the execution of ocamlformat:
OCAMLFORMAT
See option --config.