slackbuilds/haskell/ghc/ghc.1

2339 lines
84 KiB
Groff

.\" Man page generated from reStructuredText.
.
.TH "GHC" "1" "Feb 04, 2021" "8.10.4" "Glasgow Haskell Compiler"
.SH NAME
ghc \- the Glasgow Haskell Compiler
.
.nr rst2man-indent-level 0
.
.de1 rstReportMargin
\\$1 \\n[an-margin]
level \\n[rst2man-indent-level]
level margin: \\n[rst2man-indent\\n[rst2man-indent-level]]
-
\\n[rst2man-indent0]
\\n[rst2man-indent1]
\\n[rst2man-indent2]
..
.de1 INDENT
.\" .rstReportMargin pre:
. RS \\$1
. nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin]
. nr rst2man-indent-level +1
.\" .rstReportMargin post:
..
.de UNINDENT
. RE
.\" indent \\n[an-margin]
.\" old: \\n[rst2man-indent\\n[rst2man-indent-level]]
.nr rst2man-indent-level -1
.\" new: \\n[rst2man-indent\\n[rst2man-indent-level]]
.in \\n[rst2man-indent\\n[rst2man-indent-level]]u
..
.SH SYNOPSIS
.INDENT 0.0
.INDENT 3.5
.sp
.nf
.ft C
ghc [option|filename]
ghci [option|filename]
.ft P
.fi
.UNINDENT
.UNINDENT
.SH DESCRIPTION
.sp
This manual page documents briefly the \fBghc\fP and \fBghci\fP commands. Note that
\fBghci\fP is not yet available on all architectures. Extensive documentation is
available in various other formats including \fI\%PDF\fP and \fI\%HTML\fP\&.
.sp
Each of GHC\(aqs command line options is classified as either \fIstatic\fP or
\fIdynamic\fP\&. A static flag may only be specified on the command line, whereas a
dynamic flag may also be given in an \fBOPTIONS\fP pragma in a source file or
set from the GHCi command\-line with \fB:set\fP .
.sp
As a rule of thumb, all the language options are dynamic, as are the
warning options and the debugging options.
.sp
The rest are static, with the notable exceptions of
\fB\-v\fP, \fB\-cpp\fP, \fB\-fasm\fP, \fB\-fvia\-C\fP, \fB\-fllvm\fP, and
\fB\-#include\fP\&.
The OPTIONS sections lists the status of each flag.
.sp
Common suffixes of file names for Haskell are:
.INDENT 0.0
.TP
.B \fB\&.hs\fP
Haskell source code; preprocess, compile
.TP
.B \fB\&.lhs\fP
literate Haskell source; unlit, preprocess, compile
.TP
.B \fB\&.hi\fP
Interface file; contains information about exported symbols
.TP
.B \fB\&.hc\fP
intermediate C files
.TP
.B \fB\&.⟨way⟩_o\fP
object files for "way" ⟨way⟩; common ways are:
.INDENT 7.0
.TP
.B \fBdyn\fP
dynamically\-linked
.TP
.B \fBp\fP
built with profiling
.UNINDENT
.TP
.B \fB\&.⟨way⟩_hi\fP
interface files for "way" ⟨way⟩; common ways are:
.UNINDENT
.SH OPTIONS
.TP
.B Code generation
\fB\-dynamic\-too\fP \fB\-fasm\fP \fB\-fllvm\fP \fB\-fbyte\-code\fP \fB\-fexternal\-dynamic\-refs\fP \fB\-fllvm\fP \fB\-fasm\fP \fB\-fno\-code\fP \fB\-fobject\-code\fP \fB\-fPIC\fP \fB\-fPIE\fP \fB\-fwrite\-interface\fP
.TP
.B Debugging the compiler
\fB\-dcmm\-lint\fP \fB\-dcore\-lint\fP \fB\-ddump\-asm\fP \fB\-ddump\-asm\-expanded\fP \fB\-ddump\-asm\-liveness\fP \fB\-ddump\-asm\-native\fP \fB\-ddump\-asm\-regalloc\fP \fB\-ddump\-asm\-regalloc\-stages\fP \fB\-ddump\-asm\-stats\fP \fB\-ddump\-bcos\fP \fB\-ddump\-cfg\-weights\fP \fB\-ddump\-cmm\fP \fB\-ddump\-cmm\-caf\fP \fB\-ddump\-cmm\-cbe\fP \fB\-ddump\-cmm\-cfg\fP \fB\-ddump\-cmm\-cps\fP \fB\-ddump\-cmm\-from\-stg\fP \fB\-ddump\-cmm\-info\fP \fB\-ddump\-cmm\-proc\fP \fB\-ddump\-cmm\-procmap\fP \fB\-ddump\-cmm\-raw\fP \fB\-ddump\-cmm\-sink\fP \fB\-ddump\-cmm\-sp\fP \fB\-ddump\-cmm\-split\fP \fB\-ddump\-cmm\-switch\fP \fB\-ddump\-cmm\-verbose\fP \fB\-ddump\-cmm\-verbose\-by\-proc\fP \fB\-ddump\-core\-stats\fP \fB\-ddump\-cse\fP \fB\-ddump\-deriv\fP \fB\-ddump\-ds\fP \fB\-ddump\-ds\-preopt\fP \fB\-ddump\-ec\-trace\fP \fB\-ddump\-file\-prefix=⟨str⟩\fP \fB\-ddump\-foreign\fP \fB\-ddump\-hpc\fP \fB\-ddump\-if\-trace\fP \fB\-ddump\-inlinings\fP \fB\-ddump\-json\fP \fB\-ddump\-llvm\fP \fB\-ddump\-mod\-map\fP \fB\-ddump\-occur\-anal\fP \fB\-ddump\-opt\-cmm\fP \fB\-ddump\-parsed\fP \fB\-ddump\-parsed\-ast\fP \fB\-ddump\-prep\fP \fB\-ddump\-rn\fP \fB\-ddump\-rn\-ast\fP \fB\-ddump\-rn\-stats\fP \fB\-ddump\-rn\-trace\fP \fB\-ddump\-rtti\fP \fB\-ddump\-rule\-firings\fP \fB\-ddump\-rule\-rewrites\fP \fB\-ddump\-rules\fP \fB\-ddump\-simpl\fP \fB\-ddump\-simpl\-iterations\fP \fB\-ddump\-simpl\-stats\fP \fB\-ddump\-spec\fP \fB\-ddump\-splices\fP \fB\-ddump\-stg\fP \fB\-ddump\-stg\-final\fP \fB\-ddump\-stg\-unarised\fP \fB\-ddump\-str\-signatures\fP \fB\-ddump\-stranal\fP \fB\-ddump\-tc\fP \fB\-ddump\-tc\-ast\fP \fB\-ddump\-tc\-trace\fP \fB\-ddump\-ticked\fP \fB\-ddump\-timings\fP \fB\-ddump\-to\-file\fP \fB\-ddump\-types\fP \fB\-ddump\-worker\-wrapper\fP \fB\-dfaststring\-stats\fP \fB\-dhex\-word\-literals\fP \fB\-dinitial\-unique=⟨s⟩\fP \fB\-dinline\-check=⟨str⟩\fP \fB\-dno\-debug\-output\fP \fB\-ddebug\-output\fP \fB\-dno\-typeable\-binds\fP \fB\-dppr\-case\-as\-let\fP \fB\-dppr\-cols=⟨n⟩\fP \fB\-dppr\-debug\fP \fB\-dppr\-user\-length\fP \fB\-drule\-check=⟨str⟩\fP \fB\-dshow\-passes\fP \fB\-dstg\-lint\fP \fB\-dsuppress\-all\fP \fB\-dsuppress\-coercions\fP \fB\-dsuppress\-idinfo\fP \fB\-dsuppress\-module\-prefixes\fP \fB\-dsuppress\-stg\-free\-vars\fP \fB\-dsuppress\-ticks\fP \fB\-dsuppress\-timestamps\fP \fB\-dsuppress\-type\-applications\fP \fB\-dsuppress\-type\-signatures\fP \fB\-dsuppress\-unfoldings\fP \fB\-dsuppress\-uniques\fP \fB\-dsuppress\-var\-kinds\fP \fB\-dth\-dec\-file\fP \fB\-dunique\-increment=⟨i⟩\fP \fB\-dverbose\-core2core\fP \fB\-dverbose\-stg2stg\fP \fB\-falignment\-sanitisation\fP \fB\-fcatch\-bottoms\fP \fB\-fllvm\-fill\-undef\-with\-garbage\fP \fB\-fproc\-alignment\fP \fB\-g\fP \fB\-g⟨n⟩\fP
.TP
.B C pre\-processor
\fB\-cpp\fP \fB\-D⟨symbol⟩[=⟨value⟩]\fP \fB\-U⟨symbol⟩\fP \fB\-I⟨dir⟩\fP \fB\-U⟨symbol⟩\fP
.TP
.B Finding imports
\fB\-i\fP \fB\-i⟨dir⟩[:⟨dir⟩]*\fP
.TP
.B Interactive mode
\fB\-fbreak\-on\-error\fP \fB\-fno\-break\-on\-error\fP \fB\-fbreak\-on\-exception\fP \fB\-fno\-break\-on\-exception\fP \fB\-fghci\-hist\-size=⟨n⟩\fP \fB\-fghci\-leak\-check\fP \fB\-fno\-ghci\-leak\-check\fP \fB\-flocal\-ghci\-history\fP \fB\-fno\-local\-ghci\-history\fP \fB\-fno\-it\fP \fB\-fno\-no\-it\fP \fB\-fprint\-bind\-result\fP \fB\-fno\-print\-bind\-result\fP \fB\-fprint\-evld\-with\-show\fP \fB\-fshow\-loaded\-modules\fP \fB\-ghci\-script\fP \fB\-ignore\-dot\-ghci\fP \fB\-interactive\-print ⟨name⟩\fP
.TP
.B Interface files
\fB\-\-show\-iface ⟨file⟩\fP \fB\-ddump\-hi\fP \fB\-ddump\-hi\-diffs\fP \fB\-ddump\-minimal\-imports\fP
.TP
.B Keeping intermediate files
\fB\-keep\-hc\-file\fP \fB\-keep\-hc\-files\fP \fB\-keep\-hi\-files\fP \fB\-no\-keep\-hi\-files\fP \fB\-keep\-hscpp\-file\fP \fB\-keep\-hscpp\-files\fP \fB\-keep\-llvm\-file\fP \fB\-keep\-llvm\-files\fP \fB\-keep\-o\-files\fP \fB\-no\-keep\-o\-files\fP \fB\-keep\-s\-file\fP \fB\-keep\-s\-files\fP \fB\-keep\-tmp\-files\fP
.TP
.B Language options
\fB\-fno\-safe\-haskell\fP \fB\-fsort\-by\-size\-hole\-fits\fP \fB\-fno\-sort\-by\-size\-hole\-fits\fP \fB\-fsort\-by\-subsumption\-hole\-fits\fP \fB\-fno\-sort\-by\-subsumption\-hole\-fits\fP \fB\-Winferred\-safe\-imports\fP \fB\-Wno\-inferred\-safe\-imports\fP \fB\-Wmissing\-safe\-haskell\-mode\fP \fB\-Wno\-missing\-safe\-haskell\-mode\fP \fB\-XAllowAmbiguousTypes\fP \fB\-XApplicativeDo\fP \fB\-XArrows\fP \fB\-XBangPatterns\fP \fB\-XBinaryLiterals\fP \fB\-XBlockArguments\fP \fB\-XCApiFFI\fP \fB\-XConstrainedClassMethods\fP \fB\-XConstraintKinds\fP \fB\-XCPP\fP \fB\-XCUSKs\fP \fB\-XDataKinds\fP \fB\-XDatatypeContexts\fP \fB\-XDefaultSignatures\fP \fB\-XDeriveAnyClass\fP \fB\-XDeriveDataTypeable\fP \fB\-XDeriveFoldable\fP \fB\-XDeriveFunctor\fP \fB\-XDeriveGeneric\fP \fB\-XDeriveLift\fP \fB\-XDeriveTraversable\fP \fB\-XDerivingStrategies\fP \fB\-XDerivingVia\fP \fB\-XDisambiguateRecordFields\fP \fB\-XDuplicateRecordFields\fP \fB\-XEmptyCase\fP \fB\-XEmptyDataDecls\fP \fB\-XEmptyDataDeriving\fP \fB\-XExistentialQuantification\fP \fB\-XExplicitForAll\fP \fB\-XExplicitNamespaces\fP \fB\-XExtendedDefaultRules\fP \fB\-XFlexibleContexts\fP \fB\-XFlexibleInstances\fP \fB\-XForeignFunctionInterface\fP \fB\-XFunctionalDependencies\fP \fB\-XGADTs\fP \fB\-XGADTSyntax\fP \fB\-XGeneralisedNewtypeDeriving\fP \fB\-XGeneralizedNewtypeDeriving\fP \fB\-XHaskell2010\fP \fB\-XHaskell98\fP \fB\-XHexFloatLiterals\fP \fB\-XImplicitParams\fP \fB\-XImportQualifiedPost\fP \fB\-XImpredicativeTypes\fP \fB\-XIncoherentInstances\fP \fB\-XInstanceSigs\fP \fB\-XInterruptibleFFI\fP \fB\-XKindSignatures\fP \fB\-XLambdaCase\fP \fB\-XLiberalTypeSynonyms\fP \fB\-XMagicHash\fP \fB\-XMonadComprehensions\fP \fB\-XMonadFailDesugaring\fP \fB\-XMonoLocalBinds\fP \fB\-XMultiParamTypeClasses\fP \fB\-XMultiWayIf\fP \fB\-XNamedFieldPuns\fP \fB\-XNamedWildCards\fP \fB\-XNegativeLiterals\fP \fB\-XNoImplicitPrelude\fP \fB\-XNoMonomorphismRestriction\fP \fB\-XNondecreasingIndentation\fP \fB\-XNoPatternGuards\fP \fB\-XNoTraditionalRecordSyntax\fP \fB\-XNPlusKPatterns\fP \fB\-XNullaryTypeClasses\fP \fB\-XNumDecimals\fP \fB\-XNumericUnderscores\fP \fB\-XOverlappingInstances\fP \fB\-XOverloadedLabels\fP \fB\-XOverloadedLists\fP \fB\-XOverloadedStrings\fP \fB\-XPackageImports\fP \fB\-XParallelListComp\fP \fB\-XPartialTypeSignatures\fP \fB\-XPatternSynonyms\fP \fB\-XPolyKinds\fP \fB\-XPostfixOperators\fP \fB\-XQuantifiedConstraints\fP \fB\-XQuasiQuotes\fP \fB\-XRank2Types\fP \fB\-XRankNTypes\fP \fB\-XRebindableSyntax\fP \fB\-XRecordWildCards\fP \fB\-XRecursiveDo\fP \fB\-XRoleAnnotations\fP \fB\-XSafe\fP \fB\-XScopedTypeVariables\fP \fB\-XStandaloneDeriving\fP \fB\-XStandaloneKindSignatures\fP \fB\-XStarIsType\fP \fB\-XStaticPointers\fP \fB\-XStrict\fP \fB\-XStrictData\fP \fB\-XTemplateHaskell\fP \fB\-XTemplateHaskellQuotes\fP \fB\-XTransformListComp\fP \fB\-XTrustworthy\fP \fB\-XTupleSections\fP \fB\-XTypeApplications\fP \fB\-XTypeFamilies\fP \fB\-XTypeFamilyDependencies\fP \fB\-XTypeInType\fP \fB\-XTypeOperators\fP \fB\-XTypeSynonymInstances\fP \fB\-XUnboxedSums\fP \fB\-XUnboxedTuples\fP \fB\-XUndecidableInstances\fP \fB\-XUndecidableSuperClasses\fP \fB\-XUnicodeSyntax\fP \fB\-XUnliftedFFITypes\fP \fB\-XUnliftedNewtypes\fP \fB\-XUnsafe\fP \fB\-XViewPatterns\fP
.TP
.B Linking options
\fB\-c\fP \fB\-debug\fP \fB\-dylib\-install\-name ⟨path⟩\fP \fB\-dynamic\fP \fB\-dynload\fP \fB\-eventlog\fP \fB\-fno\-embed\-manifest\fP \fB\-fno\-gen\-manifest\fP \fB\-fno\-shared\-implib\fP \fB\-framework ⟨name⟩\fP \fB\-framework\-path ⟨dir⟩\fP \fB\-fwhole\-archive\-hs\-libs\fP \fB\-keep\-cafs\fP \fB\-L ⟨dir⟩\fP \fB\-l ⟨lib⟩\fP \fB\-main\-is ⟨thing⟩\fP \fB\-no\-hs\-main\fP \fB\-no\-rtsopts\-suggestions\fP \fB\-package ⟨name⟩\fP \fB\-pie\fP \fB\-rdynamic\fP \fB\-rtsopts[=⟨none|some|all|ignore|ignoreAll⟩]\fP \fB\-shared\fP \fB\-split\-sections\fP \fB\-static\fP \fB\-staticlib\fP \fB\-threaded\fP \fB\-with\-rtsopts=⟨opts⟩\fP
.TP
.B Miscellaneous options
\fB\-fexternal\-interpreter\fP \fB\-fglasgow\-exts\fP \fB\-fno\-glasgow\-exts\fP \fB\-ghcversion\-file ⟨path to ghcversion.h⟩\fP \fB\-H ⟨size⟩\fP \fB\-j[⟨n⟩]\fP
.TP
.B Modes of operation
\fB\-\-frontend ⟨module⟩\fP \fB\-\-help\fP \fB\-?\fP \fB\-\-info\fP \fB\-\-interactive\fP \fB\-\-make\fP \fB\-\-mk\-dll\fP \fB\-\-numeric\-version\fP \fB\-\-print\-libdir\fP \fB\-\-show\-iface ⟨file⟩\fP \fB\-\-show\-options\fP \fB\-\-supported\-extensions\fP \fB\-\-supported\-languages\fP \fB\-\-version\fP \fB\-V\fP \fB\-e ⟨expr⟩\fP \fB\-M\fP
.TP
.B Individual optimizations
\fB\-fasm\-shortcutting\fP \fB\-fno\-asm\-shortcutting\fP \fB\-fbinary\-blob\-threshold=⟨n⟩\fP \fB\-fblock\-layout\-cfg\fP \fB\-fno\-block\-layout\-cfg\fP \fB\-fblock\-layout\-weightless\fP \fB\-fno\-block\-layout\-weightless\fP \fB\-fblock\-layout\-weights\fP \fB\-fcall\-arity\fP \fB\-fno\-call\-arity\fP \fB\-fcase\-folding\fP \fB\-fno\-case\-folding\fP \fB\-fcase\-merge\fP \fB\-fno\-case\-merge\fP \fB\-fcmm\-elim\-common\-blocks\fP \fB\-fno\-cmm\-elim\-common\-blocks\fP \fB\-fcmm\-sink\fP \fB\-fno\-cmm\-sink\fP \fB\-fcpr\-anal\fP \fB\-fno\-cpr\-anal\fP \fB\-fcross\-module\-specialise\fP \fB\-fno\-cross\-module\-specialise\fP \fB\-fcse\fP \fB\-fno\-cse\fP \fB\-fdicts\-cheap\fP \fB\-fno\-dicts\-cheap\fP \fB\-fdicts\-strict\fP \fB\-fno\-dicts\-strict\fP \fB\-fdmd\-tx\-dict\-sel\fP \fB\-fno\-dmd\-tx\-dict\-sel\fP \fB\-fdo\-eta\-reduction\fP \fB\-fno\-do\-eta\-reduction\fP \fB\-fdo\-lambda\-eta\-expansion\fP \fB\-fno\-do\-lambda\-eta\-expansion\fP \fB\-feager\-blackholing\fP \fB\-fenable\-rewrite\-rules\fP \fB\-fno\-enable\-rewrite\-rules\fP \fB\-fexcess\-precision\fP \fB\-fno\-excess\-precision\fP \fB\-fexitification\fP \fB\-fno\-exitification\fP \fB\-fexpose\-all\-unfoldings\fP \fB\-fno\-expose\-all\-unfoldings\fP \fB\-ffloat\-in\fP \fB\-fno\-float\-in\fP \fB\-ffull\-laziness\fP \fB\-fno\-full\-laziness\fP \fB\-ffun\-to\-thunk\fP \fB\-fno\-fun\-to\-thunk\fP \fB\-fignore\-asserts\fP \fB\-fno\-ignore\-asserts\fP \fB\-fignore\-interface\-pragmas\fP \fB\-fno\-ignore\-interface\-pragmas\fP \fB\-flate\-dmd\-anal\fP \fB\-fno\-late\-dmd\-anal\fP \fB\-flate\-specialise\fP \fB\-fno\-late\-specialise\fP \fB\-fliberate\-case\fP \fB\-fno\-liberate\-case\fP \fB\-fliberate\-case\-threshold=⟨n⟩\fP \fB\-fno\-liberate\-case\-threshold\fP \fB\-fllvm\-pass\-vectors\-in\-regs\fP \fB\-fno\-llvm\-pass\-vectors\-in\-regs\fP \fB\-floopification\fP \fB\-fno\-loopification\fP \fB\-fmax\-inline\-alloc\-size=⟨n⟩\fP \fB\-fmax\-inline\-memcpy\-insns=⟨n⟩\fP \fB\-fmax\-inline\-memset\-insns=⟨n⟩\fP \fB\-fmax\-simplifier\-iterations=⟨n⟩\fP \fB\-fmax\-uncovered\-patterns=⟨n⟩\fP \fB\-fmax\-worker\-args=⟨n⟩\fP \fB\-fno\-opt\-coercion\fP \fB\-fno\-pre\-inlining\fP \fB\-fno\-state\-hack\fP \fB\-fomit\-interface\-pragmas\fP \fB\-fno\-omit\-interface\-pragmas\fP \fB\-fomit\-yields\fP \fB\-fno\-omit\-yields\fP \fB\-foptimal\-applicative\-do\fP \fB\-fno\-optimal\-applicative\-do\fP \fB\-fpedantic\-bottoms\fP \fB\-fno\-pedantic\-bottoms\fP \fB\-fregs\-graph\fP \fB\-fno\-regs\-graph\fP \fB\-fregs\-iterative\fP \fB\-fno\-regs\-iterative\fP \fB\-fsimpl\-tick\-factor=⟨n⟩\fP \fB\-fsimplifier\-phases=⟨n⟩\fP \fB\-fsolve\-constant\-dicts\fP \fB\-fno\-solve\-constant\-dicts\fP \fB\-fspec\-constr\fP \fB\-fno\-spec\-constr\fP \fB\-fspec\-constr\-count=⟨n⟩\fP \fB\-fno\-spec\-constr\-count\fP \fB\-fspec\-constr\-keen\fP \fB\-fno\-spec\-constr\-keen\fP \fB\-fspec\-constr\-threshold=⟨n⟩\fP \fB\-fno\-spec\-constr\-threshold\fP \fB\-fspecialise\fP \fB\-fno\-specialise\fP \fB\-fspecialise\-aggressively\fP \fB\-fno\-specialise\-aggressively\fP \fB\-fstatic\-argument\-transformation\fP \fB\-fno\-static\-argument\-transformation\fP \fB\-fstg\-cse\fP \fB\-fno\-stg\-cse\fP \fB\-fstg\-lift\-lams\fP \fB\-fno\-stg\-lift\-lams\fP \fB\-fstg\-lift\-lams\-known\fP \fB\-fno\-stg\-lift\-lams\-known\fP \fB\-fstg\-lift\-lams\-non\-rec\-args\fP \fB\-fno\-stg\-lift\-lams\-non\-rec\-args\-any\fP \fB\-fstg\-lift\-lams\-rec\-args\fP \fB\-fno\-stg\-lift\-lams\-rec\-args\-any\fP \fB\-fstrictness\fP \fB\-fno\-strictness\fP \fB\-fstrictness\-before=⟨n⟩\fP \fB\-funbox\-small\-strict\-fields\fP \fB\-fno\-unbox\-small\-strict\-fields\fP \fB\-funbox\-strict\-fields\fP \fB\-fno\-unbox\-strict\-fields\fP \fB\-funfolding\-creation\-threshold=⟨n⟩\fP \fB\-funfolding\-dict\-discount=⟨n⟩\fP \fB\-funfolding\-fun\-discount=⟨n⟩\fP \fB\-funfolding\-keeness\-factor=⟨n⟩\fP \fB\-funfolding\-use\-threshold=⟨n⟩\fP \fB\-fworker\-wrapper\fP
.TP
.B Optimization levels
\fB\-O\fP \fB\-O1\fP \fB\-O0\fP \fB\-O0\fP \fB\-O2\fP \fB\-O0\fP \fB\-O⟨n⟩\fP \fB\-O0\fP
.TP
.B Package options
\fB\-clear\-package\-db\fP \fB\-distrust ⟨pkg⟩\fP \fB\-distrust\-all\-packages\fP \fB\-fpackage\-trust\fP \fB\-global\-package\-db\fP \fB\-hide\-all\-packages\fP \fB\-hide\-package ⟨pkg⟩\fP \fB\-ignore\-package ⟨pkg⟩\fP \fB\-no\-auto\-link\-packages\fP \fB\-no\-global\-package\-db\fP \fB\-no\-user\-package\-db\fP \fB\-package ⟨pkg⟩\fP \fB\-package\-db ⟨file⟩\fP \fB\-package\-env ⟨file⟩|⟨name⟩\fP \fB\-package\-id ⟨unit\-id⟩\fP \fB\-this\-unit\-id ⟨unit\-id⟩\fP \fB\-trust ⟨pkg⟩\fP \fB\-user\-package\-db\fP
.TP
.B Phases of compilation
\fB\-C\fP \fB\-c\fP \fB\-E\fP \fB\-F\fP \fB\-S\fP \fB\-x ⟨suffix⟩\fP
.TP
.B Overriding external programs
\fB\-pgma ⟨cmd⟩\fP \fB\-pgmc ⟨cmd⟩\fP \fB\-pgmdll ⟨cmd⟩\fP \fB\-pgmF ⟨cmd⟩\fP \fB\-pgmi ⟨cmd⟩\fP \fB\-pgminstall_name_tool ⟨cmd⟩\fP \fB\-pgmL ⟨cmd⟩\fP \fB\-pgml ⟨cmd⟩\fP \fB\-pgmlc ⟨cmd⟩\fP \fB\-pgmlibtool ⟨cmd⟩\fP \fB\-pgmlm ⟨cmd⟩\fP \fB\-pgmlo ⟨cmd⟩\fP \fB\-pgmotool ⟨cmd⟩\fP \fB\-pgmP ⟨cmd⟩\fP \fB\-pgms ⟨cmd⟩\fP \fB\-pgmwindres ⟨cmd⟩\fP
.TP
.B Phase\-specific options
\fB\-opta ⟨option⟩\fP \fB\-optc ⟨option⟩\fP \fB\-optcxx ⟨option⟩\fP \fB\-optdll ⟨option⟩\fP \fB\-optF ⟨option⟩\fP \fB\-opti ⟨option⟩\fP \fB\-optL ⟨option⟩\fP \fB\-optl ⟨option⟩\fP \fB\-optlc ⟨option⟩\fP \fB\-optlm ⟨option⟩\fP \fB\-optlo ⟨option⟩\fP \fB\-optP ⟨option⟩\fP \fB\-optwindres ⟨option⟩\fP \fB\-pgmc\-supports\-no\-pie\fP
.TP
.B Platform\-specific options
\fB\-mbmi2\fP \fB\-msse2\fP \fB\-msse4.2\fP
.TP
.B Compiler plugins
\fB\-fclear\-plugins\fP \fB\-fplugin\-opt=⟨module⟩:⟨args⟩\fP \fB\-fplugin\-trustworthy\fP \fB\-fplugin=⟨module⟩\fP \fB\-hide\-all\-plugin\-packages\fP \fB\-plugin\-package ⟨pkg⟩\fP \fB\-plugin\-package\-id ⟨pkg\-id⟩\fP
.TP
.B Profiling
\fB\-fno\-prof\-auto\fP \fB\-fprof\-auto\fP \fB\-fno\-prof\-cafs\fP \fB\-fprof\-cafs\fP \fB\-fno\-prof\-count\-entries\fP \fB\-fprof\-count\-entries\fP \fB\-fprof\-auto\fP \fB\-fno\-prof\-auto\fP \fB\-fprof\-auto\-calls\fP \fB\-fno\-prof\-auto\-calls\fP \fB\-fprof\-auto\-exported\fP \fB\-fno\-prof\-auto\fP \fB\-fprof\-auto\-top\fP \fB\-fno\-prof\-auto\fP \fB\-fprof\-cafs\fP \fB\-fno\-prof\-cafs\fP \fB\-prof\fP \fB\-ticky\fP
.TP
.B Program coverage
\fB\-fhpc\fP
.TP
.B Recompilation checking
\fB\-fforce\-recomp\fP \fB\-fno\-force\-recomp\fP \fB\-fignore\-hpc\-changes\fP \fB\-fno\-ignore\-hpc\-changes\fP \fB\-fignore\-optim\-changes\fP \fB\-fno\-ignore\-optim\-changes\fP
.TP
.B Redirecting output
\fB\-\-exclude\-module=⟨file⟩\fP \fB\-ddump\-mod\-cycles\fP \fB\-dep\-makefile ⟨file⟩\fP \fB\-dep\-suffix ⟨suffix⟩\fP \fB\-dumpdir ⟨dir⟩\fP \fB\-hcsuf ⟨suffix⟩\fP \fB\-hidir ⟨dir⟩\fP \fB\-hiedir ⟨dir⟩\fP \fB\-hiesuf ⟨suffix⟩\fP \fB\-hisuf ⟨suffix⟩\fP \fB\-include\-cpp\-deps\fP \fB\-include\-pkg\-deps\fP \fB\-o ⟨file⟩\fP \fB\-odir ⟨dir⟩\fP \fB\-ohi ⟨file⟩\fP \fB\-osuf ⟨suffix⟩\fP \fB\-outputdir ⟨dir⟩\fP \fB\-stubdir ⟨dir⟩\fP
.TP
.B Temporary files
\fB\-tmpdir ⟨dir⟩\fP
.TP
.B Verbosity options
\fB\-fabstract\-refinement\-hole\-fits\fP \fB\-fno\-abstract\-refinement\-hole\-fits\fP \fB\-fdefer\-diagnostics\fP \fB\-fdiagnostics\-color=⟨always|auto|never⟩\fP \fB\-fdiagnostics\-show\-caret\fP \fB\-fno\-diagnostics\-show\-caret\fP \fB\-ferror\-spans\fP \fB\-fhide\-source\-paths\fP \fB\-fkeep\-going\fP \fB\-fmax\-refinement\-hole\-fits=⟨n⟩\fP \fB\-fno\-max\-refinement\-hole\-fits\fP \fB\-fmax\-relevant\-binds=⟨n⟩\fP \fB\-fno\-max\-relevant\-binds\fP \fB\-fmax\-valid\-hole\-fits=⟨n⟩\fP \fB\-fno\-max\-valid\-hole\-fits\fP \fB\-fno\-show\-valid\-hole\-fits\fP \fB\-fno\-sort\-valid\-hole\-fits\fP \fB\-fsort\-valid\-hole\-fits\fP \fB\-fprint\-axiom\-incomps\fP \fB\-fno\-print\-axiom\-incomps\fP \fB\-fprint\-equality\-relations\fP \fB\-fno\-print\-equality\-relations\fP \fB\-fprint\-expanded\-synonyms\fP \fB\-fno\-print\-expanded\-synonyms\fP \fB\-fprint\-explicit\-coercions\fP \fB\-fno\-print\-explicit\-coercions\fP \fB\-fprint\-explicit\-foralls\fP \fB\-fno\-print\-explicit\-foralls\fP \fB\-fprint\-explicit\-kinds\fP \fB\-fno\-print\-explicit\-kinds\fP \fB\-fprint\-explicit\-runtime\-reps\fP \fB\-fno\-print\-explicit\-runtime\-reps\fP \fB\-fprint\-potential\-instances\fP \fB\-fno\-print\-potential\-instances\fP \fB\-fprint\-typechecker\-elaboration\fP \fB\-fno\-print\-typechecker\-elaboration\fP \fB\-fprint\-unicode\-syntax\fP \fB\-fno\-print\-unicode\-syntax\fP \fB\-frefinement\-level\-hole\-fits=⟨n⟩\fP \fB\-fno\-refinement\-level\-hole\-fits\fP \fB\-freverse\-errors\fP \fB\-fno\-reverse\-errors\fP \fB\-fshow\-docs\-of\-hole\-fits\fP \fB\-fno\-show\-docs\-of\-hole\-fits\fP \fB\-fshow\-hole\-constraints\fP \fB\-fshow\-hole\-matches\-of\-hole\-fits\fP \fB\-fno\-show\-hole\-matches\-of\-hole\-fits\fP \fB\-fshow\-provenance\-of\-hole\-fits\fP \fB\-fno\-show\-provenance\-of\-hole\-fits\fP \fB\-fshow\-type\-app\-of\-hole\-fits\fP \fB\-fno\-show\-type\-app\-of\-hole\-fits\fP \fB\-fshow\-type\-app\-vars\-of\-hole\-fits\fP \fB\-fno\-show\-type\-app\-vars\-of\-hole\-fits\fP \fB\-fshow\-type\-of\-hole\-fits\fP \fB\-fno\-type\-of\-hole\-fits\fP \fB\-funclutter\-valid\-hole\-fits\fP \fB\-Rghc\-timing\fP \fB\-v\fP \fB\-v⟨n⟩\fP
.TP
.B Warnings
\fB\-fdefer\-out\-of\-scope\-variables\fP \fB\-fno\-defer\-out\-of\-scope\-variables\fP \fB\-fdefer\-type\-errors\fP \fB\-fno\-defer\-type\-errors\fP \fB\-fdefer\-typed\-holes\fP \fB\-fno\-defer\-typed\-holes\fP \fB\-fenable\-th\-splice\-warnings\fP \fB\-fno\-enable\-th\-splices\fP \fB\-fhelpful\-errors\fP \fB\-fno\-helpful\-errors\fP \fB\-fmax\-pmcheck\-models=⟨n⟩\fP \fB\-fshow\-warning\-groups\fP \fB\-fno\-show\-warning\-groups\fP \fB\-fvia\-C\fP \fB\-W\fP \fB\-w\fP \fB\-w\fP \fB\-Wall\fP \fB\-w\fP \fB\-Wall\-missed\-specialisations\fP \fB\-Wno\-all\-missed\-specialisations\fP \fB\-Wcompat\fP \fB\-Wno\-compat\fP \fB\-Wcompat\-unqualified\-imports\fP \fB\-Wno\-compat\-unqualified\-imports\fP \fB\-Wcpp\-undef\fP \fB\-Wdeferred\-out\-of\-scope\-variables\fP \fB\-Wno\-deferred\-out\-of\-scope\-variables\fP \fB\-Wdeferred\-type\-errors\fP \fB\-Wno\-deferred\-type\-errors\fP \fB\-Wdeprecated\-flags\fP \fB\-Wno\-deprecated\-flags\fP \fB\-Wdeprecations\fP \fB\-Wno\-deprecations\fP \fB\-Wderiving\-defaults\fP \fB\-Wno\-deriving\-defaults\fP \fB\-Wdodgy\-exports\fP \fB\-Wno\-dodgy\-exports\fP \fB\-Wdodgy\-foreign\-imports\fP \fB\-Wno\-dodgy\-foreign\-import\fP \fB\-Wdodgy\-imports\fP \fB\-Wno\-dodgy\-imports\fP \fB\-Wduplicate\-constraints\fP \fB\-Wno\-duplicate\-constraints\fP \fB\-Wduplicate\-exports\fP \fB\-Wno\-duplicate\-exports\fP \fB\-Wempty\-enumerations\fP \fB\-Wno\-empty\-enumerations\fP \fB\-Werror\fP \fB\-Wwarn\fP \fB\-Weverything\fP \fB\-Whi\-shadowing\fP \fB\-Wno\-hi\-shadowing\fP \fB\-Widentities\fP \fB\-Wno\-identities\fP \fB\-Wimplicit\-kind\-vars\fP \fB\-Wno\-implicit\-kind\-vars\fP \fB\-Wimplicit\-prelude\fP \fB\-Wno\-implicit\-prelude\fP \fB\-Winaccessible\-code\fP \fB\-Wno\-inaccessible\-code\fP \fB\-Wincomplete\-patterns\fP \fB\-Wno\-incomplete\-patterns\fP \fB\-Wincomplete\-record\-updates\fP \fB\-Wno\-incomplete\-record\-updates\fP \fB\-Wincomplete\-uni\-patterns\fP \fB\-Wno\-incomplete\-uni\-patterns\fP \fB\-Winline\-rule\-shadowing\fP \fB\-Wno\-inline\-rule\-shadowing\fP \fB\-Wmissed\-extra\-shared\-lib\fP \fB\-Wno\-missed\-extra\-shared\-lib\fP \fB\-Wmissed\-specialisations\fP \fB\-Wno\-missed\-specialisations\fP \fB\-Wmissing\-deriving\-strategies\fP \fB\-Wno\-missing\-deriving\-strategies\fP \fB\-Wmissing\-export\-lists\fP \fB\-fnowarn\-missing\-export\-lists\fP \fB\-Wmissing\-exported\-signatures\fP \fB\-Wno\-missing\-exported\-signatures\fP \fB\-Wmissing\-exported\-sigs\fP \fB\-Wno\-missing\-exported\-sigs\fP \fB\-Wmissing\-fields\fP \fB\-Wno\-missing\-fields\fP \fB\-Wmissing\-home\-modules\fP \fB\-Wno\-missing\-home\-modules\fP \fB\-Wmissing\-import\-lists\fP \fB\-fnowarn\-missing\-import\-lists\fP \fB\-Wmissing\-local\-signatures\fP \fB\-Wno\-missing\-local\-signatures\fP \fB\-Wmissing\-local\-sigs\fP \fB\-Wno\-missing\-local\-sigs\fP \fB\-Wmissing\-methods\fP \fB\-Wno\-missing\-methods\fP \fB\-Wmissing\-monadfail\-instances\fP \fB\-Wno\-missing\-monadfail\-instances\fP \fB\-Wmissing\-pattern\-synonym\-signatures\fP \fB\-Wno\-missing\-pattern\-synonym\-signatures\fP \fB\-Wmissing\-signatures\fP \fB\-Wno\-missing\-signatures\fP \fB\-Wmonomorphism\-restriction\fP \fB\-Wno\-monomorphism\-restriction\fP \fB\-Wname\-shadowing\fP \fB\-Wno\-name\-shadowing\fP \fB\-Wno\-compat\fP \fB\-Wcompat\fP \fB\-Wnoncanonical\-monad\-instances\fP \fB\-Wno\-noncanonical\-monad\-instances\fP \fB\-Wnoncanonical\-monadfail\-instances\fP \fB\-Wno\-noncanonical\-monadfail\-instances\fP \fB\-Wnoncanonical\-monoid\-instances\fP \fB\-Wno\-noncanonical\-monoid\-instances\fP \fB\-Worphans\fP \fB\-Wno\-orphans\fP \fB\-Woverflowed\-literals\fP \fB\-Wno\-overflowed\-literals\fP \fB\-Woverlapping\-patterns\fP \fB\-Wno\-overlapping\-patterns\fP \fB\-Wpartial\-fields\fP \fB\-Wno\-partial\-fields\fP \fB\-Wpartial\-type\-signatures\fP \fB\-Wno\-partial\-type\-signatures\fP \fB\-Wredundant\-constraints\fP \fB\-Wno\-redundant\-constraints\fP \fB\-Wredundant\-record\-wildcards\fP \fB\-Wno\-redundant\-record\-wildcards\fP \fB\-Wsafe\fP \fB\-Wno\-safe\fP \fB\-Wsemigroup\fP \fB\-Wno\-semigroup\fP \fB\-Wsimplifiable\-class\-constraints\fP \fB\-Wno\-simplifiable\-class\-constraints\fP \fB\-Wspace\-after\-bang\fP \fB\-Wno\-missing\-space\-after\-bang\fP \fB\-Wstar\-binder\fP \fB\-Wno\-star\-binder\fP \fB\-Wstar\-is\-type\fP \fB\-Wno\-star\-is\-type\fP \fB\-Wtabs\fP \fB\-Wno\-tabs\fP \fB\-Wtrustworthy\-safe\fP \fB\-Wno\-safe\fP \fB\-Wtype\-defaults\fP \fB\-Wno\-type\-defaults\fP \fB\-Wtyped\-holes\fP \fB\-Wno\-typed\-holes\fP \fB\-Wunbanged\-strict\-patterns\fP \fB\-Wno\-unbanged\-strict\-patterns\fP \fB\-Wunrecognised\-pragmas\fP \fB\-Wno\-unrecognised\-pragmas\fP \fB\-Wunrecognised\-warning\-flags\fP \fB\-Wno\-unrecognised\-warning\-flags\fP \fB\-Wunsafe\fP \fB\-Wno\-unsafe\fP \fB\-Wunsupported\-calling\-conventions\fP \fB\-Wno\-unsupported\-calling\-conventions\fP \fB\-Wunsupported\-llvm\-version\fP \fB\-Wno\-monomorphism\-restriction\fP \fB\-Wunticked\-promoted\-constructors\fP \fB\-Wno\-unticked\-promoted\-constructors\fP \fB\-Wunused\-binds\fP \fB\-Wno\-unused\-binds\fP \fB\-Wunused\-do\-bind\fP \fB\-Wno\-unused\-do\-bind\fP \fB\-Wunused\-foralls\fP \fB\-Wno\-unused\-foralls\fP \fB\-Wunused\-imports\fP \fB\-Wno\-unused\-imports\fP \fB\-Wunused\-local\-binds\fP \fB\-Wno\-unused\-local\-binds\fP \fB\-Wunused\-matches\fP \fB\-Wno\-unused\-matches\fP \fB\-Wunused\-packages\fP \fB\-Wno\-unused\-packages\fP \fB\-Wunused\-pattern\-binds\fP \fB\-Wno\-unused\-pattern\-binds\fP \fB\-Wunused\-record\-wildcards\fP \fB\-Wno\-unused\-record\-wildcards\fP \fB\-Wunused\-top\-binds\fP \fB\-Wno\-unused\-top\-binds\fP \fB\-Wunused\-type\-patterns\fP \fB\-Wno\-unused\-type\-patterns\fP \fB\-Wwarn\fP \fB\-Werror\fP \fB\-Wwarnings\-deprecations\fP \fB\-Wno\-warnings\-deprecations\fP \fB\-Wwrong\-do\-bind\fP \fB\-Wno\-wrong\-do\-bind\fP
.SS Code generation
.INDENT 0.0
.TP
.B \fB\-dynamic\-too\fP
Build dynamic object files \fIas well as\fP static object files
during compilation
.TP
.B \fB\-fasm\fP
Use the native code generator
.TP
.B \fB\-fbyte\-code\fP
Generate byte\-code
.TP
.B \fB\-fexternal\-dynamic\-refs\fP
Generate code for linking against dynamic libraries
.TP
.B \fB\-fllvm\fP
Compile using the LLVM code generator
.TP
.B \fB\-fno\-code\fP
Omit code generation
.TP
.B \fB\-fobject\-code\fP
Generate object code
.TP
.B \fB\-fPIC\fP
Generate position\-independent code (where available)
.TP
.B \fB\-fPIE\fP
Generate code for a position\-independent executable (where available)
.TP
.B \fB\-fwrite\-interface\fP
Always write interface files
.UNINDENT
.SS Debugging the compiler
.INDENT 0.0
.TP
.B \fB\-dcmm\-lint\fP
C\-\e\- pass sanity checking
.TP
.B \fB\-dcore\-lint\fP
Turn on internal sanity checking
.TP
.B \fB\-ddump\-asm\fP
Dump final assembly
.TP
.B \fB\-ddump\-asm\-expanded\fP
Dump the result of the synthetic instruction expansion pass.
.TP
.B \fB\-ddump\-asm\-liveness\fP
Dump assembly augmented with register liveness
.TP
.B \fB\-ddump\-asm\-native\fP
Dump initial assembly
.TP
.B \fB\-ddump\-asm\-regalloc\fP
Dump the result of register allocation
.TP
.B \fB\-ddump\-asm\-regalloc\-stages\fP
Dump the build/spill stages of the \fB\-fregs\-graph\fP
register allocator.
.TP
.B \fB\-ddump\-asm\-stats\fP
Dump statistics from the register allocator.
.TP
.B \fB\-ddump\-bcos\fP
Dump interpreter byte code
.TP
.B \fB\-ddump\-cfg\-weights\fP
Dump the assumed weights of the CFG.
.TP
.B \fB\-ddump\-cmm\fP
Dump the final C\-\e\- output
.TP
.B \fB\-ddump\-cmm\-caf\fP
Dump the results of the C\-\e\- CAF analysis pass.
.TP
.B \fB\-ddump\-cmm\-cbe\fP
Dump the results of common block elimination
.TP
.B \fB\-ddump\-cmm\-cfg\fP
Dump the results of the C\-\e\- control flow optimisation pass.
.TP
.B \fB\-ddump\-cmm\-cps\fP
Dump the results of the CPS pass
.TP
.B \fB\-ddump\-cmm\-from\-stg\fP
Dump STG\-to\-C\-\e\- output
.TP
.B \fB\-ddump\-cmm\-info\fP
Dump the results of the C\-\e\- info table augmentation pass.
.TP
.B \fB\-ddump\-cmm\-proc\fP
Dump the results of proc\-point analysis
.TP
.B \fB\-ddump\-cmm\-procmap\fP
Dump the results of the C\-\e\- proc\-point map pass.
.TP
.B \fB\-ddump\-cmm\-raw\fP
Dump raw C\-\e\-
.TP
.B \fB\-ddump\-cmm\-sink\fP
Dump the results of the C\-\e\- sinking pass.
.TP
.B \fB\-ddump\-cmm\-sp\fP
Dump the results of the C\-\e\- stack layout pass.
.TP
.B \fB\-ddump\-cmm\-split\fP
Dump the results of the C\-\e\- proc\-point splitting pass.
.TP
.B \fB\-ddump\-cmm\-switch\fP
Dump the results of switch lowering passes
.TP
.B \fB\-ddump\-cmm\-verbose\fP
Write output from main C\-\e\- pipeline passes to files
.TP
.B \fB\-ddump\-cmm\-verbose\-by\-proc\fP
Show output from main C\-\e\- pipeline passes (grouped by proc)
.TP
.B \fB\-ddump\-core\-stats\fP
Print a one\-line summary of the size of the Core program at the
end of the optimisation pipeline
.TP
.B \fB\-ddump\-cse\fP
Dump CSE output
.TP
.B \fB\-ddump\-deriv\fP
Dump deriving output
.TP
.B \fB\-ddump\-ds\fP
Dump desugarer output.
.TP
.B \fB\-ddump\-ec\-trace\fP
Trace exhaustiveness checker
.TP
.B \fB\-ddump\-file\-prefix=⟨str⟩\fP
Set the prefix of the filenames used for debugging output.
.TP
.B \fB\-ddump\-foreign\fP
Dump \fBforeign export\fP stubs
.TP
.B \fB\-ddump\-hpc\fP
An alias for \fB\-ddump\-ticked\fP\&.
.TP
.B \fB\-ddump\-if\-trace\fP
Trace interface files
.TP
.B \fB\-ddump\-inlinings\fP
Dump inlining info
.TP
.B \fB\-ddump\-json\fP
Dump error messages as JSON documents
.TP
.B \fB\-ddump\-llvm\fP
Dump LLVM intermediate code.
.TP
.B \fB\-ddump\-mod\-map\fP
Dump the state of the module mapping database.
.TP
.B \fB\-ddump\-occur\-anal\fP
Dump occurrence analysis output
.TP
.B \fB\-ddump\-opt\-cmm\fP
Dump the results of C\-\e\- to C\-\e\- optimising passes
.TP
.B \fB\-ddump\-parsed\fP
Dump parse tree
.TP
.B \fB\-ddump\-parsed\-ast\fP
Dump parser output as a syntax tree
.TP
.B \fB\-ddump\-prep\fP
Dump prepared core
.TP
.B \fB\-ddump\-rn\fP
Dump renamer output
.TP
.B \fB\-ddump\-rn\-ast\fP
Dump renamer output as a syntax tree
.TP
.B \fB\-ddump\-rn\-stats\fP
Renamer stats
.TP
.B \fB\-ddump\-rn\-trace\fP
Trace renamer
.TP
.B \fB\-ddump\-rtti\fP
Trace runtime type inference
.TP
.B \fB\-ddump\-rule\-firings\fP
Dump rule firing info
.TP
.B \fB\-ddump\-rule\-rewrites\fP
Dump detailed rule firing info
.TP
.B \fB\-ddump\-rules\fP
Dump rewrite rules
.TP
.B \fB\-ddump\-simpl\fP
Dump final simplifier output
.TP
.B \fB\-ddump\-simpl\-iterations\fP
Dump output from each simplifier iteration
.TP
.B \fB\-ddump\-simpl\-stats\fP
Dump simplifier stats
.TP
.B \fB\-ddump\-spec\fP
Dump specialiser output
.TP
.B \fB\-ddump\-splices\fP
Dump TH spliced expressions, and what they evaluate to
.TP
.B \fB\-ddump\-stg\fP
Show CoreToStg output
.TP
.B \fB\-ddump\-stg\-final\fP
Show output of last STG pass.
.TP
.B \fB\-ddump\-stg\-unarised\fP
Show unarised STG
.TP
.B \fB\-ddump\-str\-signatures\fP
Dump strictness signatures
.TP
.B \fB\-ddump\-stranal\fP
Dump strictness analyser output
.TP
.B \fB\-ddump\-tc\fP
Dump typechecker output
.TP
.B \fB\-ddump\-tc\-ast\fP
Dump typechecker output as a syntax tree
.TP
.B \fB\-ddump\-tc\-trace\fP
Trace typechecker
.TP
.B \fB\-ddump\-ticked\fP
Dump the code instrumented by HPC (hpc).
.TP
.B \fB\-ddump\-timings\fP
Dump per\-pass timing and allocation statistics
.TP
.B \fB\-ddump\-to\-file\fP
Dump to files instead of stdout
.TP
.B \fB\-ddump\-types\fP
Dump type signatures
.TP
.B \fB\-ddump\-worker\-wrapper\fP
Dump worker\-wrapper output
.TP
.B \fB\-dfaststring\-stats\fP
Show statistics for fast string usage when finished
.TP
.B \fB\-dhex\-word\-literals\fP
Print values of type \fIWord#\fP in hexadecimal.
.TP
.B \fB\-dinitial\-unique=⟨s⟩\fP
Start \fBUniqSupply\fP allocation from ⟨s⟩.
.TP
.B \fB\-dinline\-check=⟨str⟩\fP
Dump information about inlining decisions
.TP
.B \fB\-dno\-debug\-output\fP
Suppress unsolicited debugging output
.TP
.B \fB\-dno\-typeable\-binds\fP
Don\(aqt generate bindings for Typeable methods
.TP
.B \fB\-dppr\-case\-as\-let\fP
Print single alternative case expressions as strict lets.
.TP
.B \fB\-dppr\-cols=⟨n⟩\fP
Set the width of debugging output. For example \fB\-dppr\-cols200\fP
.TP
.B \fB\-dppr\-debug\fP
Turn on debug printing (more verbose)
.TP
.B \fB\-dppr\-user\-length\fP
Set the depth for printing expressions in error msgs
.TP
.B \fB\-drule\-check=⟨str⟩\fP
Dump information about potential rule application
.TP
.B \fB\-dshow\-passes\fP
Print out each pass name as it happens
.TP
.B \fB\-dstg\-lint\fP
STG pass sanity checking
.TP
.B \fB\-dsuppress\-all\fP
In dumps, suppress everything (except for uniques) that is
suppressible.
.TP
.B \fB\-dsuppress\-coercions\fP
Suppress the printing of coercions in Core dumps to make them
shorter
.TP
.B \fB\-dsuppress\-idinfo\fP
Suppress extended information about identifiers where they
are bound
.TP
.B \fB\-dsuppress\-module\-prefixes\fP
Suppress the printing of module qualification prefixes
.TP
.B \fB\-dsuppress\-stg\-free\-vars\fP
Suppress the printing of closure free variable lists in STG output
.TP
.B \fB\-dsuppress\-ticks\fP
Suppress "ticks" in the pretty\-printer output.
.TP
.B \fB\-dsuppress\-timestamps\fP
Suppress timestamps in dumps
.TP
.B \fB\-dsuppress\-type\-applications\fP
Suppress type applications
.TP
.B \fB\-dsuppress\-type\-signatures\fP
Suppress type signatures
.TP
.B \fB\-dsuppress\-unfoldings\fP
Suppress the printing of the stable unfolding of a variable at
its binding site
.TP
.B \fB\-dsuppress\-uniques\fP
Suppress the printing of uniques in debug output (easier to use
\fBdiff\fP)
.TP
.B \fB\-dsuppress\-var\-kinds\fP
Suppress the printing of variable kinds
.TP
.B \fB\-dth\-dec\-file\fP
Dump evaluated TH declarations into \fI*.th.hs\fP files
.TP
.B \fB\-dunique\-increment=⟨i⟩\fP
Set the increment for the generated \fBUnique\fP\(aqs to ⟨i⟩.
.TP
.B \fB\-dverbose\-core2core\fP
Show output from each core\-to\-core pass
.TP
.B \fB\-dverbose\-stg2stg\fP
Show output from each STG\-to\-STG pass
.TP
.B \fB\-falignment\-sanitisation\fP
Compile with alignment checks for all info table dereferences.
.TP
.B \fB\-fcatch\-bottoms\fP
Insert \fBerror\fP expressions after bottoming expressions; useful
when debugging the compiler.
.TP
.B \fB\-fllvm\-fill\-undef\-with\-garbage\fP
Intruct LLVM to fill dead STG registers with garbage
.TP
.B \fB\-fproc\-alignment\fP
Align functions at given boundary.
.TP
.B \fB\-g\fP
Produce DWARF debug information in compiled object files.
⟨n⟩ can be 0, 1, or 2, with higher numbers producing richer
output. If ⟨n⟩ is omitted, level 2 is assumed.
.UNINDENT
.SS C pre\-processor
.INDENT 0.0
.TP
.B \fB\-cpp\fP
Run the C pre\-processor on Haskell source files
.TP
.B \fB\-D⟨symbol⟩[=⟨value⟩]\fP
Define a symbol in the C pre\-processor
.TP
.B \fB\-I⟨dir⟩\fP
Add ⟨dir⟩ to the directory search list for \fB#include\fP files
.TP
.B \fB\-U⟨symbol⟩\fP
Undefine a symbol in the C pre\-processor
.UNINDENT
.SS Finding imports
.INDENT 0.0
.TP
.B \fB\-i\fP
Empty the import directory list
.TP
.B \fB\-i⟨dir⟩[:⟨dir⟩]*\fP
add ⟨dir⟩, ⟨dir2⟩, etc. to import path
.UNINDENT
.SS Interactive mode
.INDENT 0.0
.TP
.B \fB\-fbreak\-on\-error\fP
Break on uncaught exceptions and errors
.TP
.B \fB\-fbreak\-on\-exception\fP
Break on any exception thrown
.TP
.B \fB\-fghci\-hist\-size=⟨n⟩\fP
Set the number of entries GHCi keeps for \fB:history\fP\&.
See ghci\-debugger\&.
.TP
.B \fB\-fghci\-leak\-check\fP
(Debugging only) check for space leaks when loading
new modules in GHCi.
.TP
.B \fB\-flocal\-ghci\-history\fP
Use current directory for the GHCi command history
file \fB\&.ghci\-history\fP\&.
.TP
.B \fB\-fno\-it\fP
No longer set the special variable \fBit\fP\&.
.TP
.B \fB\-fprint\-bind\-result\fP
Turn on printing of binding results in GHCi
.TP
.B \fB\-fprint\-evld\-with\-show\fP
Instruct \fB:print\fP to use \fBShow\fP instances where possible.
.TP
.B \fB\-fshow\-loaded\-modules\fP
Show the names of modules that GHCi loaded after a
\fB:load\fP command.
.TP
.B \fB\-ghci\-script\fP
Read additional \fB\&.ghci\fP files
.TP
.B \fB\-ignore\-dot\-ghci\fP
Disable reading of \fB\&.ghci\fP files
.TP
.B \fB\-interactive\-print ⟨name⟩\fP
Select the function to use for printing evaluated
expressions in GHCi
.UNINDENT
.SS Interface files
.INDENT 0.0
.TP
.B \fB\-\-show\-iface ⟨file⟩\fP
See modes\&.
.TP
.B \fB\-ddump\-hi\fP
Dump the new interface to stdout
.TP
.B \fB\-ddump\-hi\-diffs\fP
Show the differences vs. the old interface
.TP
.B \fB\-ddump\-minimal\-imports\fP
Dump a minimal set of imports
.UNINDENT
.SS Keeping intermediate files
.INDENT 0.0
.TP
.B \fB\-keep\-hc\-file\fP
Retain intermediate \fB\&.hc\fP files.
.TP
.B \fB\-keep\-hi\-files\fP
Retain intermediate \fB\&.hi\fP files (the default).
.TP
.B \fB\-keep\-hscpp\-file\fP
Retain intermediate \fB\&.hscpp\fP files.
.TP
.B \fB\-keep\-llvm\-file\fP
Retain intermediate LLVM \fB\&.ll\fP files.
Implies \fB\-fllvm\fP\&.
.TP
.B \fB\-keep\-o\-files\fP
Retain intermediate \fB\&.o\fP files (the default).
.TP
.B \fB\-keep\-s\-file\fP
Retain intermediate \fB\&.s\fP files.
.TP
.B \fB\-keep\-tmp\-files\fP
Retain all intermediate temporary files.
.UNINDENT
.SS Language options
.INDENT 0.0
.TP
.B \fB\-fno\-safe\-haskell\fP
Disable Safe Haskell
.TP
.B \fB\-fsort\-by\-size\-hole\-fits\fP
Sort valid hole fits by size.
.TP
.B \fB\-fsort\-by\-subsumption\-hole\-fits\fP
Sort valid hole fits by subsumption.
.TP
.B \fB\-Winferred\-safe\-imports\fP
warn when an explicitly Safe Haskell module imports a Safe\-Inferred one
.TP
.B \fB\-Wmissing\-safe\-haskell\-mode\fP
warn when the Safe Haskell mode is not explicitly specified.
.TP
.B \fB\-XAllowAmbiguousTypes\fP
Allow the user to write ambiguous types, and
the type inference engine to infer them.
.TP
.B \fB\-XApplicativeDo\fP
Enable Applicative do\-notation desugaring
.TP
.B \fB\-XArrows\fP
Enable arrow notation extension
.TP
.B \fB\-XBangPatterns\fP
Enable bang patterns.
.TP
.B \fB\-XBinaryLiterals\fP
Enable support for binary literals.
.TP
.B \fB\-XBlockArguments\fP
Allow \fBdo\fP blocks and other constructs as function arguments.
.TP
.B \fB\-XCApiFFI\fP
Enable the CAPI calling convention.
.TP
.B \fB\-XConstrainedClassMethods\fP
Enable constrained class methods.
.TP
.B \fB\-XConstraintKinds\fP
Enable a kind of constraints.
.TP
.B \fB\-XCPP\fP
Enable the C preprocessor.
.TP
.B \fB\-XCUSKs\fP
Enable detection of complete user\-supplied kind signatures.
.TP
.B \fB\-XDataKinds\fP
Enable datatype promotion.
.TP
.B \fB\-XDatatypeContexts\fP
Allow contexts on \fBdata\fP types.
.TP
.B \fB\-XDefaultSignatures\fP
Enable default signatures.
.TP
.B \fB\-XDeriveAnyClass\fP
Enable deriving for any class.
.TP
.B \fB\-XDeriveDataTypeable\fP
Enable deriving for the \fBData\fP class.
Implied by (deprecated) \fBAutoDeriveTypeable\fP\&.
.TP
.B \fB\-XDeriveFoldable\fP
Enable deriving for the Foldable class.
Implied by \fBDeriveTraversable\fP\&.
.TP
.B \fB\-XDeriveFunctor\fP
Enable deriving for the Functor class.
Implied by \fBDeriveTraversable\fP\&.
.TP
.B \fB\-XDeriveGeneric\fP
Enable deriving for the Generic class.
.TP
.B \fB\-XDeriveLift\fP
Enable deriving for the Lift class
.TP
.B \fB\-XDeriveTraversable\fP
Enable deriving for the Traversable class.
Implies \fBDeriveFunctor\fP and \fBDeriveFoldable\fP\&.
.TP
.B \fB\-XDerivingStrategies\fP
Enables deriving strategies.
.TP
.B \fB\-XDerivingVia\fP
Enable deriving instances \fBvia\fP types of the same runtime
representation.
Implies \fBDerivingStrategies\fP\&.
.TP
.B \fB\-XDisambiguateRecordFields\fP
Enable record field disambiguation.
Implied by \fBRecordWildCards\fP\&.
.TP
.B \fB\-XDuplicateRecordFields\fP
Allow definition of record types with identically\-named fields.
.TP
.B \fB\-XEmptyCase\fP
Allow empty case alternatives.
.TP
.B \fB\-XEmptyDataDecls\fP
Allow definition of empty \fBdata\fP types.
.TP
.B \fB\-XEmptyDataDeriving\fP
Allow deriving instances of standard type classes for
empty data types.
.TP
.B \fB\-XExistentialQuantification\fP
Enable liberalised type synonyms.
.TP
.B \fB\-XExplicitForAll\fP
Enable explicit universal quantification.
Implied by \fBScopedTypeVariables\fP, \fBLiberalTypeSynonyms\fP,
\fBRankNTypes\fP and \fBExistentialQuantification\fP\&.
.TP
.B \fB\-XExplicitNamespaces\fP
Enable using the keyword \fBtype\fP to specify the namespace of
entries in imports and exports (explicit\-namespaces).
Implied by \fBTypeOperators\fP and \fBTypeFamilies\fP\&.
.TP
.B \fB\-XExtendedDefaultRules\fP
Use GHCi\(aqs extended default rules in a normal module.
.TP
.B \fB\-XFlexibleContexts\fP
Enable flexible contexts.
.TP
.B \fB\-XFlexibleInstances\fP
Enable flexible instances.
Implies \fBTypeSynonymInstances\fP\&.
.TP
.B \fB\-XForeignFunctionInterface\fP
Enable foreign function interface.
.TP
.B \fB\-XFunctionalDependencies\fP
Enable functional dependencies.
Implies \fBMultiParamTypeClasses\fP\&.
.TP
.B \fB\-XGADTs\fP
Enable generalised algebraic data types.
Implies \fBGADTSyntax\fP and \fBMonoLocalBinds\fP\&.
.TP
.B \fB\-XGADTSyntax\fP
Enable generalised algebraic data type syntax.
.TP
.B \fB\-XGeneralisedNewtypeDeriving\fP
Enable newtype deriving.
.TP
.B \fB\-XGeneralizedNewtypeDeriving\fP
Enable newtype deriving.
.TP
.B \fB\-XHaskell2010\fP
Use the Haskell 2010 language variant.
.TP
.B \fB\-XHaskell98\fP
Use the Haskell 2010 language variant.
.TP
.B \fB\-XHexFloatLiterals\fP
Enable support for hexadecimal floating point literals\&.
.TP
.B \fB\-XImplicitParams\fP
Enable Implicit Parameters.
.TP
.B \fB\-XImportQualifiedPost\fP
\fBImportQualifiedPost\fP allows the syntax \fBimport M qualified\fP
.TP
.B \fB\-XImpredicativeTypes\fP
Enable impredicative types.
Implies \fBRankNTypes\fP\&.
.TP
.B \fB\-XIncoherentInstances\fP
Enable incoherent instances.
Implies \fBOverlappingInstances\fP\&.
.TP
.B \fB\-XInstanceSigs\fP
Enable instance signatures.
.TP
.B \fB\-XInterruptibleFFI\fP
Enable interruptible FFI.
.TP
.B \fB\-XKindSignatures\fP
Enable kind signatures.
Implied by \fBTypeFamilies\fP and \fBPolyKinds\fP\&.
.TP
.B \fB\-XLambdaCase\fP
Enable lambda\-case expressions.
.TP
.B \fB\-XLiberalTypeSynonyms\fP
Enable liberalised type synonyms.
.TP
.B \fB\-XMagicHash\fP
Allow \fB#\fP as a postfix modifier on identifiers.
.TP
.B \fB\-XMonadComprehensions\fP
Enable monad comprehensions.
.TP
.B \fB\-XMonadFailDesugaring\fP
Enable monadfail desugaring.
.TP
.B \fB\-XMonoLocalBinds\fP
Enable do not generalise local bindings.
Implied by \fBTypeFamilies\fP and \fBGADTs\fP\&.
.TP
.B \fB\-XMultiParamTypeClasses\fP
Enable multi parameter type classes.
Implied by \fBFunctionalDependencies\fP\&.
.TP
.B \fB\-XMultiWayIf\fP
Enable multi\-way if\-expressions.
.TP
.B \fB\-XNamedFieldPuns\fP
Enable record puns.
.TP
.B \fB\-XNamedWildCards\fP
Enable named wildcards.
.TP
.B \fB\-XNegativeLiterals\fP
Enable support for negative literals.
.TP
.B \fB\-XNoImplicitPrelude\fP
Don\(aqt implicitly \fBimport Prelude\fP\&.
Implied by \fBRebindableSyntax\fP\&.
.TP
.B \fB\-XNoMonomorphismRestriction\fP
Disable the monomorphism restriction.
.TP
.B \fB\-XNondecreasingIndentation\fP
Allow nested contexts to be at the same indentation level as
its enclosing context.
.TP
.B \fB\-XNoPatternGuards\fP
Disable pattern guards.
Implied by \fBHaskell98\fP\&.
.TP
.B \fB\-XNoTraditionalRecordSyntax\fP
Disable support for traditional record syntax
(as supported by Haskell 98) \fBC {f = x}\fP
.TP
.B \fB\-XNPlusKPatterns\fP
Enable support for \fBn+k\fP patterns.
Implied by \fBHaskell98\fP\&.
.TP
.B \fB\-XNullaryTypeClasses\fP
Deprecated, does nothing. nullary (no parameter) type
classes are now enabled using \fBMultiParamTypeClasses\fP\&.
.TP
.B \fB\-XNumDecimals\fP
Enable support for \(aqfractional\(aq integer literals.
.TP
.B \fB\-XNumericUnderscores\fP
Enable support for numeric underscores\&.
.TP
.B \fB\-XOverlappingInstances\fP
Enable overlapping instances.
.TP
.B \fB\-XOverloadedLabels\fP
Enable overloaded labels.
.TP
.B \fB\-XOverloadedLists\fP
Enable overloaded lists.
.TP
.B \fB\-XOverloadedStrings\fP
Enable overloaded string literals.
.TP
.B \fB\-XPackageImports\fP
Enable package\-qualified imports.
.TP
.B \fB\-XParallelListComp\fP
Enable parallel list comprehensions.
.TP
.B \fB\-XPartialTypeSignatures\fP
Enable partial type signatures.
.TP
.B \fB\-XPatternSynonyms\fP
Enable pattern synonyms.
.TP
.B \fB\-XPolyKinds\fP
Enable kind polymorphism.
Implies \fBKindSignatures\fP\&.
.TP
.B \fB\-XPostfixOperators\fP
Enable postfix operators.
.TP
.B \fB\-XQuantifiedConstraints\fP
Allow \fBforall\fP quantifiers in constraints.
.TP
.B \fB\-XQuasiQuotes\fP
Enable quasiquotation.
.TP
.B \fB\-XRank2Types\fP
Enable rank\-2 types.
Synonym for \fBRankNTypes\fP\&.
.TP
.B \fB\-XRankNTypes\fP
Enable rank\-N types.
Implied by \fBImpredicativeTypes\fP\&.
.TP
.B \fB\-XRebindableSyntax\fP
Employ rebindable syntax.
Implies \fBNoImplicitPrelude\fP\&.
.TP
.B \fB\-XRecordWildCards\fP
Enable record wildcards.
Implies \fBDisambiguateRecordFields\fP\&.
.TP
.B \fB\-XRecursiveDo\fP
Enable recursive do (mdo) notation.
.TP
.B \fB\-XRoleAnnotations\fP
Enable role annotations.
.TP
.B \fB\-XSafe\fP
Enable the Safe Haskell Safe mode.
.TP
.B \fB\-XScopedTypeVariables\fP
Enable lexically\-scoped type variables.
.TP
.B \fB\-XStandaloneDeriving\fP
Enable standalone deriving.
.TP
.B \fB\-XStandaloneKindSignatures\fP
Allow the use of standalone kind signatures.
.TP
.B \fB\-XStarIsType\fP
Treat \fB*\fP as \fBData.Kind.Type\fP\&.
.TP
.B \fB\-XStaticPointers\fP
Enable static pointers.
.TP
.B \fB\-XStrict\fP
Make bindings in the current module strict by default.
.TP
.B \fB\-XStrictData\fP
Enable default strict datatype fields.
.TP
.B \fB\-XTemplateHaskell\fP
Enable Template Haskell.
.TP
.B \fB\-XTemplateHaskellQuotes\fP
Enable quotation subset of
Template Haskell\&.
.TP
.B \fB\-XTransformListComp\fP
Enable generalised list comprehensions.
.TP
.B \fB\-XTrustworthy\fP
Enable the Safe Haskell Trustworthy mode.
.TP
.B \fB\-XTupleSections\fP
Enable tuple sections.
.TP
.B \fB\-XTypeApplications\fP
Enable type application syntax in terms and types.
.TP
.B \fB\-XTypeFamilies\fP
Enable type families.
Implies \fBExplicitNamespaces\fP, \fBKindSignatures\fP,
and \fBMonoLocalBinds\fP\&.
.TP
.B \fB\-XTypeFamilyDependencies\fP
Enable injective type families.
Implies \fBTypeFamilies\fP\&.
.TP
.B \fB\-XTypeInType\fP
Deprecated. Enable kind polymorphism and datatype promotion.
.TP
.B \fB\-XTypeOperators\fP
Enable type operators.
Implies \fBExplicitNamespaces\fP\&.
.TP
.B \fB\-XTypeSynonymInstances\fP
Enable type synonyms in instance heads.
Implied by \fBFlexibleInstances\fP\&.
.TP
.B \fB\-XUnboxedSums\fP
Enable unboxed sums.
.TP
.B \fB\-XUnboxedTuples\fP
Enable the use of unboxed tuple syntax.
.TP
.B \fB\-XUndecidableInstances\fP
Enable undecidable instances.
.TP
.B \fB\-XUndecidableSuperClasses\fP
Allow all superclass constraints, including those that may
result in non\-termination of the typechecker.
.TP
.B \fB\-XUnicodeSyntax\fP
Enable unicode syntax.
.TP
.B \fB\-XUnliftedFFITypes\fP
Enable unlifted FFI types
.TP
.B \fB\-XUnliftedNewtypes\fP
Enable unlifted newtypes.
.TP
.B \fB\-XUnsafe\fP
Enable Safe Haskell Unsafe mode.
.TP
.B \fB\-XViewPatterns\fP
Enable view patterns.
.UNINDENT
.SS Linking options
.INDENT 0.0
.TP
.B \fB\-c\fP
Stop after generating object (\fB\&.o\fP) file
.TP
.B \fB\-debug\fP
Use the debugging runtime
.TP
.B \fB\-dylib\-install\-name ⟨path⟩\fP
Set the install name (via \fB\-install_name\fP passed to Apple\(aqs
linker), specifying the full install path of the library file.
Any libraries or executables that link with it later will pick
up that path as their runtime search location for it.
(Darwin/OS X only)
.TP
.B \fB\-dynamic\fP
Build dynamically\-linked object files and executables
.TP
.B \fB\-dynload\fP
Selects one of a number of modes for finding shared libraries at runtime.
.TP
.B \fB\-eventlog\fP
Enable runtime event tracing
.TP
.B \fB\-fno\-embed\-manifest\fP
Do not embed the manifest in the executable (Windows only)
.TP
.B \fB\-fno\-gen\-manifest\fP
Do not generate a manifest file (Windows only)
.TP
.B \fB\-fno\-shared\-implib\fP
Don\(aqt generate an import library for a DLL (Windows only)
.TP
.B \fB\-framework ⟨name⟩\fP
On Darwin/OS X/iOS only, link in the framework ⟨name⟩. This
option corresponds to the \fB\-framework\fP option for Apple\(aqs Linker.
.TP
.B \fB\-framework\-path ⟨dir⟩\fP
On Darwin/OS X/iOS only, add ⟨dir⟩ to the list of directories
searched for frameworks. This option corresponds to the \fB\-F\fP
option for Apple\(aqs Linker.
.TP
.B \fB\-fwhole\-archive\-hs\-libs\fP
When linking a binary executable, this inserts the flag
\fB\-Wl,\-\-whole\-archive\fP before any \fB\-l\fP flags for Haskell
libraries, and \fB\-Wl,\-\-no\-whole\-archive\fP afterwards
.TP
.B \fB\-keep\-cafs\fP
Do not garbage\-collect CAFs (top\-level expressions) at runtime
.TP
.B \fB\-L ⟨dir⟩\fP
Add ⟨dir⟩ to the list of directories searched for libraries
.TP
.B \fB\-l ⟨lib⟩\fP
Link in library ⟨lib⟩
.TP
.B \fB\-main\-is ⟨thing⟩\fP
Set main module and function
.TP
.B \fB\-no\-hs\-main\fP
Don\(aqt assume this program contains \fBmain\fP
.TP
.B \fB\-no\-rtsopts\-suggestions\fP
Don\(aqt print RTS suggestions about linking with
\fB\-rtsopts[=⟨none|some|all|ignore|ignoreAll⟩]\fP\&.
.TP
.B \fB\-package ⟨name⟩\fP
Expose package ⟨pkg⟩
.TP
.B \fB\-pie\fP
Instruct the linker to produce a position\-independent executable.
.TP
.B \fB\-rdynamic\fP
This instructs the linker to add all symbols, not only used
ones, to the dynamic symbol table. Currently Linux and
Windows/MinGW32 only. This is equivalent to using
\fB\-optl \-rdynamic\fP on Linux, and \fB\-optl \-export\-all\-symbols\fP
on Windows.
.TP
.B \fB\-rtsopts[=⟨none|some|all|ignore|ignoreAll⟩]\fP
Control whether the RTS behaviour can be tweaked via command\-line
flags and the \fBGHCRTS\fP environment variable. Using \fBnone\fP
means no RTS flags can be given; \fBsome\fP means only a minimum
of safe options can be given (the default); \fBall\fP (or no
argument at all) means that all RTS flags are permitted; \fBignore\fP
means RTS flags can be given, but are treated as regular arguments and
passed to the Haskell program as arguments; \fBignoreAll\fP is the same as
\fBignore\fP, but \fBGHCRTS\fP is also ignored. \fB\-rtsopts\fP does not
affect \fB\-with\-rtsopts\fP behavior; flags passed via \fB\-with\-rtsopts\fP
are used regardless of \fB\-rtsopts\fP\&.
.TP
.B \fB\-shared\fP
Generate a shared library (as opposed to an executable)
.TP
.B \fB\-split\-sections\fP
Split sections for link\-time dead\-code stripping
.TP
.B \fB\-static\fP
Use static Haskell libraries
.TP
.B \fB\-staticlib\fP
Generate a standalone static library (as opposed to an
executable). This is useful when cross compiling. The
library together with all its dependencies ends up in in a
single static library that can be linked against.
.TP
.B \fB\-threaded\fP
Use the threaded runtime
.TP
.B \fB\-with\-rtsopts=⟨opts⟩\fP
Set the default RTS options to ⟨opts⟩.
.UNINDENT
.SS Miscellaneous options
.INDENT 0.0
.TP
.B \fB\-fexternal\-interpreter\fP
Run interpreted code in a separate process
.TP
.B \fB\-fglasgow\-exts\fP
Deprecated. Enable most language extensions;
see options\-language for exactly which ones.
.TP
.B \fB\-ghcversion\-file ⟨path to ghcversion.h⟩\fP
(GHC as a C compiler only) Use this \fBghcversion.h\fP file
.TP
.B \fB\-H ⟨size⟩\fP
Set the minimum size of the heap to ⟨size⟩
.TP
.B \fB\-j[⟨n⟩]\fP
When compiling with \fB\-\-make\fP, compile ⟨n⟩ modules
in parallel.
.UNINDENT
.SS Modes of operation
.INDENT 0.0
.TP
.B \fB\-\-frontend ⟨module⟩\fP
run GHC with the given frontend plugin; see
frontend_plugins for details.
.TP
.B \fB\-\-help\fP
Display help
.TP
.B \fB\-\-info\fP
display information about the compiler
.TP
.B \fB\-\-interactive\fP
Interactive mode \- normally used by just running \fBghci\fP;
see ghci for details.
.TP
.B \fB\-\-make\fP
Build a multi\-module Haskell program, automatically figuring out
dependencies. Likely to be much easier, and faster, than using
\fBmake\fP; see make\-mode for details.
.TP
.B \fB\-\-mk\-dll\fP
DLL\-creation mode (Windows only)
.TP
.B \fB\-\-numeric\-version\fP
display GHC version (numeric only)
.TP
.B \fB\-\-print\-libdir\fP
display GHC library directory
.TP
.B \fB\-\-show\-iface ⟨file⟩\fP
display the contents of an interface file.
.TP
.B \fB\-\-show\-options\fP
display the supported command line options
.TP
.B \fB\-\-supported\-extensions\fP
display the supported language extensions
.TP
.B \fB\-\-version\fP
display GHC version
.TP
.B \fB\-e ⟨expr⟩\fP
Evaluate \fBexpr\fP; see eval\-mode for details.
.TP
.B \fB\-M\fP
generate dependency information suitable for use in a
\fBMakefile\fP; see makefile\-dependencies for details.
.UNINDENT
.SS Individual optimizations
.INDENT 0.0
.TP
.B \fB\-fasm\-shortcutting\fP
Enable shortcutting on assembly. Implied by \fB\-O2\fP\&.
.TP
.B \fB\-fbinary\-blob\-threshold=⟨n⟩\fP
\fIdefault: 500K.\fP Tweak assembly generator for binary blobs.
.TP
.B \fB\-fblock\-layout\-cfg\fP
Use the new cfg based block layout algorithm.
.TP
.B \fB\-fblock\-layout\-weightless\fP
Ignore cfg weights for code layout.
.TP
.B \fB\-fblock\-layout\-weights\fP
Sets edge weights used by the new code layout algorithm.
.TP
.B \fB\-fcall\-arity\fP
Enable call\-arity optimisation. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcase\-folding\fP
Enable constant folding in case expressions. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcase\-merge\fP
Enable case\-merging. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcmm\-elim\-common\-blocks\fP
Enable Cmm common block elimination. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcmm\-sink\fP
Enable Cmm sinking. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcpr\-anal\fP
Turn on CPR analysis in the demand analyser. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fcross\-module\-specialise\fP
Turn on specialisation of overloaded functions imported from
other modules.
.TP
.B \fB\-fcse\fP
Enable common sub\-expression elimination. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fdicts\-cheap\fP
Make dictionary\-valued expressions seem cheap to the optimiser.
.TP
.B \fB\-fdicts\-strict\fP
Make dictionaries strict
.TP
.B \fB\-fdmd\-tx\-dict\-sel\fP
Use a special demand transformer for dictionary selectors.
Always enabled by default.
.TP
.B \fB\-fdo\-eta\-reduction\fP
Enable eta\-reduction. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fdo\-lambda\-eta\-expansion\fP
Enable lambda eta\-expansion. Always enabled by default.
.TP
.B \fB\-feager\-blackholing\fP
Turn on eager blackholing
.TP
.B \fB\-fenable\-rewrite\-rules\fP
Switch on all rewrite rules (including rules generated by
automatic specialisation of overloaded functions). Implied by
\fB\-O\fP\&.
.TP
.B \fB\-fexcess\-precision\fP
Enable excess intermediate precision
.TP
.B \fB\-fexitification\fP
Enables exitification optimisation. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fexpose\-all\-unfoldings\fP
Expose all unfoldings, even for very large or recursive functions.
.TP
.B \fB\-ffloat\-in\fP
Turn on the float\-in transformation. Implied by \fB\-O\fP\&.
.TP
.B \fB\-ffull\-laziness\fP
Turn on full laziness (floating bindings outwards).
Implied by \fB\-O\fP\&.
.TP
.B \fB\-ffun\-to\-thunk\fP
Allow worker\-wrapper to convert a function closure into a thunk
if the function does not use any of its arguments. Off by default.
.TP
.B \fB\-fignore\-asserts\fP
Ignore assertions in the source. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fignore\-interface\-pragmas\fP
Ignore pragmas in interface files. Implied by \fB\-O0\fP only.
.TP
.B \fB\-flate\-dmd\-anal\fP
Run demand analysis again, at the end of the
simplification pipeline
.TP
.B \fB\-flate\-specialise\fP
Run a late specialisation pass
.TP
.B \fB\-fliberate\-case\fP
Turn on the liberate\-case transformation. Implied by \fB\-O2\fP\&.
.TP
.B \fB\-fliberate\-case\-threshold=⟨n⟩\fP
\fIdefault: 2000.\fP Set the size threshold for the liberate\-case
transformation to ⟨n⟩
.TP
.B \fB\-fllvm\-pass\-vectors\-in\-regs\fP
Pass vector value in vector registers for function calls
.TP
.B \fB\-floopification\fP
Turn saturated self\-recursive tail\-calls into local jumps in the
generated assembly. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fmax\-inline\-alloc\-size=⟨n⟩\fP
\fIdefault: 128.\fP Set the maximum size of inline array allocations
to ⟨n⟩ bytes (default: 128).
.TP
.B \fB\-fmax\-inline\-memcpy\-insns=⟨n⟩\fP
\fIdefault: 32.\fP Inline \fBmemcpy\fP calls if they would generate no
more than ⟨n⟩ pseudo instructions.
.TP
.B \fB\-fmax\-inline\-memset\-insns=⟨n⟩\fP
\fIdefault: 32.\fP Inline \fBmemset\fP calls if they would generate no
more than ⟨n⟩ pseudo instructions
.TP
.B \fB\-fmax\-simplifier\-iterations=⟨n⟩\fP
\fIdefault: 4.\fP Set the max iterations for the simplifier.
.TP
.B \fB\-fmax\-uncovered\-patterns=⟨n⟩\fP
\fIdefault: 4.\fP Set the maximum number of patterns to display in
warnings about non\-exhaustive ones.
.TP
.B \fB\-fmax\-worker\-args=⟨n⟩\fP
\fIdefault: 10.\fP If a worker has that many arguments, none will
be unpacked anymore.
.TP
.B \fB\-fno\-opt\-coercion\fP
Turn off the coercion optimiser
.TP
.B \fB\-fno\-pre\-inlining\fP
Turn off pre\-inlining
.TP
.B \fB\-fno\-state\-hack\fP
Turn off the state hackwhereby any lambda with a real\-world
state token as argument is considered to be single\-entry. Hence
OK to inline things inside it.
.TP
.B \fB\-fomit\-interface\-pragmas\fP
Don\(aqt generate interface pragmas. Implied by \fB\-O0\fP only.
.TP
.B \fB\-fomit\-yields\fP
Omit heap checks when no allocation is being performed.
.TP
.B \fB\-foptimal\-applicative\-do\fP
Use a slower but better algorithm for ApplicativeDo
.TP
.B \fB\-fpedantic\-bottoms\fP
Make GHC be more precise about its treatment of bottom (but see
also \fB\-fno\-state\-hack\fP). In particular, GHC will not
eta\-expand through a case expression.
.TP
.B \fB\-fregs\-graph\fP
Use the graph colouring register allocator for register
allocation in the native code generator. Implied by \fB\-O2\fP\&.
.TP
.B \fB\-fregs\-iterative\fP
Use the iterative coalescing graph colouring register allocator
in the native code generator.
.TP
.B \fB\-fsimpl\-tick\-factor=⟨n⟩\fP
\fIdefault: 100.\fP Set the percentage factor for simplifier ticks.
.TP
.B \fB\-fsimplifier\-phases=⟨n⟩\fP
\fIdefault: 2.\fP Set the number of phases for the simplifier.
Ignored with \fB\-O0\fP\&.
.TP
.B \fB\-fsolve\-constant\-dicts\fP
When solving constraints, try to eagerly solve
super classes using available dictionaries.
.TP
.B \fB\-fspec\-constr\fP
Turn on the SpecConstr transformation. Implied by \fB\-O2\fP\&.
.TP
.B \fB\-fspec\-constr\-count=⟨n⟩\fP
default: 3.* Set to ⟨n⟩ the maximum number of specialisations that
will be created for any one function by the SpecConstr
transformation.
.TP
.B \fB\-fspec\-constr\-keen\fP
Specialize a call with an explicit constructor argument,
even if the argument is not scrutinised in the body of the function
.TP
.B \fB\-fspec\-constr\-threshold=⟨n⟩\fP
\fIdefault: 2000.\fP Set the size threshold for the SpecConstr
transformation to ⟨n⟩.
.TP
.B \fB\-fspecialise\fP
Turn on specialisation of overloaded functions. Implied by \fB\-O\fP\&.
.TP
.B \fB\-fspecialise\-aggressively\fP
Turn on specialisation of overloaded functions regardless of
size, if unfolding is available
.TP
.B \fB\-fstatic\-argument\-transformation\fP
Turn on the static argument transformation.
.TP
.B \fB\-fstg\-cse\fP
Enable common sub\-expression elimination on the STG
intermediate language
.TP
.B \fB\-fstg\-lift\-lams\fP
Enable late lambda lifting on the STG intermediate
language. Implied by \fB\-O2\fP\&.
.TP
.B \fB\-fstg\-lift\-lams\-known\fP
Allow turning known into unknown calls while performing
late lambda lifting.
.TP
.B \fB\-fstg\-lift\-lams\-non\-rec\-args\fP
Create top\-level non\-recursive functions with at most <n>
parameters while performing late lambda lifting.
.TP
.B \fB\-fstg\-lift\-lams\-rec\-args\fP
Create top\-level recursive functions with at most <n>
parameters while performing late lambda lifting.
.TP
.B \fB\-fstrictness\fP
Turn on strictness analysis.
Implied by \fB\-O\fP\&. Implies \fB\-fworker\-wrapper\fP
.TP
.B \fB\-fstrictness\-before=⟨n⟩\fP
Run an additional strictness analysis before simplifier phase ⟨n⟩
.TP
.B \fB\-funbox\-small\-strict\-fields\fP
Flatten strict constructor fields with a pointer\-sized
representation. Implied by \fB\-O\fP\&.
.TP
.B \fB\-funbox\-strict\-fields\fP
Flatten strict constructor fields
.TP
.B \fB\-funfolding\-creation\-threshold=⟨n⟩\fP
\fIdefault: 750.\fP Tweak unfolding settings.
.TP
.B \fB\-funfolding\-dict\-discount=⟨n⟩\fP
\fIdefault: 30.\fP Tweak unfolding settings.
.TP
.B \fB\-funfolding\-fun\-discount=⟨n⟩\fP
\fIdefault: 60.\fP Tweak unfolding settings.
.TP
.B \fB\-funfolding\-keeness\-factor=⟨n⟩\fP
\fIdefault: 1.5.\fP Tweak unfolding settings.
.TP
.B \fB\-funfolding\-use\-threshold=⟨n⟩\fP
\fIdefault: 60.\fP Tweak unfolding settings.
.TP
.B \fB\-fworker\-wrapper\fP
Enable the worker\-wrapper transformation.
.UNINDENT
.SS Optimization levels
.INDENT 0.0
.TP
.B \fB\-O\fP
Enable level 1 optimisations
.TP
.B \fB\-O0\fP
Disable optimisations (default)
.TP
.B \fB\-O2\fP
Enable level 2 optimisations
.TP
.B \fB\-O⟨n⟩\fP
Any \-On where n > 2 is the same as \-O2.
.UNINDENT
.SS Package options
.INDENT 0.0
.TP
.B \fB\-clear\-package\-db\fP
Clear the package db stack.
.TP
.B \fB\-distrust ⟨pkg⟩\fP
Expose package ⟨pkg⟩ and set it to be distrusted. See
safe\-haskell\&.
.TP
.B \fB\-distrust\-all\-packages\fP
Distrust all packages by default. See safe\-haskell\&.
.TP
.B \fB\-fpackage\-trust\fP
Enable Safe Haskell trusted package
requirement for trustworthy modules.
.TP
.B \fB\-global\-package\-db\fP
Add the global package db to the stack.
.TP
.B \fB\-hide\-all\-packages\fP
Hide all packages by default
.TP
.B \fB\-hide\-package ⟨pkg⟩\fP
Hide package ⟨pkg⟩
.TP
.B \fB\-ignore\-package ⟨pkg⟩\fP
Ignore package ⟨pkg⟩
.TP
.B \fB\-no\-auto\-link\-packages\fP
Don\(aqt automatically link in the base and rts packages.
.TP
.B \fB\-no\-global\-package\-db\fP
Remove the global package db from the stack.
.TP
.B \fB\-no\-user\-package\-db\fP
Remove the user\(aqs package db from the stack.
.TP
.B \fB\-package ⟨pkg⟩\fP
Expose package ⟨pkg⟩
.TP
.B \fB\-package\-db ⟨file⟩\fP
Add ⟨file⟩ to the package db stack.
.TP
.B \fB\-package\-env ⟨file⟩|⟨name⟩\fP
Use the specified package environment.
.TP
.B \fB\-package\-id ⟨unit\-id⟩\fP
Expose package by id ⟨unit\-id⟩
.TP
.B \fB\-this\-unit\-id ⟨unit\-id⟩\fP
Compile to be part of unit (i.e. package)
⟨unit\-id⟩
.TP
.B \fB\-trust ⟨pkg⟩\fP
Expose package ⟨pkg⟩ and set it to be trusted. See
safe\-haskell\&.
.TP
.B \fB\-user\-package\-db\fP
Add the user\(aqs package db to the stack.
.UNINDENT
.SS Phases of compilation
.INDENT 0.0
.TP
.B \fB\-C\fP
Stop after generating C (\fB\&.hc\fP file)
.TP
.B \fB\-c\fP
Stop after generating object (\fB\&.o\fP) file
.TP
.B \fB\-E\fP
Stop after preprocessing (\fB\&.hspp\fP file)
.TP
.B \fB\-F\fP
Enable the use of a pre\-processor
(set with \fB\-pgmF ⟨cmd⟩\fP)
.TP
.B \fB\-S\fP
Stop after generating assembly (\fB\&.s\fP file)
.TP
.B \fB\-x ⟨suffix⟩\fP
Override default behaviour for source files
.UNINDENT
.SS Overriding external programs
.INDENT 0.0
.TP
.B \fB\-pgma ⟨cmd⟩\fP
Use ⟨cmd⟩ as the assembler
.TP
.B \fB\-pgmc ⟨cmd⟩\fP
Use ⟨cmd⟩ as the C compiler
.TP
.B \fB\-pgmdll ⟨cmd⟩\fP
Use ⟨cmd⟩ as the DLL generator
.TP
.B \fB\-pgmF ⟨cmd⟩\fP
Use ⟨cmd⟩ as the pre\-processor (with \fB\-F\fP only)
.TP
.B \fB\-pgmi ⟨cmd⟩\fP
Use ⟨cmd⟩ as the external interpreter command.
.TP
.B \fB\-pgminstall_name_tool ⟨cmd⟩\fP
Use ⟨cmd⟩ as the program to inject \fBrunpath\fP into mach\-o dylibs on macOS
.TP
.B \fB\-pgmL ⟨cmd⟩\fP
Use ⟨cmd⟩ as the literate pre\-processor
.TP
.B \fB\-pgml ⟨cmd⟩\fP
Use ⟨cmd⟩ as the linker
.TP
.B \fB\-pgmlc ⟨cmd⟩\fP
Use ⟨cmd⟩ as the LLVM compiler
.TP
.B \fB\-pgmlibtool ⟨cmd⟩\fP
Use ⟨cmd⟩ as the command for libtool (with \fB\-staticlib\fP only).
.TP
.B \fB\-pgmlm ⟨cmd⟩\fP
Use ⟨cmd⟩ as the linker when merging object files
.TP
.B \fB\-pgmlo ⟨cmd⟩\fP
Use ⟨cmd⟩ as the LLVM optimiser
.TP
.B \fB\-pgmotool ⟨cmd⟩\fP
Use ⟨cmd⟩ as the program to inspect mach\-o dylibs on macOS
.TP
.B \fB\-pgmP ⟨cmd⟩\fP
Use ⟨cmd⟩ as the C pre\-processor (with \fB\-cpp\fP only)
.TP
.B \fB\-pgms ⟨cmd⟩\fP
Use ⟨cmd⟩ as the splitter
.TP
.B \fB\-pgmwindres ⟨cmd⟩\fP
Use ⟨cmd⟩ as the program for embedding manifests on Windows.
.UNINDENT
.SS Phase\-specific options
.INDENT 0.0
.TP
.B \fB\-opta ⟨option⟩\fP
pass ⟨option⟩ to the assembler
.TP
.B \fB\-optc ⟨option⟩\fP
pass ⟨option⟩ to the C compiler
.TP
.B \fB\-optcxx ⟨option⟩\fP
pass ⟨option⟩ to the C++ compiler
.TP
.B \fB\-optdll ⟨option⟩\fP
pass ⟨option⟩ to the DLL generator
.TP
.B \fB\-optF ⟨option⟩\fP
pass ⟨option⟩ to the custom pre\-processor
.TP
.B \fB\-opti ⟨option⟩\fP
pass ⟨option⟩ to the interpreter sub\-process.
.TP
.B \fB\-optL ⟨option⟩\fP
pass ⟨option⟩ to the literate pre\-processor
.TP
.B \fB\-optl ⟨option⟩\fP
pass ⟨option⟩ to the linker
.TP
.B \fB\-optlc ⟨option⟩\fP
pass ⟨option⟩ to the LLVM compiler
.TP
.B \fB\-optlm ⟨option⟩\fP
pass ⟨option⟩ to the linker when merging object files.
.TP
.B \fB\-optlo ⟨option⟩\fP
pass ⟨option⟩ to the LLVM optimiser
.TP
.B \fB\-optP ⟨option⟩\fP
pass ⟨option⟩ to cpp (with \fB\-cpp\fP only)
.TP
.B \fB\-optwindres ⟨option⟩\fP
pass ⟨option⟩ to \fBwindres\fP\&.
.TP
.B \fB\-pgmc\-supports\-no\-pie\fP
Indicate that the C compiler supports \fB\-no\-pie\fP
.UNINDENT
.SS Platform\-specific options
.INDENT 0.0
.TP
.B \fB\-mbmi2\fP
(x86 only) Use BMI2 for bit manipulation operations
.TP
.B \fB\-msse2\fP
(x86 only) Use SSE2 for floating\-point operations
.TP
.B \fB\-msse4.2\fP
(x86 only) Use SSE4.2 for floating\-point operations
.UNINDENT
.SS Compiler plugins
.INDENT 0.0
.TP
.B \fB\-fclear\-plugins\fP
Clear the list of active plugins
.TP
.B \fB\-fplugin\-opt=⟨module⟩:⟨args⟩\fP
Give arguments to a plugin module; module must be specified with
\fB\-fplugin=⟨module⟩\fP
.TP
.B \fB\-fplugin\-trustworthy\fP
Trust the used plugins and no longer mark the compiled module
as unsafe
.TP
.B \fB\-fplugin=⟨module⟩\fP
Load a plugin exported by a given module
.TP
.B \fB\-hide\-all\-plugin\-packages\fP
Hide all packages for plugins by default
.TP
.B \fB\-plugin\-package ⟨pkg⟩\fP
Expose ⟨pkg⟩ for plugins
.TP
.B \fB\-plugin\-package\-id ⟨pkg\-id⟩\fP
Expose ⟨pkg\-id⟩ for plugins
.UNINDENT
.SS Profiling
.INDENT 0.0
.TP
.B \fB\-fno\-prof\-auto\fP
Disables any previous \fB\-fprof\-auto\fP,
\fB\-fprof\-auto\-top\fP, or \fB\-fprof\-auto\-exported\fP options.
.TP
.B \fB\-fno\-prof\-cafs\fP
Disables any previous \fB\-fprof\-cafs\fP option.
.TP
.B \fB\-fno\-prof\-count\-entries\fP
Do not collect entry counts
.TP
.B \fB\-fprof\-auto\fP
Auto\-add \fBSCC\fP\e s to all bindings not marked INLINE
.TP
.B \fB\-fprof\-auto\-calls\fP
Auto\-add \fBSCC\fP\e s to all call sites
.TP
.B \fB\-fprof\-auto\-exported\fP
Auto\-add \fBSCC\fP\e s to all exported bindings not marked INLINE
.TP
.B \fB\-fprof\-auto\-top\fP
Auto\-add \fBSCC\fP\e s to all top\-level bindings not marked INLINE
.TP
.B \fB\-fprof\-cafs\fP
Auto\-add \fBSCC\fP\e s to all CAFs
.TP
.B \fB\-prof\fP
Turn on profiling
.TP
.B \fB\-ticky\fP
Turn on ticky\-ticky profiling
.UNINDENT
.SS Program coverage
.INDENT 0.0
.TP
.B \fB\-fhpc\fP
Turn on Haskell program coverage instrumentation
.UNINDENT
.SS Recompilation checking
.INDENT 0.0
.TP
.B \fB\-fforce\-recomp\fP
Turn off recompilation checking. This is implied by any
\fB\-ddump\-X\fP option when compiling a single file
(i.e. when using \fB\-c\fP).
.TP
.B \fB\-fignore\-hpc\-changes\fP
Do not recompile modules just to match changes to
HPC flags. This is especially useful for avoiding recompilation
when using GHCi, and is enabled by default for GHCi.
.TP
.B \fB\-fignore\-optim\-changes\fP
Do not recompile modules just to match changes to
optimisation flags. This is especially useful for avoiding
recompilation when using GHCi, and is enabled by default for
GHCi.
.UNINDENT
.SS Redirecting output
.INDENT 0.0
.TP
.B \fB\-\-exclude\-module=⟨file⟩\fP
Regard \fB⟨file⟩\fP as "stable"; i.e., exclude it from having
dependencies on it.
.TP
.B \fB\-ddump\-mod\-cycles\fP
Dump module cycles
.TP
.B \fB\-dep\-makefile ⟨file⟩\fP
Use ⟨file⟩ as the makefile
.TP
.B \fB\-dep\-suffix ⟨suffix⟩\fP
Make dependencies that declare that files with suffix
\fB\&.⟨suf⟩⟨osuf⟩\fP depend on interface files with suffix \fB\&.⟨suf⟩hi\fP
.TP
.B \fB\-dumpdir ⟨dir⟩\fP
redirect dump files
.TP
.B \fB\-hcsuf ⟨suffix⟩\fP
set the suffix to use for intermediate C files
.TP
.B \fB\-hidir ⟨dir⟩\fP
set directory for interface files
.TP
.B \fB\-hiedir ⟨dir⟩\fP
set directory for extended interface files
.TP
.B \fB\-hiesuf ⟨suffix⟩\fP
set the suffix to use for extended interface files
.TP
.B \fB\-hisuf ⟨suffix⟩\fP
set the suffix to use for interface files
.TP
.B \fB\-include\-cpp\-deps\fP
Include preprocessor dependencies
.TP
.B \fB\-include\-pkg\-deps\fP
Regard modules imported from packages as unstable
.TP
.B \fB\-o ⟨file⟩\fP
set output filename
.TP
.B \fB\-odir ⟨dir⟩\fP
set directory for object files
.TP
.B \fB\-ohi ⟨file⟩\fP
set the filename in which to put the interface
.TP
.B \fB\-osuf ⟨suffix⟩\fP
set the output file suffix
.TP
.B \fB\-outputdir ⟨dir⟩\fP
set output directory
.TP
.B \fB\-stubdir ⟨dir⟩\fP
redirect FFI stub files
.UNINDENT
.SS Temporary files
.INDENT 0.0
.TP
.B \fB\-tmpdir ⟨dir⟩\fP
set the directory for temporary files
.UNINDENT
.SS Verbosity options
.INDENT 0.0
.TP
.B \fB\-fabstract\-refinement\-hole\-fits\fP
\fIdefault: off.\fP Toggles whether refinements where one or more
of the holes are abstract are reported.
.TP
.B \fB\-fdefer\-diagnostics\fP
Defer and group diagnostic messages by severity
.TP
.B \fB\-fdiagnostics\-color=⟨always|auto|never⟩\fP
Use colors in error messages
.TP
.B \fB\-fdiagnostics\-show\-caret\fP
Whether to show snippets of original source code
.TP
.B \fB\-ferror\-spans\fP
Output full span in error messages
.TP
.B \fB\-fhide\-source\-paths\fP
hide module source and object paths
.TP
.B \fB\-fkeep\-going\fP
Continue compilation as far as possible on errors
.TP
.B \fB\-fmax\-refinement\-hole\-fits=⟨n⟩\fP
\fIdefault: 6.\fP Set the maximum number of refinement hole fits
for typed holes to display in type error messages.
.TP
.B \fB\-fmax\-relevant\-binds=⟨n⟩\fP
\fIdefault: 6.\fP Set the maximum number of bindings to display in
type error messages.
.TP
.B \fB\-fmax\-valid\-hole\-fits=⟨n⟩\fP
\fIdefault: 6.\fP Set the maximum number of valid hole fits for
typed holes to display in type error messages.
.TP
.B \fB\-fno\-show\-valid\-hole\-fits\fP
Disables showing a list of valid hole fits for typed holes
in type error messages.
.TP
.B \fB\-fno\-sort\-valid\-hole\-fits\fP
Disables the sorting of the list of valid hole fits for typed holes
in type error messages.
.TP
.B \fB\-fprint\-axiom\-incomps\fP
Display equation incompatibilities in closed type families
.TP
.B \fB\-fprint\-equality\-relations\fP
Distinguish between equality relations when printing
.TP
.B \fB\-fprint\-expanded\-synonyms\fP
In type errors, also print type\-synonym\-expanded types.
.TP
.B \fB\-fprint\-explicit\-coercions\fP
Print coercions in types
.TP
.B \fB\-fprint\-explicit\-foralls\fP
Print explicit \fBforall\fP quantification in types.
See also \fBExplicitForAll\fP
.TP
.B \fB\-fprint\-explicit\-kinds\fP
Print explicit kind foralls and kind arguments in types.
See also \fBKindSignatures\fP
.TP
.B \fB\-fprint\-explicit\-runtime\-reps\fP
Print \fBRuntimeRep\fP variables in types which are
runtime\-representation polymorphic.
.TP
.B \fB\-fprint\-potential\-instances\fP
display all available instances in type error messages
.TP
.B \fB\-fprint\-typechecker\-elaboration\fP
Print extra information from typechecker.
.TP
.B \fB\-fprint\-unicode\-syntax\fP
Use unicode syntax when printing expressions, types and kinds.
See also \fBUnicodeSyntax\fP
.TP
.B \fB\-frefinement\-level\-hole\-fits=⟨n⟩\fP
\fIdefault: off.\fP Sets the level of refinement of the
refinement hole fits, where level \fBn\fP means that hole fits
of up to \fBn\fP holes will be considered.
.TP
.B \fB\-freverse\-errors\fP
Output errors in reverse order
.TP
.B \fB\-fshow\-docs\-of\-hole\-fits\fP
Toggles whether to show the documentation of the valid
hole fits in the output.
.TP
.B \fB\-fshow\-hole\-constraints\fP
Show constraints when reporting typed holes.
.TP
.B \fB\-fshow\-hole\-matches\-of\-hole\-fits\fP
Toggles whether to show the type of the additional holes
in refinement hole fits.
.TP
.B \fB\-fshow\-provenance\-of\-hole\-fits\fP
Toggles whether to show the provenance of the valid hole fits
in the output.
.TP
.B \fB\-fshow\-type\-app\-of\-hole\-fits\fP
Toggles whether to show the type application of the valid
hole fits in the output.
.TP
.B \fB\-fshow\-type\-app\-vars\-of\-hole\-fits\fP
Toggles whether to show what type each quantified
variable takes in a valid hole fit.
.TP
.B \fB\-fshow\-type\-of\-hole\-fits\fP
Toggles whether to show the type of the valid hole fits
in the output.
.TP
.B \fB\-funclutter\-valid\-hole\-fits\fP
Unclutter the list of valid hole fits by not showing
provenance nor type applications of suggestions.
.TP
.B \fB\-Rghc\-timing\fP
Summarise timing stats for GHC (same as \fB+RTS \-tstderr\fP).
.TP
.B \fB\-v\fP
verbose mode (equivalent to \fB\-v3\fP)
.TP
.B \fB\-v⟨n⟩\fP
set verbosity level
.UNINDENT
.SS Warnings
.INDENT 0.0
.TP
.B \fB\-fdefer\-out\-of\-scope\-variables\fP
Convert variable out of scope variables errors into warnings.
Implied by \fB\-fdefer\-type\-errors\fP\&.
See also \fB\-Wdeferred\-out\-of\-scope\-variables\fP\&.
.TP
.B \fB\-fdefer\-type\-errors\fP
Turn type errors into warnings, deferring the error until
runtime\&. Implies
\fB\-fdefer\-typed\-holes\fP and
\fB\-fdefer\-out\-of\-scope\-variables\fP\&.
See also \fB\-Wdeferred\-type\-errors\fP
.TP
.B \fB\-fdefer\-typed\-holes\fP
Convert typed hole errors into warnings,
deferring the error until runtime\&.
Implied by \fB\-fdefer\-type\-errors\fP\&.
See also \fB\-Wtyped\-holes\fP\&.
.TP
.B \fB\-fenable\-th\-splice\-warnings\fP
Generate warnings for Template Haskell splices
.TP
.B \fB\-fhelpful\-errors\fP
Make suggestions for mis\-spelled names.
.TP
.B \fB\-fmax\-pmcheck\-models=⟨n⟩\fP
soft limit on the number of parallel models the pattern match
checker should check a pattern match clause against
.TP
.B \fB\-fshow\-warning\-groups\fP
show which group an emitted warning belongs to.
.TP
.B \fB\-fvia\-C\fP
use the C code generator
.TP
.B \fB\-W\fP
enable normal warnings
.TP
.B \fB\-w\fP
disable all warnings
.TP
.B \fB\-Wall\fP
enable almost all warnings (details in options\-sanity)
.TP
.B \fB\-Wall\-missed\-specialisations\fP
warn when specialisation of any overloaded function fails.
.TP
.B \fB\-Wcompat\fP
enable future compatibility warnings
(details in options\-sanity)
.TP
.B \fB\-Wcompat\-unqualified\-imports\fP
Report unqualified imports of core libraries which are expected
to cause compatibility problems in future releases.
.TP
.B \fB\-Wcpp\-undef\fP
warn on uses of the \fI#if\fP directive on undefined identifiers
.TP
.B \fB\-Wdeferred\-out\-of\-scope\-variables\fP
Report warnings when variable out\-of\-scope errors are
deferred until runtime\&.
See \fB\-fdefer\-out\-of\-scope\-variables\fP\&.
.TP
.B \fB\-Wdeferred\-type\-errors\fP
Report warnings when deferred type errors are enabled. This option is enabled by
default. See \fB\-fdefer\-type\-errors\fP\&.
.TP
.B \fB\-Wdeprecated\-flags\fP
warn about uses of commandline flags that are deprecated
.TP
.B \fB\-Wdeprecations\fP
warn about uses of functions & types that have warnings or
deprecated pragmas. Alias for \fB\-Wwarnings\-deprecations\fP
.TP
.B \fB\-Wderiving\-defaults\fP
warn about default deriving when using both
\fBDeriveAnyClass\fP and \fBGeneralizedNewtypeDeriving\fP
.TP
.B \fB\-Wdodgy\-exports\fP
warn about dodgy exports
.TP
.B \fB\-Wdodgy\-foreign\-imports\fP
warn about dodgy foreign imports
.TP
.B \fB\-Wdodgy\-imports\fP
warn about dodgy imports
.TP
.B \fB\-Wduplicate\-constraints\fP
warn when a constraint appears duplicated in a type signature
.TP
.B \fB\-Wduplicate\-exports\fP
warn when an entity is exported multiple times
.TP
.B \fB\-Wempty\-enumerations\fP
warn about enumerations that are empty
.TP
.B \fB\-Werror\fP
make warnings fatal
.TP
.B \fB\-Weverything\fP
enable all warnings supported by GHC
.TP
.B \fB\-Whi\-shadowing\fP
\fI(deprecated)\fP
warn when a \fB\&.hi\fP file in the current directory shadows a library
.TP
.B \fB\-Widentities\fP
warn about uses of Prelude numeric conversions that are probably
the identity (and hence could be omitted)
.TP
.B \fB\-Wimplicit\-kind\-vars\fP
warn when kind variables are implicitly quantified over.
.TP
.B \fB\-Wimplicit\-prelude\fP
warn when the Prelude is implicitly imported
.TP
.B \fB\-Winaccessible\-code\fP
warn about inaccessible code
.TP
.B \fB\-Wincomplete\-patterns\fP
warn when a pattern match could fail
.TP
.B \fB\-Wincomplete\-record\-updates\fP
warn when a record update could fail
.TP
.B \fB\-Wincomplete\-uni\-patterns\fP
warn when a pattern match in a lambda expression or
pattern binding could fail
.TP
.B \fB\-Winline\-rule\-shadowing\fP
Warn if a rewrite RULE might fail to fire because the
function might be inlined before the rule has a chance to fire.
See rules\-inline\&.
.TP
.B \fB\-Wmissed\-extra\-shared\-lib\fP
Warn when GHCi can\(aqt load a shared lib.
.TP
.B \fB\-Wmissed\-specialisations\fP
warn when specialisation of an imported, overloaded function
fails.
.TP
.B \fB\-Wmissing\-deriving\-strategies\fP
warn when a deriving clause is missing a deriving strategy
.TP
.B \fB\-Wmissing\-export\-lists\fP
warn when a module declaration does not explicitly list all
exports
.TP
.B \fB\-Wmissing\-exported\-signatures\fP
warn about top\-level functions without signatures, only if they
are exported. takes precedence over \-Wmissing\-signatures
.TP
.B \fB\-Wmissing\-exported\-sigs\fP
\fI(deprecated)\fP
warn about top\-level functions without signatures, only if they
are exported. takes precedence over \-Wmissing\-signatures
.TP
.B \fB\-Wmissing\-fields\fP
warn when fields of a record are uninitialised
.TP
.B \fB\-Wmissing\-home\-modules\fP
warn when encountering a home module imported, but not listed
on the command line. Useful for cabal to ensure GHC won\(aqt pick
up modules, not listed neither in \fBexposed\-modules\fP, nor in
\fBother\-modules\fP\&.
.TP
.B \fB\-Wmissing\-import\-lists\fP
warn when an import declaration does not explicitly list all the
names brought into scope
.TP
.B \fB\-Wmissing\-local\-signatures\fP
warn about polymorphic local bindings without signatures
.TP
.B \fB\-Wmissing\-local\-sigs\fP
\fI(deprecated)\fP
warn about polymorphic local bindings without signatures
.TP
.B \fB\-Wmissing\-methods\fP
warn when class methods are undefined
.TP
.B \fB\-Wmissing\-monadfail\-instances\fP
Warn when a failable pattern is used in a do\-block that does
not have a \fBMonadFail\fP instance.
.TP
.B \fB\-Wmissing\-pattern\-synonym\-signatures\fP
warn when pattern synonyms do not have type signatures
.TP
.B \fB\-Wmissing\-signatures\fP
warn about top\-level functions without signatures
.TP
.B \fB\-Wmonomorphism\-restriction\fP
warn when the Monomorphism Restriction is applied
.TP
.B \fB\-Wname\-shadowing\fP
warn when names are shadowed
.TP
.B \fB\-Wno\-compat\fP
Disables all warnings enabled by \fB\-Wcompat\fP\&.
.TP
.B \fB\-Wnoncanonical\-monad\-instances\fP
warn when \fBApplicative\fP or \fBMonad\fP instances have
noncanonical definitions of \fBreturn\fP, \fBpure\fP, \fB(>>)\fP,
or \fB(*>)\fP\&.
See flag description in options\-sanity for more details.
.TP
.B \fB\-Wnoncanonical\-monadfail\-instances\fP
warn when \fBMonad\fP or \fBMonadFail\fP instances have
noncanonical definitions of \fBfail\fP\&.
See flag description in options\-sanity for more details.
.TP
.B \fB\-Wnoncanonical\-monoid\-instances\fP
warn when \fBSemigroup\fP or \fBMonoid\fP instances have
noncanonical definitions of \fB(<>)\fP or \fBmappend\fP\&.
See flag description in options\-sanity for more details.
.TP
.B \fB\-Worphans\fP
warn when the module contains orphan instance declarations
or rewrite rules
.TP
.B \fB\-Woverflowed\-literals\fP
warn about literals that will overflow their type
.TP
.B \fB\-Woverlapping\-patterns\fP
warn about overlapping patterns
.TP
.B \fB\-Wpartial\-fields\fP
warn when defining a partial record field.
.TP
.B \fB\-Wpartial\-type\-signatures\fP
warn about holes in partial type signatures when
\fBPartialTypeSignatures\fP is enabled. Not applicable when
\fBPartialTypeSignatures\fP is not enabled, in which case
errors are generated for such holes.
.TP
.B \fB\-Wredundant\-constraints\fP
Have the compiler warn about redundant constraints in type
signatures.
.TP
.B \fB\-Wredundant\-record\-wildcards\fP
Warn about record wildcard matches when the wildcard binds no patterns.
.TP
.B \fB\-Wsafe\fP
warn if the module being compiled is regarded to be safe.
.TP
.B \fB\-Wsemigroup\fP
warn when a \fBMonoid\fP is not \fBSemigroup\fP, and on non\-
\fBSemigroup\fP definitions of \fB(<>)\fP?
.TP
.B \fB\-Wsimplifiable\-class\-constraints\fP
Warn about class constraints in a type signature that can
be simplified using a top\-level instance declaration.
.TP
.B \fB\-Wspace\-after\-bang\fP
warn for missing space before the second argument
of an infix definition of \fB(!)\fP when
\fBBangPatterns\fP are not enabled
.TP
.B \fB\-Wstar\-binder\fP
warn about binding the \fB(*)\fP type operator despite
\fBStarIsType\fP
.TP
.B \fB\-Wstar\-is\-type\fP
warn when \fB*\fP is used to mean \fBData.Kind.Type\fP
.TP
.B \fB\-Wtabs\fP
warn if there are tabs in the source file
.TP
.B \fB\-Wtrustworthy\-safe\fP
warn if the module being compiled is marked as
\fBTrustworthy\fP but it could instead be marked as
\fBSafe\fP, a more informative bound.
.TP
.B \fB\-Wtype\-defaults\fP
warn when defaulting happens
.TP
.B \fB\-Wtyped\-holes\fP
Report warnings when typed hole errors are
deferred until runtime\&. See
\fB\-fdefer\-typed\-holes\fP\&.
.TP
.B \fB\-Wunbanged\-strict\-patterns\fP
warn on pattern bind of unlifted variable that is neither bare
nor banged
.TP
.B \fB\-Wunrecognised\-pragmas\fP
warn about uses of pragmas that GHC doesn\(aqt recognise
.TP
.B \fB\-Wunrecognised\-warning\-flags\fP
throw a warning when an unrecognised \fB\-W...\fP flag is
encountered on the command line.
.TP
.B \fB\-Wunsafe\fP
warn if the module being compiled is regarded to be unsafe.
See safe\-haskell
.TP
.B \fB\-Wunsupported\-calling\-conventions\fP
warn about use of an unsupported calling convention
.TP
.B \fB\-Wunsupported\-llvm\-version\fP
Warn when using \fB\-fllvm\fP with an unsupported
version of LLVM.
.TP
.B \fB\-Wunticked\-promoted\-constructors\fP
warn if promoted constructors are not ticked
.TP
.B \fB\-Wunused\-binds\fP
warn about bindings that are unused. Alias for
\fB\-Wunused\-top\-binds\fP, \fB\-Wunused\-local\-binds\fP and
\fB\-Wunused\-pattern\-binds\fP
.TP
.B \fB\-Wunused\-do\-bind\fP
warn about do bindings that appear to throw away values of types
other than \fB()\fP
.TP
.B \fB\-Wunused\-foralls\fP
warn about type variables in user\-written
\fBforall\fP\es that are unused
.TP
.B \fB\-Wunused\-imports\fP
warn about unnecessary imports
.TP
.B \fB\-Wunused\-local\-binds\fP
warn about local bindings that are unused
.TP
.B \fB\-Wunused\-matches\fP
warn about variables in patterns that aren\(aqt used
.TP
.B \fB\-Wunused\-packages\fP
warn when package is requested on command line, but was never loaded.
.TP
.B \fB\-Wunused\-pattern\-binds\fP
warn about pattern match bindings that are unused
.TP
.B \fB\-Wunused\-record\-wildcards\fP
Warn about record wildcard matches when none of the bound variables
are used.
.TP
.B \fB\-Wunused\-top\-binds\fP
warn about top\-level bindings that are unused
.TP
.B \fB\-Wunused\-type\-patterns\fP
warn about unused type variables which arise from patterns in
in type family and data family instances
.TP
.B \fB\-Wwarn\fP
make warnings non\-fatal
.TP
.B \fB\-Wwarnings\-deprecations\fP
warn about uses of functions & types that have warnings or
deprecated pragmas
.TP
.B \fB\-Wwrong\-do\-bind\fP
warn about do bindings that appear to throw away monadic values
that you should have bound instead
.UNINDENT
.SH COPYRIGHT
.sp
Copyright 2015. The University Court of the University of Glasgow.
All rights reserved.
.SH AUTHOR
The GHC Team
.SH COPYRIGHT
2015, GHC Team
.\" Generated by docutils manpage writer.
.