Do not make FunctionalDependencies force MonoLocalBinds
[ghc-hetmet.git] / compiler / main / DynFlags.hs
1 {-# OPTIONS_GHC -w #-}
2 -- Temporary, until rtsIsProfiled is fixed
3
4 -- |
5 -- Dynamic flags
6 --
7 --
8 -- (c) The University of Glasgow 2005
9 --
10
11 -- Most flags are dynamic flags, which means they can change from
12 -- compilation to compilation using @OPTIONS_GHC@ pragmas, and in a
13 -- multi-session GHC each session can be using different dynamic
14 -- flags.  Dynamic flags can also be set at the prompt in GHCi.
15 module DynFlags (
16         -- * Dynamic flags and associated configuration types
17         DynFlag(..),
18         ExtensionFlag(..),
19         glasgowExtsFlags,
20         flattenExtensionFlags,
21         ensureFlattenedExtensionFlags,
22         dopt,
23         dopt_set,
24         dopt_unset,
25         xopt,
26         xopt_set,
27         xopt_unset,
28         xopt_set_flattened,
29         xopt_unset_flattened,
30         DynFlags(..),
31         RtsOptsEnabled(..),
32         HscTarget(..), isObjectTarget, defaultObjectTarget,
33         GhcMode(..), isOneShot,
34         GhcLink(..), isNoLink,
35         PackageFlag(..),
36         Option(..), showOpt,
37         DynLibLoader(..),
38         fFlags, fLangFlags, xFlags,
39         dphPackage,
40         wayNames,
41
42         -- ** Manipulating DynFlags
43         defaultDynFlags,                -- DynFlags
44         initDynFlags,                   -- DynFlags -> IO DynFlags
45
46         getOpts,                        -- DynFlags -> (DynFlags -> [a]) -> [a]
47         getVerbFlag,
48         updOptLevel,
49         setTmpDir,
50         setPackageName,
51         doingTickyProfiling,
52
53         -- ** Parsing DynFlags
54         parseDynamicFlags,
55         parseDynamicNoPackageFlags,
56         allFlags,
57
58         supportedLanguagesAndExtensions,
59
60         -- ** DynFlag C compiler options
61         machdepCCOpts, picCCOpts,
62
63         -- * Configuration of the stg-to-stg passes
64         StgToDo(..),
65         getStgToDo,
66
67         -- * Compiler configuration suitable for display to the user
68         Printable(..),
69         compilerInfo
70 #ifdef GHCI
71 -- Only in stage 2 can we be sure that the RTS 
72 -- exposes the appropriate runtime boolean
73         , rtsIsProfiled
74 #endif
75   ) where
76
77 #include "HsVersions.h"
78
79 #ifndef OMIT_NATIVE_CODEGEN
80 import Platform
81 #endif
82 import Module
83 import PackageConfig
84 import PrelNames        ( mAIN )
85 import StaticFlags
86 import {-# SOURCE #-} Packages (PackageState)
87 import DriverPhases     ( Phase(..), phaseInputExt )
88 import Config
89 import CmdLineParser
90 import Constants        ( mAX_CONTEXT_REDUCTION_DEPTH )
91 import Panic
92 import Util
93 import Maybes           ( orElse )
94 import SrcLoc
95 import FastString
96 import Outputable
97 import Foreign.C        ( CInt )
98 import {-# SOURCE #-} ErrUtils ( Severity(..), Message, mkLocMessage )
99
100 import System.IO.Unsafe ( unsafePerformIO )
101 import Data.IORef
102 import Control.Monad    ( when )
103
104 import Data.Char
105 import Data.List
106 import Data.Map (Map)
107 import qualified Data.Map as Map
108 import System.FilePath
109 import System.IO        ( stderr, hPutChar )
110
111 -- -----------------------------------------------------------------------------
112 -- DynFlags
113
114 -- | Enumerates the simple on-or-off dynamic flags
115 data DynFlag
116
117    -- debugging flags
118    = Opt_D_dump_cmm
119    | Opt_D_dump_cmmz
120    | Opt_D_dump_cmmz_pretty
121    | Opt_D_dump_cps_cmm
122    | Opt_D_dump_cvt_cmm
123    | Opt_D_dump_asm
124    | Opt_D_dump_asm_native
125    | Opt_D_dump_asm_liveness
126    | Opt_D_dump_asm_coalesce
127    | Opt_D_dump_asm_regalloc
128    | Opt_D_dump_asm_regalloc_stages
129    | Opt_D_dump_asm_conflicts
130    | Opt_D_dump_asm_stats
131    | Opt_D_dump_asm_expanded
132    | Opt_D_dump_llvm
133    | Opt_D_dump_cpranal
134    | Opt_D_dump_deriv
135    | Opt_D_dump_ds
136    | Opt_D_dump_flatC
137    | Opt_D_dump_foreign
138    | Opt_D_dump_inlinings
139    | Opt_D_dump_rule_firings
140    | Opt_D_dump_occur_anal
141    | Opt_D_dump_parsed
142    | Opt_D_dump_rn
143    | Opt_D_dump_simpl
144    | Opt_D_dump_simpl_iterations
145    | Opt_D_dump_simpl_phases
146    | Opt_D_dump_spec
147    | Opt_D_dump_prep
148    | Opt_D_dump_stg
149    | Opt_D_dump_stranal
150    | Opt_D_dump_tc
151    | Opt_D_dump_types
152    | Opt_D_dump_rules
153    | Opt_D_dump_cse
154    | Opt_D_dump_worker_wrapper
155    | Opt_D_dump_rn_trace
156    | Opt_D_dump_rn_stats
157    | Opt_D_dump_opt_cmm
158    | Opt_D_dump_simpl_stats
159    | Opt_D_dump_tc_trace
160    | Opt_D_dump_if_trace
161    | Opt_D_dump_splices
162    | Opt_D_dump_BCOs
163    | Opt_D_dump_vect
164    | Opt_D_dump_hpc
165    | Opt_D_dump_rtti
166    | Opt_D_source_stats
167    | Opt_D_verbose_core2core
168    | Opt_D_verbose_stg2stg
169    | Opt_D_dump_hi
170    | Opt_D_dump_hi_diffs
171    | Opt_D_dump_minimal_imports
172    | Opt_D_dump_mod_cycles
173    | Opt_D_dump_view_pattern_commoning
174    | Opt_D_faststring_stats
175    | Opt_DumpToFile                     -- ^ Append dump output to files instead of stdout.
176    | Opt_D_no_debug_output
177    | Opt_DoCoreLinting
178    | Opt_DoStgLinting
179    | Opt_DoCmmLinting
180    | Opt_DoAsmLinting
181
182    | Opt_WarnIsError                    -- -Werror; makes warnings fatal
183    | Opt_WarnDuplicateExports
184    | Opt_WarnHiShadows
185    | Opt_WarnImplicitPrelude
186    | Opt_WarnIncompletePatterns
187    | Opt_WarnIncompletePatternsRecUpd
188    | Opt_WarnMissingFields
189    | Opt_WarnMissingImportList
190    | Opt_WarnMissingMethods
191    | Opt_WarnMissingSigs
192    | Opt_WarnMissingLocalSigs
193    | Opt_WarnNameShadowing
194    | Opt_WarnOverlappingPatterns
195    | Opt_WarnTypeDefaults
196    | Opt_WarnMonomorphism
197    | Opt_WarnUnusedBinds
198    | Opt_WarnUnusedImports
199    | Opt_WarnUnusedMatches
200    | Opt_WarnWarningsDeprecations
201    | Opt_WarnDeprecatedFlags
202    | Opt_WarnDodgyExports
203    | Opt_WarnDodgyImports
204    | Opt_WarnOrphans
205    | Opt_WarnTabs
206    | Opt_WarnUnrecognisedPragmas
207    | Opt_WarnDodgyForeignImports
208    | Opt_WarnLazyUnliftedBindings
209    | Opt_WarnUnusedDoBind
210    | Opt_WarnWrongDoBind
211    | Opt_WarnAlternativeLayoutRuleTransitional
212
213    | Opt_PrintExplicitForalls
214
215    -- optimisation opts
216    | Opt_Strictness
217    | Opt_FullLaziness
218    | Opt_FloatIn
219    | Opt_Specialise
220    | Opt_StaticArgumentTransformation
221    | Opt_CSE
222    | Opt_LiberateCase
223    | Opt_SpecConstr
224    | Opt_DoLambdaEtaExpansion
225    | Opt_IgnoreAsserts
226    | Opt_DoEtaReduction
227    | Opt_CaseMerge
228    | Opt_UnboxStrictFields
229    | Opt_MethodSharing
230    | Opt_DictsCheap
231    | Opt_EnableRewriteRules             -- Apply rewrite rules during simplification
232    | Opt_Vectorise
233    | Opt_RegsGraph                      -- do graph coloring register allocation
234    | Opt_RegsIterative                  -- do iterative coalescing graph coloring register allocation
235
236    -- Interface files
237    | Opt_IgnoreInterfacePragmas
238    | Opt_OmitInterfacePragmas
239    | Opt_ExposeAllUnfoldings
240
241    -- profiling opts
242    | Opt_AutoSccsOnAllToplevs
243    | Opt_AutoSccsOnExportedToplevs
244    | Opt_AutoSccsOnIndividualCafs
245
246    -- misc opts
247    | Opt_Pp
248    | Opt_ForceRecomp
249    | Opt_DryRun
250    | Opt_DoAsmMangling
251    | Opt_ExcessPrecision
252    | Opt_EagerBlackHoling
253    | Opt_ReadUserPackageConf
254    | Opt_NoHsMain
255    | Opt_SplitObjs
256    | Opt_StgStats
257    | Opt_HideAllPackages
258    | Opt_PrintBindResult
259    | Opt_Haddock
260    | Opt_HaddockOptions
261    | Opt_Hpc_No_Auto
262    | Opt_BreakOnException
263    | Opt_BreakOnError
264    | Opt_PrintEvldWithShow
265    | Opt_PrintBindContents
266    | Opt_GenManifest
267    | Opt_EmbedManifest
268    | Opt_EmitExternalCore
269    | Opt_SharedImplib
270    | Opt_BuildingCabalPackage
271    | Opt_SSE2
272
273         -- temporary flags
274    | Opt_RunCPS
275    | Opt_RunCPSZ
276    | Opt_ConvertToZipCfgAndBack
277    | Opt_AutoLinkPackages
278    | Opt_ImplicitImportQualified
279    | Opt_TryNewCodeGen
280
281    -- keeping stuff
282    | Opt_KeepHiDiffs
283    | Opt_KeepHcFiles
284    | Opt_KeepSFiles
285    | Opt_KeepRawSFiles
286    | Opt_KeepTmpFiles
287    | Opt_KeepRawTokenStream
288    | Opt_KeepLlvmFiles
289
290    deriving (Eq, Show)
291
292 data Language = Haskell98 | Haskell2010
293
294 data ExtensionFlag
295    = Opt_Cpp
296    | Opt_OverlappingInstances
297    | Opt_UndecidableInstances
298    | Opt_IncoherentInstances
299    | Opt_MonomorphismRestriction
300    | Opt_MonoPatBinds
301    | Opt_MonoLocalBinds
302    | Opt_RelaxedPolyRec         -- Deprecated
303    | Opt_ExtendedDefaultRules           -- Use GHC's extended rules for defaulting
304    | Opt_ForeignFunctionInterface
305    | Opt_UnliftedFFITypes
306    | Opt_GHCForeignImportPrim
307    | Opt_PArr                           -- Syntactic support for parallel arrays
308    | Opt_Arrows                         -- Arrow-notation syntax
309    | Opt_TemplateHaskell
310    | Opt_QuasiQuotes
311    | Opt_ImplicitParams
312    | Opt_Generics                       -- "Derivable type classes"
313    | Opt_ImplicitPrelude
314    | Opt_ScopedTypeVariables
315    | Opt_UnboxedTuples
316    | Opt_BangPatterns
317    | Opt_TypeFamilies
318    | Opt_OverloadedStrings
319    | Opt_DisambiguateRecordFields
320    | Opt_RecordWildCards
321    | Opt_RecordPuns
322    | Opt_ViewPatterns
323    | Opt_GADTs
324    | Opt_NPlusKPatterns
325    | Opt_DoAndIfThenElse
326
327    | Opt_StandaloneDeriving
328    | Opt_DeriveDataTypeable
329    | Opt_DeriveFunctor
330    | Opt_DeriveTraversable
331    | Opt_DeriveFoldable
332
333    | Opt_TypeSynonymInstances
334    | Opt_FlexibleContexts
335    | Opt_FlexibleInstances
336    | Opt_ConstrainedClassMethods
337    | Opt_MultiParamTypeClasses
338    | Opt_FunctionalDependencies
339    | Opt_UnicodeSyntax
340    | Opt_PolymorphicComponents
341    | Opt_ExistentialQuantification
342    | Opt_MagicHash
343    | Opt_EmptyDataDecls
344    | Opt_KindSignatures
345    | Opt_ParallelListComp
346    | Opt_TransformListComp
347    | Opt_GeneralizedNewtypeDeriving
348    | Opt_RecursiveDo
349    | Opt_DoRec
350    | Opt_PostfixOperators
351    | Opt_TupleSections
352    | Opt_PatternGuards
353    | Opt_LiberalTypeSynonyms
354    | Opt_Rank2Types
355    | Opt_RankNTypes
356    | Opt_ImpredicativeTypes
357    | Opt_TypeOperators
358    | Opt_PackageImports
359    | Opt_NewQualifiedOperators
360    | Opt_ExplicitForAll
361    | Opt_AlternativeLayoutRule
362    | Opt_AlternativeLayoutRuleTransitional
363    | Opt_DatatypeContexts
364    deriving (Eq, Show)
365
366 -- | Contains not only a collection of 'DynFlag's but also a plethora of
367 -- information relating to the compilation of a single file or GHC session
368 data DynFlags = DynFlags {
369   ghcMode               :: GhcMode,
370   ghcLink               :: GhcLink,
371   hscTarget             :: HscTarget,
372   hscOutName            :: String,      -- ^ Name of the output file
373   extCoreName           :: String,      -- ^ Name of the .hcr output file
374   verbosity             :: Int,         -- ^ Verbosity level: see Note [Verbosity levels]
375   optLevel              :: Int,         -- ^ Optimisation level
376   simplPhases           :: Int,         -- ^ Number of simplifier phases
377   maxSimplIterations    :: Int,         -- ^ Max simplifier iterations
378   shouldDumpSimplPhase  :: Maybe String,
379   ruleCheck             :: Maybe String,
380   strictnessBefore      :: [Int],       -- ^ Additional demand analysis
381
382   specConstrThreshold   :: Maybe Int,   -- ^ Threshold for SpecConstr
383   specConstrCount       :: Maybe Int,   -- ^ Max number of specialisations for any one function
384   liberateCaseThreshold :: Maybe Int,   -- ^ Threshold for LiberateCase
385
386 #ifndef OMIT_NATIVE_CODEGEN
387   targetPlatform        :: Platform,    -- ^ The platform we're compiling for. Used by the NCG.
388 #endif
389   stolen_x86_regs       :: Int,
390   cmdlineHcIncludes     :: [String],    -- ^ @\-\#includes@
391   importPaths           :: [FilePath],
392   mainModIs             :: Module,
393   mainFunIs             :: Maybe String,
394   ctxtStkDepth          :: Int,         -- ^ Typechecker context stack depth
395
396   dphBackend            :: DPHBackend,
397
398   thisPackage           :: PackageId,   -- ^ name of package currently being compiled
399
400   -- ways
401   ways                  :: [Way],       -- ^ Way flags from the command line
402   buildTag              :: String,      -- ^ The global \"way\" (e.g. \"p\" for prof)
403   rtsBuildTag           :: String,      -- ^ The RTS \"way\"
404
405   -- For object splitting
406   splitInfo             :: Maybe (String,Int),
407
408   -- paths etc.
409   objectDir             :: Maybe String,
410   dylibInstallName      :: Maybe String,
411   hiDir                 :: Maybe String,
412   stubDir               :: Maybe String,
413
414   objectSuf             :: String,
415   hcSuf                 :: String,
416   hiSuf                 :: String,
417
418   outputFile            :: Maybe String,
419   outputHi              :: Maybe String,
420   dynLibLoader          :: DynLibLoader,
421
422   -- | This is set by 'DriverPipeline.runPipeline' based on where
423   --    its output is going.
424   dumpPrefix            :: Maybe FilePath,
425
426   -- | Override the 'dumpPrefix' set by 'DriverPipeline.runPipeline'.
427   --    Set by @-ddump-file-prefix@
428   dumpPrefixForce       :: Maybe FilePath,
429
430   includePaths          :: [String],
431   libraryPaths          :: [String],
432   frameworkPaths        :: [String],    -- used on darwin only
433   cmdlineFrameworks     :: [String],    -- ditto
434   tmpDir                :: String,      -- no trailing '/'
435
436   ghcUsagePath          :: FilePath,    -- Filled in by SysTools
437   ghciUsagePath         :: FilePath,    -- ditto
438   rtsOpts               :: Maybe String,
439   rtsOptsEnabled        :: RtsOptsEnabled,
440
441   hpcDir                :: String,      -- ^ Path to store the .mix files
442
443   -- options for particular phases
444   opt_L                 :: [String],
445   opt_P                 :: [String],
446   opt_F                 :: [String],
447   opt_c                 :: [String],
448   opt_m                 :: [String],
449   opt_a                 :: [String],
450   opt_l                 :: [String],
451   opt_windres           :: [String],
452   opt_lo                :: [String], -- LLVM: llvm optimiser
453   opt_lc                :: [String], -- LLVM: llc static compiler
454
455   -- commands for particular phases
456   pgm_L                 :: String,
457   pgm_P                 :: (String,[Option]),
458   pgm_F                 :: String,
459   pgm_c                 :: (String,[Option]),
460   pgm_m                 :: (String,[Option]),
461   pgm_s                 :: (String,[Option]),
462   pgm_a                 :: (String,[Option]),
463   pgm_l                 :: (String,[Option]),
464   pgm_dll               :: (String,[Option]),
465   pgm_T                 :: String,
466   pgm_sysman            :: String,
467   pgm_windres           :: String,
468   pgm_lo                :: (String,[Option]), -- LLVM: opt llvm optimiser
469   pgm_lc                :: (String,[Option]), -- LLVM: llc static compiler
470
471   --  For ghc -M
472   depMakefile           :: FilePath,
473   depIncludePkgDeps     :: Bool,
474   depExcludeMods        :: [ModuleName],
475   depSuffixes           :: [String],
476
477   --  Package flags
478   extraPkgConfs         :: [FilePath],
479   topDir                :: FilePath,    -- filled in by SysTools
480   systemPackageConfig   :: FilePath,    -- ditto
481         -- ^ The @-package-conf@ flags given on the command line, in the order
482         -- they appeared.
483
484   packageFlags          :: [PackageFlag],
485         -- ^ The @-package@ and @-hide-package@ flags from the command-line
486
487   -- Package state
488   -- NB. do not modify this field, it is calculated by
489   -- Packages.initPackages and Packages.updatePackages.
490   pkgDatabase           :: Maybe [PackageConfig],
491   pkgState              :: PackageState,
492
493   -- Temporary files
494   -- These have to be IORefs, because the defaultCleanupHandler needs to
495   -- know what to clean when an exception happens
496   filesToClean          :: IORef [FilePath],
497   dirsToClean           :: IORef (Map FilePath FilePath),
498
499   -- hsc dynamic flags
500   flags                 :: [DynFlag],
501   language              :: Maybe Language,
502   extensionFlags        :: Either [OnOff ExtensionFlag]
503                                   [ExtensionFlag],
504
505   -- | Message output action: use "ErrUtils" instead of this if you can
506   log_action            :: Severity -> SrcSpan -> PprStyle -> Message -> IO (),
507
508   haddockOptions :: Maybe String
509  }
510
511 wayNames :: DynFlags -> [WayName]
512 wayNames = map wayName . ways
513
514 -- | The target code type of the compilation (if any).
515 --
516 -- Whenever you change the target, also make sure to set 'ghcLink' to
517 -- something sensible.
518 --
519 -- 'HscNothing' can be used to avoid generating any output, however, note
520 -- that:
521 --
522 --  * This will not run the desugaring step, thus no warnings generated in
523 --    this step will be output.  In particular, this includes warnings related
524 --    to pattern matching.  You can run the desugarer manually using
525 --    'GHC.desugarModule'.
526 --
527 --  * If a program uses Template Haskell the typechecker may try to run code
528 --    from an imported module.  This will fail if no code has been generated
529 --    for this module.  You can use 'GHC.needsTemplateHaskell' to detect
530 --    whether this might be the case and choose to either switch to a
531 --    different target or avoid typechecking such modules.  (The latter may
532 --    preferable for security reasons.)
533 --
534 data HscTarget
535   = HscC           -- ^ Generate C code.
536   | HscAsm         -- ^ Generate assembly using the native code generator.
537   | HscLlvm        -- ^ Generate assembly using the llvm code generator.
538   | HscJava        -- ^ Generate Java bytecode.
539   | HscInterpreted -- ^ Generate bytecode.  (Requires 'LinkInMemory')
540   | HscNothing     -- ^ Don't generate any code.  See notes above.
541   deriving (Eq, Show)
542
543 -- | Will this target result in an object file on the disk?
544 isObjectTarget :: HscTarget -> Bool
545 isObjectTarget HscC     = True
546 isObjectTarget HscAsm   = True
547 isObjectTarget HscLlvm  = True
548 isObjectTarget _        = False
549
550 -- | The 'GhcMode' tells us whether we're doing multi-module
551 -- compilation (controlled via the "GHC" API) or one-shot
552 -- (single-module) compilation.  This makes a difference primarily to
553 -- the "Finder": in one-shot mode we look for interface files for
554 -- imported modules, but in multi-module mode we look for source files
555 -- in order to check whether they need to be recompiled.
556 data GhcMode
557   = CompManager         -- ^ @\-\-make@, GHCi, etc.
558   | OneShot             -- ^ @ghc -c Foo.hs@
559   | MkDepend            -- ^ @ghc -M@, see "Finder" for why we need this
560   deriving Eq
561
562 instance Outputable GhcMode where
563   ppr CompManager = ptext (sLit "CompManager")
564   ppr OneShot     = ptext (sLit "OneShot")
565   ppr MkDepend    = ptext (sLit "MkDepend")
566
567 isOneShot :: GhcMode -> Bool
568 isOneShot OneShot = True
569 isOneShot _other  = False
570
571 -- | What to do in the link step, if there is one.
572 data GhcLink
573   = NoLink              -- ^ Don't link at all
574   | LinkBinary          -- ^ Link object code into a binary
575   | LinkInMemory        -- ^ Use the in-memory dynamic linker (works for both
576                         --   bytecode and object code).
577   | LinkDynLib          -- ^ Link objects into a dynamic lib (DLL on Windows, DSO on ELF platforms)
578   deriving (Eq, Show)
579
580 isNoLink :: GhcLink -> Bool
581 isNoLink NoLink = True
582 isNoLink _      = False
583
584 -- Is it worth evaluating this Bool and caching it in the DynFlags value
585 -- during initDynFlags?
586 doingTickyProfiling :: DynFlags -> Bool
587 doingTickyProfiling _ = opt_Ticky
588   -- XXX -ticky is a static flag, because it implies -debug which is also
589   -- static.  If the way flags were made dynamic, we could fix this.
590
591 data PackageFlag
592   = ExposePackage  String
593   | ExposePackageId String
594   | HidePackage    String
595   | IgnorePackage  String
596   deriving Eq
597
598 defaultHscTarget :: HscTarget
599 defaultHscTarget = defaultObjectTarget
600
601 -- | The 'HscTarget' value corresponding to the default way to create
602 -- object files on the current platform.
603 defaultObjectTarget :: HscTarget
604 defaultObjectTarget
605   | cGhcWithNativeCodeGen == "YES"      =  HscAsm
606   | otherwise                           =  HscC
607
608 data DynLibLoader
609   = Deployable
610   | SystemDependent
611   deriving Eq
612
613 data RtsOptsEnabled = RtsOptsNone | RtsOptsSafeOnly | RtsOptsAll
614
615 -- | Used by 'GHC.newSession' to partially initialize a new 'DynFlags' value
616 initDynFlags :: DynFlags -> IO DynFlags
617 initDynFlags dflags = do
618  -- someday these will be dynamic flags
619  ways <- readIORef v_Ways
620  refFilesToClean <- newIORef []
621  refDirsToClean <- newIORef Map.empty
622  return dflags{
623         ways            = ways,
624         buildTag        = mkBuildTag (filter (not . wayRTSOnly) ways),
625         rtsBuildTag     = mkBuildTag ways,
626         filesToClean    = refFilesToClean,
627         dirsToClean     = refDirsToClean
628         }
629
630 -- | The normal 'DynFlags'. Note that they is not suitable for use in this form
631 -- and must be fully initialized by 'GHC.newSession' first.
632 defaultDynFlags :: DynFlags
633 defaultDynFlags =
634      DynFlags {
635         ghcMode                 = CompManager,
636         ghcLink                 = LinkBinary,
637         hscTarget               = defaultHscTarget,
638         hscOutName              = "",
639         extCoreName             = "",
640         verbosity               = 0,
641         optLevel                = 0,
642         simplPhases             = 2,
643         maxSimplIterations      = 4,
644         shouldDumpSimplPhase    = Nothing,
645         ruleCheck               = Nothing,
646         specConstrThreshold     = Just 200,
647         specConstrCount         = Just 3,
648         liberateCaseThreshold   = Just 200,
649         strictnessBefore        = [],
650
651 #ifndef OMIT_NATIVE_CODEGEN
652         targetPlatform          = defaultTargetPlatform,
653 #endif
654         stolen_x86_regs         = 4,
655         cmdlineHcIncludes       = [],
656         importPaths             = ["."],
657         mainModIs               = mAIN,
658         mainFunIs               = Nothing,
659         ctxtStkDepth            = mAX_CONTEXT_REDUCTION_DEPTH,
660
661         dphBackend              = DPHPar,
662
663         thisPackage             = mainPackageId,
664
665         objectDir               = Nothing,
666         dylibInstallName        = Nothing,
667         hiDir                   = Nothing,
668         stubDir                 = Nothing,
669
670         objectSuf               = phaseInputExt StopLn,
671         hcSuf                   = phaseInputExt HCc,
672         hiSuf                   = "hi",
673
674         outputFile              = Nothing,
675         outputHi                = Nothing,
676         dynLibLoader            = SystemDependent,
677         dumpPrefix              = Nothing,
678         dumpPrefixForce         = Nothing,
679         includePaths            = [],
680         libraryPaths            = [],
681         frameworkPaths          = [],
682         cmdlineFrameworks       = [],
683         tmpDir                  = cDEFAULT_TMPDIR,
684         rtsOpts                 = Nothing,
685         rtsOptsEnabled          = RtsOptsSafeOnly,
686
687         hpcDir                  = ".hpc",
688
689         opt_L                   = [],
690         opt_P                   = (if opt_PIC
691                                    then ["-D__PIC__", "-U __PIC__"] -- this list is reversed
692                                    else []),
693         opt_F                   = [],
694         opt_c                   = [],
695         opt_a                   = [],
696         opt_m                   = [],
697         opt_l                   = [],
698         opt_windres             = [],
699         opt_lo                  = [],
700         opt_lc                  = [],
701
702         extraPkgConfs           = [],
703         packageFlags            = [],
704         pkgDatabase             = Nothing,
705         pkgState                = panic "no package state yet: call GHC.setSessionDynFlags",
706         ways                    = panic "defaultDynFlags: No ways",
707         buildTag                = panic "defaultDynFlags: No buildTag",
708         rtsBuildTag             = panic "defaultDynFlags: No rtsBuildTag",
709         splitInfo               = Nothing,
710         -- initSysTools fills all these in
711         ghcUsagePath            = panic "defaultDynFlags: No ghciUsagePath",
712         ghciUsagePath           = panic "defaultDynFlags: No ghciUsagePath",
713         topDir                  = panic "defaultDynFlags: No topDir",
714         systemPackageConfig     = panic  "no systemPackageConfig: call GHC.setSessionDynFlags",
715         pgm_L                   = panic "defaultDynFlags: No pgm_L",
716         pgm_P                   = panic "defaultDynFlags: No pgm_P",
717         pgm_F                   = panic "defaultDynFlags: No pgm_F",
718         pgm_c                   = panic "defaultDynFlags: No pgm_c",
719         pgm_m                   = panic "defaultDynFlags: No pgm_m",
720         pgm_s                   = panic "defaultDynFlags: No pgm_s",
721         pgm_a                   = panic "defaultDynFlags: No pgm_a",
722         pgm_l                   = panic "defaultDynFlags: No pgm_l",
723         pgm_dll                 = panic "defaultDynFlags: No pgm_dll",
724         pgm_T                   = panic "defaultDynFlags: No pgm_T",
725         pgm_sysman              = panic "defaultDynFlags: No pgm_sysman",
726         pgm_windres             = panic "defaultDynFlags: No pgm_windres",
727         pgm_lo                  = panic "defaultDynFlags: No pgm_lo",
728         pgm_lc                  = panic "defaultDynFlags: No pgm_lc",
729         -- end of initSysTools values
730         -- ghc -M values
731         depMakefile       = "Makefile",
732         depIncludePkgDeps = False,
733         depExcludeMods    = [],
734         depSuffixes       = [],
735         -- end of ghc -M values
736         filesToClean   = panic "defaultDynFlags: No filesToClean",
737         dirsToClean    = panic "defaultDynFlags: No dirsToClean",
738         haddockOptions = Nothing,
739         flags = defaultFlags,
740         language = Nothing,
741         extensionFlags = Left [],
742
743         log_action = \severity srcSpan style msg ->
744                         case severity of
745                           SevOutput -> printOutput (msg style)
746                           SevInfo   -> printErrs (msg style)
747                           SevFatal  -> printErrs (msg style)
748                           _         -> do 
749                                 hPutChar stderr '\n'
750                                 printErrs ((mkLocMessage srcSpan msg) style)
751                      -- careful (#2302): printErrs prints in UTF-8, whereas
752                      -- converting to string first and using hPutStr would
753                      -- just emit the low 8 bits of each unicode char.
754       }
755
756 {-
757 Note [Verbosity levels]
758 ~~~~~~~~~~~~~~~~~~~~~~~
759     0   |   print errors & warnings only
760     1   |   minimal verbosity: print "compiling M ... done." for each module.
761     2   |   equivalent to -dshow-passes
762     3   |   equivalent to existing "ghc -v"
763     4   |   "ghc -v -ddump-most"
764     5   |   "ghc -v -ddump-all"
765 -}
766
767 data OnOff a = On a
768              | Off a
769
770 flattenExtensionFlags :: DynFlags -> DynFlags
771 flattenExtensionFlags dflags
772     = case extensionFlags dflags of
773       Left onoffs ->
774           dflags {
775               extensionFlags = Right $ flattenExtensionFlags' (language dflags) onoffs
776           }
777       Right _ ->
778           panic "Flattening already-flattened extension flags"
779
780 ensureFlattenedExtensionFlags :: DynFlags -> DynFlags
781 ensureFlattenedExtensionFlags dflags
782     = case extensionFlags dflags of
783       Left onoffs ->
784           dflags {
785               extensionFlags = Right $ flattenExtensionFlags' (language dflags) onoffs
786           }
787       Right _ ->
788           dflags
789
790 -- OnOffs accumulate in reverse order, so we use foldr in order to
791 -- process them in the right order
792 flattenExtensionFlags' :: Maybe Language -> [OnOff ExtensionFlag]
793                        -> [ExtensionFlag]
794 flattenExtensionFlags' ml = foldr f defaultExtensionFlags
795     where f (On f)  flags = f : delete f flags
796           f (Off f) flags =     delete f flags
797           defaultExtensionFlags = languageExtensions ml
798
799 languageExtensions :: Maybe Language -> [ExtensionFlag]
800 languageExtensions Nothing
801     = Opt_MonoPatBinds   -- Experimentally, I'm making this non-standard
802                          -- behaviour the default, to see if anyone notices
803                          -- SLPJ July 06
804       -- In due course I'd like Opt_MonoLocalBinds to be on by default
805       -- SLPJ September 2010
806     : languageExtensions (Just Haskell2010)
807 languageExtensions (Just Haskell98)
808     = [Opt_ImplicitPrelude,
809        Opt_MonomorphismRestriction,
810        Opt_NPlusKPatterns,
811        Opt_DatatypeContexts]
812 languageExtensions (Just Haskell2010)
813     = [Opt_ImplicitPrelude,
814        Opt_MonomorphismRestriction,
815        Opt_DatatypeContexts,
816        Opt_EmptyDataDecls,
817        Opt_ForeignFunctionInterface,
818        Opt_PatternGuards,
819        Opt_DoAndIfThenElse,
820        Opt_RelaxedPolyRec]
821
822 -- | Test whether a 'DynFlag' is set
823 dopt :: DynFlag -> DynFlags -> Bool
824 dopt f dflags  = f `elem` (flags dflags)
825
826 -- | Set a 'DynFlag'
827 dopt_set :: DynFlags -> DynFlag -> DynFlags
828 dopt_set dfs f = dfs{ flags = f : flags dfs }
829
830 -- | Unset a 'DynFlag'
831 dopt_unset :: DynFlags -> DynFlag -> DynFlags
832 dopt_unset dfs f = dfs{ flags = filter (/= f) (flags dfs) }
833
834 -- | Test whether a 'ExtensionFlag' is set
835 xopt :: ExtensionFlag -> DynFlags -> Bool
836 xopt f dflags = case extensionFlags dflags of
837                 Left _ -> panic ("Testing for extension flag " ++ show f ++ " before flattening")
838                 Right flags -> f `elem` flags
839
840 -- | Set a 'ExtensionFlag'
841 xopt_set :: DynFlags -> ExtensionFlag -> DynFlags
842 xopt_set dfs f = case extensionFlags dfs of
843                  Left onoffs -> dfs { extensionFlags = Left (On f : onoffs) }
844                  Right _ -> panic ("Setting extension flag " ++ show f ++ " after flattening")
845
846 -- | Set a 'ExtensionFlag'
847 xopt_set_flattened :: DynFlags -> ExtensionFlag -> DynFlags
848 xopt_set_flattened dfs f = case extensionFlags dfs of
849                            Left _ ->
850                                panic ("Setting extension flag " ++ show f ++ " before flattening, but expected flattened")
851                            Right flags ->
852                                dfs { extensionFlags = Right (f : delete f flags) }
853
854 -- | Unset a 'ExtensionFlag'
855 xopt_unset :: DynFlags -> ExtensionFlag -> DynFlags
856 xopt_unset dfs f = case extensionFlags dfs of
857                    Left onoffs -> dfs { extensionFlags = Left (Off f : onoffs) }
858                    Right _ -> panic ("Unsetting extension flag " ++ show f ++ " after flattening")
859
860 -- | Unset a 'ExtensionFlag'
861 xopt_unset_flattened :: DynFlags -> ExtensionFlag -> DynFlags
862 xopt_unset_flattened dfs f = case extensionFlags dfs of
863                              Left _ ->
864                                  panic ("Unsetting extension flag " ++ show f ++ " before flattening, but expected flattened")
865                              Right flags ->
866                                  dfs { extensionFlags = Right (delete f flags) }
867
868 -- | Retrieve the options corresponding to a particular @opt_*@ field in the correct order
869 getOpts :: DynFlags             -- ^ 'DynFlags' to retrieve the options from
870         -> (DynFlags -> [a])    -- ^ Relevant record accessor: one of the @opt_*@ accessors
871         -> [a]                  -- ^ Correctly ordered extracted options
872 getOpts dflags opts = reverse (opts dflags)
873         -- We add to the options from the front, so we need to reverse the list
874
875 -- | Gets the verbosity flag for the current verbosity level. This is fed to
876 -- other tools, so GHC-specific verbosity flags like @-ddump-most@ are not included
877 getVerbFlag :: DynFlags -> String
878 getVerbFlag dflags
879   | verbosity dflags >= 3  = "-v"
880   | otherwise =  ""
881
882 setObjectDir, setHiDir, setStubDir, setOutputDir, setDylibInstallName,
883          setObjectSuf, setHiSuf, setHcSuf, parseDynLibLoaderMode,
884          setPgmP, addOptl, addOptP,
885          addCmdlineFramework, addHaddockOpts
886    :: String -> DynFlags -> DynFlags
887 setOutputFile, setOutputHi, setDumpPrefixForce
888    :: Maybe String -> DynFlags -> DynFlags
889
890 setObjectDir  f d = d{ objectDir  = Just f}
891 setHiDir      f d = d{ hiDir      = Just f}
892 setStubDir    f d = d{ stubDir    = Just f, includePaths = f : includePaths d }
893   -- -stubdir D adds an implicit -I D, so that gcc can find the _stub.h file
894   -- \#included from the .hc file when compiling with -fvia-C.
895 setOutputDir  f = setObjectDir f . setHiDir f . setStubDir f
896 setDylibInstallName  f d = d{ dylibInstallName = Just f}
897
898 setObjectSuf  f d = d{ objectSuf  = f}
899 setHiSuf      f d = d{ hiSuf      = f}
900 setHcSuf      f d = d{ hcSuf      = f}
901
902 setOutputFile f d = d{ outputFile = f}
903 setOutputHi   f d = d{ outputHi   = f}
904
905 parseDynLibLoaderMode f d =
906  case splitAt 8 f of
907    ("deploy", "")       -> d{ dynLibLoader = Deployable }
908    ("sysdep", "")       -> d{ dynLibLoader = SystemDependent }
909    _                    -> ghcError (CmdLineError ("Unknown dynlib loader: " ++ f))
910
911 setDumpPrefixForce f d = d { dumpPrefixForce = f}
912
913 -- XXX HACK: Prelude> words "'does not' work" ===> ["'does","not'","work"]
914 -- Config.hs should really use Option.
915 setPgmP   f d = let (pgm:args) = words f in d{ pgm_P   = (pgm, map Option args)}
916 addOptl   f d = d{ opt_l   = f : opt_l d}
917 addOptP   f d = d{ opt_P   = f : opt_P d}
918
919
920 setDepMakefile :: FilePath -> DynFlags -> DynFlags
921 setDepMakefile f d = d { depMakefile = deOptDep f }
922
923 setDepIncludePkgDeps :: Bool -> DynFlags -> DynFlags
924 setDepIncludePkgDeps b d = d { depIncludePkgDeps = b }
925
926 addDepExcludeMod :: String -> DynFlags -> DynFlags
927 addDepExcludeMod m d
928     = d { depExcludeMods = mkModuleName (deOptDep m) : depExcludeMods d }
929
930 addDepSuffix :: FilePath -> DynFlags -> DynFlags
931 addDepSuffix s d = d { depSuffixes = deOptDep s : depSuffixes d }
932
933 -- XXX Legacy code:
934 -- We used to use "-optdep-flag -optdeparg", so for legacy applications
935 -- we need to strip the "-optdep" off of the arg
936 deOptDep :: String -> String
937 deOptDep x = case stripPrefix "-optdep" x of
938              Just rest -> rest
939              Nothing -> x
940
941 addCmdlineFramework f d = d{ cmdlineFrameworks = f : cmdlineFrameworks d}
942
943 addHaddockOpts f d = d{ haddockOptions = Just f}
944
945 -- -----------------------------------------------------------------------------
946 -- Command-line options
947
948 -- | When invoking external tools as part of the compilation pipeline, we
949 -- pass these a sequence of options on the command-line. Rather than
950 -- just using a list of Strings, we use a type that allows us to distinguish
951 -- between filepaths and 'other stuff'. The reason for this is that
952 -- this type gives us a handle on transforming filenames, and filenames only,
953 -- to whatever format they're expected to be on a particular platform.
954 data Option
955  = FileOption -- an entry that _contains_ filename(s) / filepaths.
956               String  -- a non-filepath prefix that shouldn't be
957                       -- transformed (e.g., "/out=")
958               String  -- the filepath/filename portion
959  | Option     String
960
961 showOpt :: Option -> String
962 showOpt (FileOption pre f) = pre ++ f
963 showOpt (Option s)  = s
964
965 -----------------------------------------------------------------------------
966 -- Setting the optimisation level
967
968 updOptLevel :: Int -> DynFlags -> DynFlags
969 -- ^ Sets the 'DynFlags' to be appropriate to the optimisation level
970 updOptLevel n dfs
971   = dfs2{ optLevel = final_n }
972   where
973    final_n = max 0 (min 2 n)    -- Clamp to 0 <= n <= 2
974    dfs1 = foldr (flip dopt_unset) dfs  remove_dopts
975    dfs2 = foldr (flip dopt_set)   dfs1 extra_dopts
976
977    extra_dopts  = [ f | (ns,f) <- optLevelFlags, final_n `elem` ns ]
978    remove_dopts = [ f | (ns,f) <- optLevelFlags, final_n `notElem` ns ]
979
980 -- -----------------------------------------------------------------------------
981 -- StgToDo:  abstraction of stg-to-stg passes to run.
982
983 data StgToDo
984   = StgDoMassageForProfiling  -- should be (next to) last
985   -- There's also setStgVarInfo, but its absolute "lastness"
986   -- is so critical that it is hardwired in (no flag).
987   | D_stg_stats
988
989 getStgToDo :: DynFlags -> [StgToDo]
990 getStgToDo dflags
991   = todo2
992   where
993         stg_stats = dopt Opt_StgStats dflags
994
995         todo1 = if stg_stats then [D_stg_stats] else []
996
997         todo2 | WayProf `elem` wayNames dflags
998               = StgDoMassageForProfiling : todo1
999               | otherwise
1000               = todo1
1001
1002 {- **********************************************************************
1003 %*                                                                      *
1004                 DynFlags parser
1005 %*                                                                      *
1006 %********************************************************************* -}
1007
1008 -- -----------------------------------------------------------------------------
1009 -- Parsing the dynamic flags.
1010
1011 -- | Parse dynamic flags from a list of command line arguments.  Returns the
1012 -- the parsed 'DynFlags', the left-over arguments, and a list of warnings.
1013 -- Throws a 'UsageError' if errors occurred during parsing (such as unknown
1014 -- flags or missing arguments).
1015 parseDynamicFlags :: Monad m =>
1016                      DynFlags -> [Located String]
1017                   -> m (DynFlags, [Located String], [Located String])
1018                      -- ^ Updated 'DynFlags', left-over arguments, and
1019                      -- list of warnings.
1020 parseDynamicFlags dflags args = parseDynamicFlags_ dflags args True
1021
1022 -- | Like 'parseDynamicFlags' but does not allow the package flags (-package,
1023 -- -hide-package, -ignore-package, -hide-all-packages, -package-conf).
1024 parseDynamicNoPackageFlags :: Monad m =>
1025                      DynFlags -> [Located String]
1026                   -> m (DynFlags, [Located String], [Located String])
1027                      -- ^ Updated 'DynFlags', left-over arguments, and
1028                      -- list of warnings.
1029 parseDynamicNoPackageFlags dflags args = parseDynamicFlags_ dflags args False
1030
1031 parseDynamicFlags_ :: Monad m =>
1032                       DynFlags -> [Located String] -> Bool
1033                   -> m (DynFlags, [Located String], [Located String])
1034 parseDynamicFlags_ dflags0 args pkg_flags = do
1035   -- XXX Legacy support code
1036   -- We used to accept things like
1037   --     optdep-f  -optdepdepend
1038   --     optdep-f  -optdep depend
1039   --     optdep -f -optdepdepend
1040   --     optdep -f -optdep depend
1041   -- but the spaces trip up proper argument handling. So get rid of them.
1042   let f (L p "-optdep" : L _ x : xs) = (L p ("-optdep" ++ x)) : f xs
1043       f (x : xs) = x : f xs
1044       f xs = xs
1045       args' = f args
1046
1047       -- Note: -ignore-package (package_flags) must precede -i* (dynamic_flags)
1048       flag_spec | pkg_flags = package_flags ++ dynamic_flags
1049                 | otherwise = dynamic_flags
1050
1051   let ((leftover, errs, warns), dflags1)
1052           = runCmdLine (processArgs flag_spec args') dflags0
1053   when (not (null errs)) $ ghcError $ errorsToGhcException errs
1054
1055   -- Cannot use -fPIC with registerised -fvia-C, because the mangler
1056   -- isn't up to the job.  We know that if hscTarget == HscC, then the
1057   -- user has explicitly used -fvia-C, because -fasm is the default,
1058   -- unless there is no NCG on this platform.  The latter case is
1059   -- checked when the -fPIC flag is parsed.
1060   --
1061   let (pic_warns, dflags2)
1062         | opt_PIC && hscTarget dflags1 == HscC && cGhcUnregisterised == "NO"
1063         = ([L noSrcSpan $ "Warning: -fvia-C is incompatible with -fPIC; ignoring -fvia-C"],
1064                 dflags1{ hscTarget = HscAsm })
1065 #if !(x86_64_TARGET_ARCH && linux_TARGET_OS)
1066         | (not opt_Static || opt_PIC) && hscTarget dflags1 == HscLlvm
1067         = ([L noSrcSpan $ "Warning: -fllvm is incompatible with -fPIC and -"
1068                 ++ "dynamic on this platform;\n              ignoring -fllvm"],
1069                 dflags1{ hscTarget = HscAsm })
1070 #endif
1071         | otherwise = ([], dflags1)
1072
1073   return (dflags2, leftover, pic_warns ++ warns)
1074
1075
1076 {- **********************************************************************
1077 %*                                                                      *
1078                 DynFlags specifications
1079 %*                                                                      *
1080 %********************************************************************* -}
1081
1082 allFlags :: [String]
1083 allFlags = map ('-':) $
1084            [ flagName flag | flag <- dynamic_flags, ok (flagOptKind flag) ] ++
1085            map ("fno-"++) flags ++
1086            map ("f"++) flags ++
1087            map ("f"++) flags' ++
1088            map ("X"++) supportedExtensions
1089     where ok (PrefixPred _ _) = False
1090           ok _ = True
1091           flags = [ name | (name, _, _) <- fFlags ]
1092           flags' = [ name | (name, _, _) <- fLangFlags ]
1093
1094 --------------- The main flags themselves ------------------
1095 dynamic_flags :: [Flag (CmdLineP DynFlags)]
1096 dynamic_flags = [
1097     Flag "n"        (NoArg (setDynFlag Opt_DryRun))
1098   , Flag "cpp"      (NoArg (setExtensionFlag Opt_Cpp)) 
1099   , Flag "F"        (NoArg (setDynFlag Opt_Pp)) 
1100   , Flag "#include" 
1101          (HasArg (\s -> do { addCmdlineHCInclude s
1102                            ; addWarn "-#include and INCLUDE pragmas are deprecated: They no longer have any effect" }))
1103   , Flag "v"        (OptIntSuffix setVerbosity)
1104
1105         ------- Specific phases  --------------------------------------------
1106     -- need to appear before -pgmL to be parsed as LLVM flags.
1107   , Flag "pgmlo"          (hasArg (\f d -> d{ pgm_lo  = (f,[])}))
1108   , Flag "pgmlc"          (hasArg (\f d -> d{ pgm_lc  = (f,[])}))
1109   , Flag "pgmL"           (hasArg (\f d -> d{ pgm_L   = f}))
1110   , Flag "pgmP"           (hasArg setPgmP)
1111   , Flag "pgmF"           (hasArg (\f d -> d{ pgm_F   = f}))
1112   , Flag "pgmc"           (hasArg (\f d -> d{ pgm_c   = (f,[])}))
1113   , Flag "pgmm"           (hasArg (\f d -> d{ pgm_m   = (f,[])}))
1114   , Flag "pgms"           (hasArg (\f d -> d{ pgm_s   = (f,[])}))
1115   , Flag "pgma"           (hasArg (\f d -> d{ pgm_a   = (f,[])}))
1116   , Flag "pgml"           (hasArg (\f d -> d{ pgm_l   = (f,[])}))
1117   , Flag "pgmdll"         (hasArg (\f d -> d{ pgm_dll = (f,[])}))
1118   , Flag "pgmwindres"     (hasArg (\f d -> d{ pgm_windres = f}))
1119
1120     -- need to appear before -optl/-opta to be parsed as LLVM flags.
1121   , Flag "optlo"          (hasArg (\f d -> d{ opt_lo  = f : opt_lo d}))
1122   , Flag "optlc"          (hasArg (\f d -> d{ opt_lc  = f : opt_lc d}))
1123   , Flag "optL"           (hasArg (\f d -> d{ opt_L   = f : opt_L d}))
1124   , Flag "optP"           (hasArg addOptP)
1125   , Flag "optF"           (hasArg (\f d -> d{ opt_F   = f : opt_F d}))
1126   , Flag "optc"           (hasArg (\f d -> d{ opt_c   = f : opt_c d}))
1127   , Flag "optm"           (hasArg (\f d -> d{ opt_m   = f : opt_m d}))
1128   , Flag "opta"           (hasArg (\f d -> d{ opt_a   = f : opt_a d}))
1129   , Flag "optl"           (hasArg addOptl)
1130   , Flag "optwindres"     (hasArg (\f d -> d{ opt_windres = f : opt_windres d}))
1131
1132   , Flag "split-objs"
1133          (NoArg (if can_split 
1134                  then setDynFlag Opt_SplitObjs
1135                  else addWarn "ignoring -fsplit-objs"))
1136
1137         -------- ghc -M -----------------------------------------------------
1138   , Flag "dep-suffix"     (hasArg addDepSuffix)
1139   , Flag "optdep-s"       (hasArgDF addDepSuffix "Use -dep-suffix instead")
1140   , Flag "dep-makefile"   (hasArg setDepMakefile)
1141   , Flag "optdep-f"       (hasArgDF setDepMakefile "Use -dep-makefile instead")
1142   , Flag "optdep-w"       (NoArg  (deprecate "doesn't do anything"))
1143   , Flag "include-pkg-deps"         (noArg (setDepIncludePkgDeps True))
1144   , Flag "optdep--include-prelude"  (noArgDF (setDepIncludePkgDeps True) "Use -include-pkg-deps instead")
1145   , Flag "optdep--include-pkg-deps" (noArgDF (setDepIncludePkgDeps True) "Use -include-pkg-deps instead")
1146   , Flag "exclude-module"           (hasArg addDepExcludeMod)
1147   , Flag "optdep--exclude-module"   (hasArgDF addDepExcludeMod "Use -exclude-module instead")
1148   , Flag "optdep-x"                 (hasArgDF addDepExcludeMod "Use -exclude-module instead")
1149
1150         -------- Linking ----------------------------------------------------
1151   , Flag "no-link"            (noArg (\d -> d{ ghcLink=NoLink }))
1152   , Flag "shared"             (noArg (\d -> d{ ghcLink=LinkDynLib }))
1153   , Flag "dynload"            (hasArg parseDynLibLoaderMode)
1154   , Flag "dylib-install-name" (hasArg setDylibInstallName)
1155
1156         ------- Libraries ---------------------------------------------------
1157   , Flag "L"   (Prefix    addLibraryPath)
1158   , Flag "l"   (AnySuffix (upd . addOptl))
1159
1160         ------- Frameworks --------------------------------------------------
1161         -- -framework-path should really be -F ...
1162   , Flag "framework-path" (HasArg addFrameworkPath)
1163   , Flag "framework"      (hasArg addCmdlineFramework)
1164
1165         ------- Output Redirection ------------------------------------------
1166   , Flag "odir"              (hasArg setObjectDir)
1167   , Flag "o"                 (SepArg (upd . setOutputFile . Just))
1168   , Flag "ohi"               (hasArg (setOutputHi . Just ))
1169   , Flag "osuf"              (hasArg setObjectSuf)
1170   , Flag "hcsuf"             (hasArg setHcSuf)
1171   , Flag "hisuf"             (hasArg setHiSuf)
1172   , Flag "hidir"             (hasArg setHiDir)
1173   , Flag "tmpdir"            (hasArg setTmpDir)
1174   , Flag "stubdir"           (hasArg setStubDir)
1175   , Flag "outputdir"         (hasArg setOutputDir)
1176   , Flag "ddump-file-prefix" (hasArg (setDumpPrefixForce . Just))
1177
1178         ------- Keeping temporary files -------------------------------------
1179      -- These can be singular (think ghc -c) or plural (think ghc --make)
1180   , Flag "keep-hc-file"     (NoArg (setDynFlag Opt_KeepHcFiles))
1181   , Flag "keep-hc-files"    (NoArg (setDynFlag Opt_KeepHcFiles))
1182   , Flag "keep-s-file"      (NoArg (setDynFlag Opt_KeepSFiles))
1183   , Flag "keep-s-files"     (NoArg (setDynFlag Opt_KeepSFiles))
1184   , Flag "keep-raw-s-file"  (NoArg (setDynFlag Opt_KeepRawSFiles))
1185   , Flag "keep-raw-s-files" (NoArg (setDynFlag Opt_KeepRawSFiles))
1186   , Flag "keep-llvm-file"   (NoArg (setDynFlag Opt_KeepLlvmFiles))
1187   , Flag "keep-llvm-files"  (NoArg (setDynFlag Opt_KeepLlvmFiles))
1188      -- This only makes sense as plural
1189   , Flag "keep-tmp-files"   (NoArg (setDynFlag Opt_KeepTmpFiles))
1190
1191         ------- Miscellaneous ----------------------------------------------
1192   , Flag "no-auto-link-packages" (NoArg (unSetDynFlag Opt_AutoLinkPackages))
1193   , Flag "no-hs-main"     (NoArg (setDynFlag Opt_NoHsMain))
1194   , Flag "with-rtsopts"   (HasArg setRtsOpts)
1195   , Flag "rtsopts"        (NoArg (setRtsOptsEnabled RtsOptsAll))
1196   , Flag "rtsopts=all"    (NoArg (setRtsOptsEnabled RtsOptsAll))
1197   , Flag "rtsopts=some"   (NoArg (setRtsOptsEnabled RtsOptsSafeOnly))
1198   , Flag "rtsopts=none"   (NoArg (setRtsOptsEnabled RtsOptsNone))
1199   , Flag "no-rtsopts"     (NoArg (setRtsOptsEnabled RtsOptsNone))
1200   , Flag "main-is"        (SepArg setMainIs)
1201   , Flag "haddock"        (NoArg (setDynFlag Opt_Haddock))
1202   , Flag "haddock-opts"   (hasArg addHaddockOpts)
1203   , Flag "hpcdir"         (SepArg setOptHpcDir)
1204
1205         ------- recompilation checker --------------------------------------
1206   , Flag "recomp"         (NoArg (do { unSetDynFlag Opt_ForceRecomp
1207                                      ; deprecate "Use -fno-force-recomp instead" }))
1208   , Flag "no-recomp"      (NoArg (do { setDynFlag Opt_ForceRecomp
1209                                      ; deprecate "Use -fforce-recomp instead" }))
1210
1211         ------ HsCpp opts ---------------------------------------------------
1212   , Flag "D"              (AnySuffix (upd . addOptP))
1213   , Flag "U"              (AnySuffix (upd . addOptP))
1214
1215         ------- Include/Import Paths ----------------------------------------
1216   , Flag "I"              (Prefix    addIncludePath)
1217   , Flag "i"              (OptPrefix addImportPath)
1218
1219         ------ Debugging ----------------------------------------------------
1220   , Flag "dstg-stats"     (NoArg (setDynFlag Opt_StgStats))
1221
1222   , Flag "ddump-cmm"               (setDumpFlag Opt_D_dump_cmm)
1223   , Flag "ddump-cmmz"              (setDumpFlag Opt_D_dump_cmmz)
1224   , Flag "ddump-cmmz-pretty"       (setDumpFlag Opt_D_dump_cmmz_pretty)
1225   , Flag "ddump-cps-cmm"           (setDumpFlag Opt_D_dump_cps_cmm)
1226   , Flag "ddump-cvt-cmm"           (setDumpFlag Opt_D_dump_cvt_cmm)
1227   , Flag "ddump-asm"               (setDumpFlag Opt_D_dump_asm)
1228   , Flag "ddump-asm-native"        (setDumpFlag Opt_D_dump_asm_native)
1229   , Flag "ddump-asm-liveness"      (setDumpFlag Opt_D_dump_asm_liveness)
1230   , Flag "ddump-asm-coalesce"      (setDumpFlag Opt_D_dump_asm_coalesce)
1231   , Flag "ddump-asm-regalloc"      (setDumpFlag Opt_D_dump_asm_regalloc)
1232   , Flag "ddump-asm-conflicts"     (setDumpFlag Opt_D_dump_asm_conflicts)
1233   , Flag "ddump-asm-regalloc-stages" (setDumpFlag Opt_D_dump_asm_regalloc_stages)
1234   , Flag "ddump-asm-stats"         (setDumpFlag Opt_D_dump_asm_stats)
1235   , Flag "ddump-asm-expanded"      (setDumpFlag Opt_D_dump_asm_expanded)
1236   , Flag "ddump-llvm"              (NoArg (do { setObjTarget HscLlvm
1237                                               ; setDumpFlag' Opt_D_dump_llvm}))
1238   , Flag "ddump-cpranal"           (setDumpFlag Opt_D_dump_cpranal)
1239   , Flag "ddump-deriv"             (setDumpFlag Opt_D_dump_deriv)
1240   , Flag "ddump-ds"                (setDumpFlag Opt_D_dump_ds)
1241   , Flag "ddump-flatC"             (setDumpFlag Opt_D_dump_flatC)
1242   , Flag "ddump-foreign"           (setDumpFlag Opt_D_dump_foreign)
1243   , Flag "ddump-inlinings"         (setDumpFlag Opt_D_dump_inlinings)
1244   , Flag "ddump-rule-firings"      (setDumpFlag Opt_D_dump_rule_firings)
1245   , Flag "ddump-occur-anal"        (setDumpFlag Opt_D_dump_occur_anal)
1246   , Flag "ddump-parsed"            (setDumpFlag Opt_D_dump_parsed)
1247   , Flag "ddump-rn"                (setDumpFlag Opt_D_dump_rn)
1248   , Flag "ddump-simpl"             (setDumpFlag Opt_D_dump_simpl)
1249   , Flag "ddump-simpl-iterations"  (setDumpFlag Opt_D_dump_simpl_iterations)
1250   , Flag "ddump-simpl-phases"      (OptPrefix setDumpSimplPhases)
1251   , Flag "ddump-spec"              (setDumpFlag Opt_D_dump_spec)
1252   , Flag "ddump-prep"              (setDumpFlag Opt_D_dump_prep)
1253   , Flag "ddump-stg"               (setDumpFlag Opt_D_dump_stg)
1254   , Flag "ddump-stranal"           (setDumpFlag Opt_D_dump_stranal)
1255   , Flag "ddump-tc"                (setDumpFlag Opt_D_dump_tc)
1256   , Flag "ddump-types"             (setDumpFlag Opt_D_dump_types)
1257   , Flag "ddump-rules"             (setDumpFlag Opt_D_dump_rules)
1258   , Flag "ddump-cse"               (setDumpFlag Opt_D_dump_cse)
1259   , Flag "ddump-worker-wrapper"    (setDumpFlag Opt_D_dump_worker_wrapper)
1260   , Flag "ddump-rn-trace"          (setDumpFlag Opt_D_dump_rn_trace)
1261   , Flag "ddump-if-trace"          (setDumpFlag Opt_D_dump_if_trace)
1262   , Flag "ddump-tc-trace"          (setDumpFlag Opt_D_dump_tc_trace)
1263   , Flag "ddump-splices"           (setDumpFlag Opt_D_dump_splices)
1264   , Flag "ddump-rn-stats"          (setDumpFlag Opt_D_dump_rn_stats)
1265   , Flag "ddump-opt-cmm"           (setDumpFlag Opt_D_dump_opt_cmm)
1266   , Flag "ddump-simpl-stats"       (setDumpFlag Opt_D_dump_simpl_stats)
1267   , Flag "ddump-bcos"              (setDumpFlag Opt_D_dump_BCOs)
1268   , Flag "dsource-stats"           (setDumpFlag Opt_D_source_stats)
1269   , Flag "dverbose-core2core"      (NoArg (do { setVerbosity (Just 2)
1270                                               ; setVerboseCore2Core }))
1271   , Flag "dverbose-stg2stg"        (setDumpFlag Opt_D_verbose_stg2stg)
1272   , Flag "ddump-hi"                (setDumpFlag Opt_D_dump_hi)
1273   , Flag "ddump-minimal-imports"   (setDumpFlag Opt_D_dump_minimal_imports)
1274   , Flag "ddump-vect"              (setDumpFlag Opt_D_dump_vect)
1275   , Flag "ddump-hpc"               (setDumpFlag Opt_D_dump_hpc)
1276   , Flag "ddump-mod-cycles"        (setDumpFlag Opt_D_dump_mod_cycles)
1277   , Flag "ddump-view-pattern-commoning" (setDumpFlag Opt_D_dump_view_pattern_commoning)
1278   , Flag "ddump-to-file"           (setDumpFlag Opt_DumpToFile)
1279   , Flag "ddump-hi-diffs"          (setDumpFlag Opt_D_dump_hi_diffs)
1280   , Flag "ddump-rtti"              (setDumpFlag Opt_D_dump_rtti)
1281   , Flag "dcore-lint"              (NoArg (setDynFlag Opt_DoCoreLinting))
1282   , Flag "dstg-lint"               (NoArg (setDynFlag Opt_DoStgLinting))
1283   , Flag "dcmm-lint"               (NoArg (setDynFlag Opt_DoCmmLinting))
1284   , Flag "dasm-lint"               (NoArg (setDynFlag Opt_DoAsmLinting))
1285   , Flag "dshow-passes"            (NoArg (do forceRecompile
1286                                               setVerbosity (Just 2)))
1287   , Flag "dfaststring-stats"       (NoArg (setDynFlag Opt_D_faststring_stats))
1288
1289         ------ Machine dependant (-m<blah>) stuff ---------------------------
1290
1291   , Flag "monly-2-regs" (noArg (\s -> s{stolen_x86_regs = 2}))
1292   , Flag "monly-3-regs" (noArg (\s -> s{stolen_x86_regs = 3}))
1293   , Flag "monly-4-regs" (noArg (\s -> s{stolen_x86_regs = 4}))
1294   , Flag "msse2"        (NoArg (setDynFlag Opt_SSE2))
1295
1296      ------ Warning opts -------------------------------------------------
1297   , Flag "W"      (NoArg (mapM_ setDynFlag   minusWOpts))
1298   , Flag "Werror" (NoArg (setDynFlag         Opt_WarnIsError))
1299   , Flag "Wwarn"  (NoArg (unSetDynFlag       Opt_WarnIsError))
1300   , Flag "Wall"   (NoArg (mapM_ setDynFlag   minusWallOpts))
1301   , Flag "Wnot"   (NoArg (do { mapM_ unSetDynFlag minusWallOpts
1302                              ; deprecate "Use -w instead" }))
1303   , Flag "w"      (NoArg (mapM_ unSetDynFlag minuswRemovesOpts))
1304
1305         ------ Optimisation flags ------------------------------------------
1306   , Flag "O"      (noArg (setOptLevel 1))
1307   , Flag "Onot"   (noArgDF (setOptLevel 0) "Use -O0 instead")
1308   , Flag "Odph"   (noArg setDPHOpt)
1309   , Flag "O"      (OptIntSuffix (\mb_n -> upd (setOptLevel (mb_n `orElse` 1))))
1310                 -- If the number is missing, use 1
1311
1312   , Flag "fsimplifier-phases"          (intSuffix (\n d -> d{ simplPhases = n }))
1313   , Flag "fmax-simplifier-iterations"  (intSuffix (\n d -> d{ maxSimplIterations = n }))
1314   , Flag "fspec-constr-threshold"      (intSuffix (\n d -> d{ specConstrThreshold = Just n }))
1315   , Flag "fno-spec-constr-threshold"   (noArg (\d -> d{ specConstrThreshold = Nothing }))
1316   , Flag "fspec-constr-count"          (intSuffix (\n d -> d{ specConstrCount = Just n }))
1317   , Flag "fno-spec-constr-count"       (noArg (\d -> d{ specConstrCount = Nothing }))
1318   , Flag "fliberate-case-threshold"    (intSuffix (\n d -> d{ liberateCaseThreshold = Just n }))
1319   , Flag "fno-liberate-case-threshold" (noArg (\d -> d{ liberateCaseThreshold = Nothing }))
1320   , Flag "frule-check"                 (SepArg (\s -> upd (\d -> d{ ruleCheck = Just s })))
1321   , Flag "fcontext-stack"              (intSuffix (\n d -> d{ ctxtStkDepth = n }))
1322   , Flag "fstrictness-before"          (intSuffix (\n d -> d{ strictnessBefore = n : strictnessBefore d }))
1323
1324         ------ Profiling ----------------------------------------------------
1325
1326   -- XXX Should the -f* flags be deprecated?
1327   -- They don't seem to be documented
1328   , Flag "fauto-sccs-on-all-toplevs"       (NoArg (setDynFlag Opt_AutoSccsOnAllToplevs))
1329   , Flag "auto-all"                        (NoArg (setDynFlag Opt_AutoSccsOnAllToplevs))
1330   , Flag "no-auto-all"                     (NoArg (unSetDynFlag Opt_AutoSccsOnAllToplevs))
1331   , Flag "fauto-sccs-on-exported-toplevs"  (NoArg (setDynFlag Opt_AutoSccsOnExportedToplevs))
1332   , Flag "auto"                            (NoArg (setDynFlag Opt_AutoSccsOnExportedToplevs))
1333   , Flag "no-auto"                         (NoArg (unSetDynFlag Opt_AutoSccsOnExportedToplevs))
1334   , Flag "fauto-sccs-on-individual-cafs"   (NoArg (setDynFlag Opt_AutoSccsOnIndividualCafs))
1335   , Flag "caf-all"                         (NoArg (setDynFlag Opt_AutoSccsOnIndividualCafs))
1336   , Flag "no-caf-all"                      (NoArg (unSetDynFlag Opt_AutoSccsOnIndividualCafs))
1337
1338         ------ DPH flags ----------------------------------------------------
1339
1340   , Flag "fdph-seq"         (NoArg (setDPHBackend DPHSeq))
1341   , Flag "fdph-par"         (NoArg (setDPHBackend DPHPar))
1342   , Flag "fdph-this"        (NoArg (setDPHBackend DPHThis))
1343
1344         ------ Compiler flags -----------------------------------------------
1345
1346   , Flag "fasm"             (NoArg (setObjTarget HscAsm))
1347   , Flag "fvia-c"           (NoArg (setObjTarget HscC >>
1348          (addWarn "The -fvia-c flag will be removed in a future GHC release")))
1349   , Flag "fvia-C"           (NoArg (setObjTarget HscC >>
1350          (addWarn "The -fvia-C flag will be removed in a future GHC release")))
1351   , Flag "fllvm"            (NoArg (setObjTarget HscLlvm))
1352
1353   , Flag "fno-code"         (NoArg (do upd $ \d -> d{ ghcLink=NoLink }
1354                                        setTarget HscNothing))
1355   , Flag "fbyte-code"       (NoArg (setTarget HscInterpreted))
1356   , Flag "fobject-code"     (NoArg (setTarget defaultHscTarget))
1357   , Flag "fglasgow-exts"    (NoArg enableGlasgowExts)
1358   , Flag "fno-glasgow-exts" (NoArg disableGlasgowExts)
1359  ]
1360  ++ map (mkFlag True  "f"    setDynFlag  ) fFlags
1361  ++ map (mkFlag False "fno-" unSetDynFlag) fFlags
1362  ++ map (mkFlag True  "f"    setExtensionFlag  ) fLangFlags
1363  ++ map (mkFlag False "fno-" unSetExtensionFlag) fLangFlags
1364  ++ map (mkFlag True  "X"    setExtensionFlag  ) xFlags
1365  ++ map (mkFlag False "XNo"  unSetExtensionFlag) xFlags
1366  ++ map (mkFlag True  "X"    setLanguage) languageFlags
1367
1368 package_flags :: [Flag (CmdLineP DynFlags)]
1369 package_flags = [
1370         ------- Packages ----------------------------------------------------
1371     Flag "package-conf"         (HasArg extraPkgConf_)
1372   , Flag "no-user-package-conf" (NoArg (unSetDynFlag Opt_ReadUserPackageConf))
1373   , Flag "package-name"         (hasArg setPackageName)
1374   , Flag "package-id"           (HasArg exposePackageId)
1375   , Flag "package"              (HasArg exposePackage)
1376   , Flag "hide-package"         (HasArg hidePackage)
1377   , Flag "hide-all-packages"    (NoArg (setDynFlag Opt_HideAllPackages))
1378   , Flag "ignore-package"       (HasArg ignorePackage)
1379   , Flag "syslib"               (HasArg (\s -> do { exposePackage s
1380                                                   ; deprecate "Use -package instead" }))
1381   ]
1382
1383 type FlagSpec flag 
1384    = ( String   -- Flag in string form
1385      , flag     -- Flag in internal form
1386      , Bool -> DynP ())  -- Extra action to run when the flag is found
1387                          -- Typically, emit a warning or error
1388                          -- True  <=> we are turning the flag on
1389                          -- False <=> we are turning the flag off
1390
1391
1392 mkFlag :: Bool                  -- ^ True <=> it should be turned on
1393        -> String                -- ^ The flag prefix
1394        -> (flag -> DynP ())     -- ^ What to do when the flag is found
1395        -> FlagSpec flag         -- ^ Specification of this particular flag
1396        -> Flag (CmdLineP DynFlags)
1397 mkFlag turnOn flagPrefix f (name, flag, extra_action)
1398     = Flag (flagPrefix ++ name) (NoArg (f flag >> extra_action turnOn))
1399
1400 deprecatedForExtension :: String -> Bool -> DynP ()
1401 deprecatedForExtension lang turn_on
1402     = deprecate ("use -X"  ++ flag ++ " or pragma {-# LANGUAGE " ++ flag ++ " #-} instead")
1403     where 
1404       flag | turn_on    = lang
1405            | otherwise = "No"++lang
1406
1407 useInstead :: String -> Bool -> DynP ()
1408 useInstead flag turn_on
1409   = deprecate ("Use -f" ++ no ++ flag ++ " instead")
1410   where
1411     no = if turn_on then "" else "no-"
1412
1413 nop :: Bool -> DynP ()
1414 nop _ = return ()
1415
1416 -- | These @-f\<blah\>@ flags can all be reversed with @-fno-\<blah\>@
1417 fFlags :: [FlagSpec DynFlag]
1418 fFlags = [
1419   ( "warn-dodgy-foreign-imports",       Opt_WarnDodgyForeignImports, nop ),
1420   ( "warn-dodgy-exports",               Opt_WarnDodgyExports, nop ),
1421   ( "warn-dodgy-imports",               Opt_WarnDodgyImports, nop ),
1422   ( "warn-duplicate-exports",           Opt_WarnDuplicateExports, nop ),
1423   ( "warn-hi-shadowing",                Opt_WarnHiShadows, nop ),
1424   ( "warn-implicit-prelude",            Opt_WarnImplicitPrelude, nop ),
1425   ( "warn-incomplete-patterns",         Opt_WarnIncompletePatterns, nop ),
1426   ( "warn-incomplete-record-updates",   Opt_WarnIncompletePatternsRecUpd, nop ),
1427   ( "warn-missing-fields",              Opt_WarnMissingFields, nop ),
1428   ( "warn-missing-import-lists",        Opt_WarnMissingImportList, nop ),
1429   ( "warn-missing-methods",             Opt_WarnMissingMethods, nop ),
1430   ( "warn-missing-signatures",          Opt_WarnMissingSigs, nop ),
1431   ( "warn-missing-local-sigs",          Opt_WarnMissingLocalSigs, nop ),
1432   ( "warn-name-shadowing",              Opt_WarnNameShadowing, nop ),
1433   ( "warn-overlapping-patterns",        Opt_WarnOverlappingPatterns, nop ),
1434   ( "warn-type-defaults",               Opt_WarnTypeDefaults, nop ),
1435   ( "warn-monomorphism-restriction",    Opt_WarnMonomorphism, nop ),
1436   ( "warn-unused-binds",                Opt_WarnUnusedBinds, nop ),
1437   ( "warn-unused-imports",              Opt_WarnUnusedImports, nop ),
1438   ( "warn-unused-matches",              Opt_WarnUnusedMatches, nop ),
1439   ( "warn-warnings-deprecations",       Opt_WarnWarningsDeprecations, nop ),
1440   ( "warn-deprecations",                Opt_WarnWarningsDeprecations, nop ),
1441   ( "warn-deprecated-flags",            Opt_WarnDeprecatedFlags, nop ),
1442   ( "warn-orphans",                     Opt_WarnOrphans, nop ),
1443   ( "warn-tabs",                        Opt_WarnTabs, nop ),
1444   ( "warn-unrecognised-pragmas",        Opt_WarnUnrecognisedPragmas, nop ),
1445   ( "warn-lazy-unlifted-bindings",      Opt_WarnLazyUnliftedBindings, nop),
1446   ( "warn-unused-do-bind",              Opt_WarnUnusedDoBind, nop ),
1447   ( "warn-wrong-do-bind",               Opt_WarnWrongDoBind, nop ),
1448   ( "warn-alternative-layout-rule-transitional", Opt_WarnAlternativeLayoutRuleTransitional, nop ),
1449   ( "print-explicit-foralls",           Opt_PrintExplicitForalls, nop ),
1450   ( "strictness",                       Opt_Strictness, nop ),
1451   ( "specialise",                       Opt_Specialise, nop ),
1452   ( "float-in",                         Opt_FloatIn, nop ),
1453   ( "static-argument-transformation",   Opt_StaticArgumentTransformation, nop ),
1454   ( "full-laziness",                    Opt_FullLaziness, nop ),
1455   ( "liberate-case",                    Opt_LiberateCase, nop ),
1456   ( "spec-constr",                      Opt_SpecConstr, nop ),
1457   ( "cse",                              Opt_CSE, nop ),
1458   ( "ignore-interface-pragmas",         Opt_IgnoreInterfacePragmas, nop ),
1459   ( "omit-interface-pragmas",           Opt_OmitInterfacePragmas, nop ),
1460   ( "expose-all-unfoldings",            Opt_ExposeAllUnfoldings, nop ),
1461   ( "do-lambda-eta-expansion",          Opt_DoLambdaEtaExpansion, nop ),
1462   ( "ignore-asserts",                   Opt_IgnoreAsserts, nop ),
1463   ( "do-eta-reduction",                 Opt_DoEtaReduction, nop ),
1464   ( "case-merge",                       Opt_CaseMerge, nop ),
1465   ( "unbox-strict-fields",              Opt_UnboxStrictFields, nop ),
1466   ( "method-sharing",                   Opt_MethodSharing, nop ),
1467   ( "dicts-cheap",                      Opt_DictsCheap, nop ),
1468   ( "excess-precision",                 Opt_ExcessPrecision, nop ),
1469   ( "eager-blackholing",                Opt_EagerBlackHoling, nop ),
1470   ( "asm-mangling",                     Opt_DoAsmMangling, nop ),
1471   ( "print-bind-result",                Opt_PrintBindResult, nop ),
1472   ( "force-recomp",                     Opt_ForceRecomp, nop ),
1473   ( "hpc-no-auto",                      Opt_Hpc_No_Auto, nop ),
1474   ( "rewrite-rules",                    Opt_EnableRewriteRules, useInstead "enable-rewrite-rules" ),
1475   ( "enable-rewrite-rules",             Opt_EnableRewriteRules, nop ),
1476   ( "break-on-exception",               Opt_BreakOnException, nop ),
1477   ( "break-on-error",                   Opt_BreakOnError, nop ),
1478   ( "print-evld-with-show",             Opt_PrintEvldWithShow, nop ),
1479   ( "print-bind-contents",              Opt_PrintBindContents, nop ),
1480   ( "run-cps",                          Opt_RunCPS, nop ),
1481   ( "run-cpsz",                         Opt_RunCPSZ, nop ),
1482   ( "new-codegen",                      Opt_TryNewCodeGen, nop ),
1483   ( "convert-to-zipper-and-back",       Opt_ConvertToZipCfgAndBack, nop ),
1484   ( "vectorise",                        Opt_Vectorise, nop ),
1485   ( "regs-graph",                       Opt_RegsGraph, nop ),
1486   ( "regs-iterative",                   Opt_RegsIterative, nop ),
1487   ( "gen-manifest",                     Opt_GenManifest, nop ),
1488   ( "embed-manifest",                   Opt_EmbedManifest, nop ),
1489   ( "ext-core",                         Opt_EmitExternalCore, nop ),
1490   ( "shared-implib",                    Opt_SharedImplib, nop ),
1491   ( "building-cabal-package",           Opt_BuildingCabalPackage, nop ),
1492   ( "implicit-import-qualified",        Opt_ImplicitImportQualified, nop )
1493   ]
1494
1495 -- | These @-f\<blah\>@ flags can all be reversed with @-fno-\<blah\>@
1496 fLangFlags :: [FlagSpec ExtensionFlag]
1497 fLangFlags = [
1498   ( "th",                               Opt_TemplateHaskell,
1499     deprecatedForExtension "TemplateHaskell" >> checkTemplateHaskellOk ),
1500   ( "fi",                               Opt_ForeignFunctionInterface,
1501     deprecatedForExtension "ForeignFunctionInterface" ),
1502   ( "ffi",                              Opt_ForeignFunctionInterface,
1503     deprecatedForExtension "ForeignFunctionInterface" ),
1504   ( "arrows",                           Opt_Arrows,
1505     deprecatedForExtension "Arrows" ),
1506   ( "generics",                         Opt_Generics,
1507     deprecatedForExtension "Generics" ),
1508   ( "implicit-prelude",                 Opt_ImplicitPrelude,
1509     deprecatedForExtension "ImplicitPrelude" ),
1510   ( "bang-patterns",                    Opt_BangPatterns,
1511     deprecatedForExtension "BangPatterns" ),
1512   ( "monomorphism-restriction",         Opt_MonomorphismRestriction,
1513     deprecatedForExtension "MonomorphismRestriction" ),
1514   ( "mono-pat-binds",                   Opt_MonoPatBinds,
1515     deprecatedForExtension "MonoPatBinds" ),
1516   ( "extended-default-rules",           Opt_ExtendedDefaultRules,
1517     deprecatedForExtension "ExtendedDefaultRules" ),
1518   ( "implicit-params",                  Opt_ImplicitParams,
1519     deprecatedForExtension "ImplicitParams" ),
1520   ( "scoped-type-variables",            Opt_ScopedTypeVariables,
1521     deprecatedForExtension "ScopedTypeVariables" ),
1522   ( "parr",                             Opt_PArr,
1523     deprecatedForExtension "PArr" ),
1524   ( "allow-overlapping-instances",      Opt_OverlappingInstances,
1525     deprecatedForExtension "OverlappingInstances" ),
1526   ( "allow-undecidable-instances",      Opt_UndecidableInstances,
1527     deprecatedForExtension "UndecidableInstances" ),
1528   ( "allow-incoherent-instances",       Opt_IncoherentInstances,
1529     deprecatedForExtension "IncoherentInstances" )
1530   ]
1531
1532 supportedLanguages :: [String]
1533 supportedLanguages = [ name | (name, _, _) <- languageFlags ]
1534
1535 supportedExtensions :: [String]
1536 supportedExtensions = [ name' | (name, _, _) <- xFlags, name' <- [name, "No" ++ name] ]
1537
1538 supportedLanguagesAndExtensions :: [String]
1539 supportedLanguagesAndExtensions = supportedLanguages ++ supportedExtensions
1540
1541 -- | These -X<blah> flags cannot be reversed with -XNo<blah>
1542 languageFlags :: [FlagSpec Language]
1543 languageFlags = [
1544   ( "Haskell98",                        Haskell98, nop ),
1545   ( "Haskell2010",                      Haskell2010, nop )
1546   ]
1547
1548 -- | These -X<blah> flags can all be reversed with -XNo<blah>
1549 xFlags :: [FlagSpec ExtensionFlag]
1550 xFlags = [
1551   ( "CPP",                              Opt_Cpp, nop ),
1552   ( "PostfixOperators",                 Opt_PostfixOperators, nop ),
1553   ( "TupleSections",                    Opt_TupleSections, nop ),
1554   ( "PatternGuards",                    Opt_PatternGuards, nop ),
1555   ( "UnicodeSyntax",                    Opt_UnicodeSyntax, nop ),
1556   ( "MagicHash",                        Opt_MagicHash, nop ),
1557   ( "PolymorphicComponents",            Opt_PolymorphicComponents, nop ),
1558   ( "ExistentialQuantification",        Opt_ExistentialQuantification, nop ),
1559   ( "KindSignatures",                   Opt_KindSignatures, nop ),
1560   ( "EmptyDataDecls",                   Opt_EmptyDataDecls, nop ),
1561   ( "ParallelListComp",                 Opt_ParallelListComp, nop ),
1562   ( "TransformListComp",                Opt_TransformListComp, nop ),
1563   ( "ForeignFunctionInterface",         Opt_ForeignFunctionInterface, nop ),
1564   ( "UnliftedFFITypes",                 Opt_UnliftedFFITypes, nop ),
1565   ( "GHCForeignImportPrim",             Opt_GHCForeignImportPrim, nop ),
1566   ( "LiberalTypeSynonyms",              Opt_LiberalTypeSynonyms, nop ),
1567   ( "Rank2Types",                       Opt_Rank2Types, nop ),
1568   ( "RankNTypes",                       Opt_RankNTypes, nop ),
1569   ( "ImpredicativeTypes",               Opt_ImpredicativeTypes, 
1570         \_ -> deprecate "impredicative polymorphism will be simplified or removed in GHC 6.14" ),
1571   ( "TypeOperators",                    Opt_TypeOperators, nop ),
1572   ( "RecursiveDo",                      Opt_RecursiveDo,
1573     deprecatedForExtension "DoRec"),
1574   ( "DoRec",                            Opt_DoRec, nop ),
1575   ( "Arrows",                           Opt_Arrows, nop ),
1576   ( "PArr",                             Opt_PArr, nop ),
1577   ( "TemplateHaskell",                  Opt_TemplateHaskell, checkTemplateHaskellOk ),
1578   ( "QuasiQuotes",                      Opt_QuasiQuotes, nop ),
1579   ( "Generics",                         Opt_Generics, nop ),
1580   ( "ImplicitPrelude",                  Opt_ImplicitPrelude, nop ),
1581   ( "RecordWildCards",                  Opt_RecordWildCards, nop ),
1582   ( "NamedFieldPuns",                   Opt_RecordPuns, nop ),
1583   ( "RecordPuns",                       Opt_RecordPuns,
1584     deprecatedForExtension "NamedFieldPuns" ),
1585   ( "DisambiguateRecordFields",         Opt_DisambiguateRecordFields, nop ),
1586   ( "OverloadedStrings",                Opt_OverloadedStrings, nop ),
1587   ( "GADTs",                            Opt_GADTs, nop ),
1588   ( "ViewPatterns",                     Opt_ViewPatterns, nop ),
1589   ( "TypeFamilies",                     Opt_TypeFamilies, nop ),
1590   ( "BangPatterns",                     Opt_BangPatterns, nop ),
1591   ( "MonomorphismRestriction",          Opt_MonomorphismRestriction, nop ),
1592   ( "NPlusKPatterns",                   Opt_NPlusKPatterns, nop ),
1593   ( "DoAndIfThenElse",                  Opt_DoAndIfThenElse, nop ),
1594   ( "MonoPatBinds",                     Opt_MonoPatBinds, nop ),
1595   ( "ExplicitForAll",                   Opt_ExplicitForAll, nop ),
1596   ( "AlternativeLayoutRule",            Opt_AlternativeLayoutRule, nop ),
1597   ( "AlternativeLayoutRuleTransitional",Opt_AlternativeLayoutRuleTransitional, nop ),
1598   ( "DatatypeContexts",                 Opt_DatatypeContexts, nop ),
1599   ( "MonoLocalBinds",                   Opt_MonoLocalBinds, nop ),
1600   ( "RelaxedPolyRec",                   Opt_RelaxedPolyRec, 
1601     \ turn_on -> if not turn_on 
1602                  then deprecate "You can't turn off RelaxedPolyRec any more"
1603                  else return () ),
1604   ( "ExtendedDefaultRules",             Opt_ExtendedDefaultRules, nop ),
1605   ( "ImplicitParams",                   Opt_ImplicitParams, nop ),
1606   ( "ScopedTypeVariables",              Opt_ScopedTypeVariables, nop ),
1607
1608   ( "PatternSignatures",                Opt_ScopedTypeVariables, 
1609     deprecatedForExtension "ScopedTypeVariables" ),
1610
1611   ( "UnboxedTuples",                    Opt_UnboxedTuples, nop ),
1612   ( "StandaloneDeriving",               Opt_StandaloneDeriving, nop ),
1613   ( "DeriveDataTypeable",               Opt_DeriveDataTypeable, nop ),
1614   ( "DeriveFunctor",                    Opt_DeriveFunctor, nop ),
1615   ( "DeriveTraversable",                Opt_DeriveTraversable, nop ),
1616   ( "DeriveFoldable",                   Opt_DeriveFoldable, nop ),
1617   ( "TypeSynonymInstances",             Opt_TypeSynonymInstances, nop ),
1618   ( "FlexibleContexts",                 Opt_FlexibleContexts, nop ),
1619   ( "FlexibleInstances",                Opt_FlexibleInstances, nop ),
1620   ( "ConstrainedClassMethods",          Opt_ConstrainedClassMethods, nop ),
1621   ( "MultiParamTypeClasses",            Opt_MultiParamTypeClasses, nop ),
1622   ( "FunctionalDependencies",           Opt_FunctionalDependencies, nop ),
1623   ( "GeneralizedNewtypeDeriving",       Opt_GeneralizedNewtypeDeriving, nop ),
1624   ( "OverlappingInstances",             Opt_OverlappingInstances, nop ),
1625   ( "UndecidableInstances",             Opt_UndecidableInstances, nop ),
1626   ( "IncoherentInstances",              Opt_IncoherentInstances, nop ),
1627   ( "PackageImports",                   Opt_PackageImports, nop ),
1628   ( "NewQualifiedOperators",            Opt_NewQualifiedOperators,
1629     \_ -> deprecate "The new qualified operator syntax was rejected by Haskell'" )
1630   ]
1631
1632 defaultFlags :: [DynFlag]
1633 defaultFlags 
1634   = [ Opt_AutoLinkPackages,
1635       Opt_ReadUserPackageConf,
1636
1637       Opt_MethodSharing,
1638
1639       Opt_DoAsmMangling,
1640
1641       Opt_SharedImplib,
1642
1643       Opt_GenManifest,
1644       Opt_EmbedManifest,
1645       Opt_PrintBindContents
1646     ]
1647
1648     ++ [f | (ns,f) <- optLevelFlags, 0 `elem` ns]
1649              -- The default -O0 options
1650
1651     ++ standardWarnings
1652
1653 impliedFlags :: [(ExtensionFlag, ExtensionFlag)]
1654 impliedFlags
1655   = [ (Opt_RankNTypes,                Opt_ExplicitForAll)
1656     , (Opt_Rank2Types,                Opt_ExplicitForAll)
1657     , (Opt_ScopedTypeVariables,       Opt_ExplicitForAll)
1658     , (Opt_LiberalTypeSynonyms,       Opt_ExplicitForAll)
1659     , (Opt_ExistentialQuantification, Opt_ExplicitForAll)
1660     , (Opt_PolymorphicComponents,     Opt_ExplicitForAll)
1661
1662     , (Opt_GADTs,                  Opt_MonoLocalBinds)
1663     , (Opt_TypeFamilies,           Opt_MonoLocalBinds)
1664
1665     , (Opt_TypeFamilies,        Opt_KindSignatures)  -- Type families use kind signatures
1666                                                      -- all over the place
1667
1668     , (Opt_ImpredicativeTypes,  Opt_RankNTypes)
1669
1670         -- Record wild-cards implies field disambiguation
1671         -- Otherwise if you write (C {..}) you may well get
1672         -- stuff like " 'a' not in scope ", which is a bit silly
1673         -- if the compiler has just filled in field 'a' of constructor 'C'
1674     , (Opt_RecordWildCards,     Opt_DisambiguateRecordFields)
1675   ]
1676
1677 optLevelFlags :: [([Int], DynFlag)]
1678 optLevelFlags
1679   = [ ([0],     Opt_IgnoreInterfacePragmas)
1680     , ([0],     Opt_OmitInterfacePragmas)
1681
1682     , ([1,2],   Opt_IgnoreAsserts)
1683     , ([1,2],   Opt_EnableRewriteRules)  -- Off for -O0; see Note [Scoping for Builtin rules]
1684                                          --              in PrelRules
1685     , ([1,2],   Opt_DoEtaReduction)
1686     , ([1,2],   Opt_CaseMerge)
1687     , ([1,2],   Opt_Strictness)
1688     , ([1,2],   Opt_CSE)
1689     , ([1,2],   Opt_FullLaziness)
1690     , ([1,2],   Opt_Specialise)
1691     , ([1,2],   Opt_FloatIn)
1692
1693     , ([2],     Opt_LiberateCase)
1694     , ([2],     Opt_SpecConstr)
1695     , ([2],     Opt_RegsGraph)
1696
1697 --     , ([2],     Opt_StaticArgumentTransformation)
1698 -- Max writes: I think it's probably best not to enable SAT with -O2 for the
1699 -- 6.10 release. The version of SAT in HEAD at the moment doesn't incorporate
1700 -- several improvements to the heuristics, and I'm concerned that without
1701 -- those changes SAT will interfere with some attempts to write "high
1702 -- performance Haskell", as we saw in some posts on Haskell-Cafe earlier
1703 -- this year. In particular, the version in HEAD lacks the tail call
1704 -- criterion, so many things that look like reasonable loops will be
1705 -- turned into functions with extra (unneccesary) thunk creation.
1706
1707     , ([0,1,2], Opt_DoLambdaEtaExpansion)
1708                 -- This one is important for a tiresome reason:
1709                 -- we want to make sure that the bindings for data
1710                 -- constructors are eta-expanded.  This is probably
1711                 -- a good thing anyway, but it seems fragile.
1712     ]
1713
1714 -- -----------------------------------------------------------------------------
1715 -- Standard sets of warning options
1716
1717 standardWarnings :: [DynFlag]
1718 standardWarnings
1719     = [ Opt_WarnWarningsDeprecations,
1720         Opt_WarnDeprecatedFlags,
1721         Opt_WarnUnrecognisedPragmas,
1722         Opt_WarnOverlappingPatterns,
1723         Opt_WarnMissingFields,
1724         Opt_WarnMissingMethods,
1725         Opt_WarnDuplicateExports,
1726         Opt_WarnLazyUnliftedBindings,
1727         Opt_WarnDodgyForeignImports,
1728         Opt_WarnWrongDoBind,
1729         Opt_WarnAlternativeLayoutRuleTransitional
1730       ]
1731
1732 minusWOpts :: [DynFlag]
1733 minusWOpts
1734     = standardWarnings ++
1735       [ Opt_WarnUnusedBinds,
1736         Opt_WarnUnusedMatches,
1737         Opt_WarnUnusedImports,
1738         Opt_WarnIncompletePatterns,
1739         Opt_WarnDodgyExports,
1740         Opt_WarnDodgyImports
1741       ]
1742
1743 minusWallOpts :: [DynFlag]
1744 minusWallOpts
1745     = minusWOpts ++
1746       [ Opt_WarnTypeDefaults,
1747         Opt_WarnNameShadowing,
1748         Opt_WarnMissingSigs,
1749         Opt_WarnHiShadows,
1750         Opt_WarnOrphans,
1751         Opt_WarnUnusedDoBind
1752       ]
1753
1754 -- minuswRemovesOpts should be every warning option
1755 minuswRemovesOpts :: [DynFlag]
1756 minuswRemovesOpts
1757     = minusWallOpts ++
1758       [Opt_WarnImplicitPrelude,
1759        Opt_WarnIncompletePatternsRecUpd,
1760        Opt_WarnMonomorphism,
1761        Opt_WarnUnrecognisedPragmas,
1762        Opt_WarnTabs
1763       ]
1764
1765 enableGlasgowExts :: DynP ()
1766 enableGlasgowExts = do setDynFlag Opt_PrintExplicitForalls
1767                        mapM_ setExtensionFlag glasgowExtsFlags
1768
1769 disableGlasgowExts :: DynP ()
1770 disableGlasgowExts = do unSetDynFlag Opt_PrintExplicitForalls
1771                         mapM_ unSetExtensionFlag glasgowExtsFlags
1772
1773 glasgowExtsFlags :: [ExtensionFlag]
1774 glasgowExtsFlags = [
1775              Opt_ForeignFunctionInterface
1776            , Opt_UnliftedFFITypes
1777            , Opt_GADTs
1778            , Opt_ImplicitParams
1779            , Opt_ScopedTypeVariables
1780            , Opt_UnboxedTuples
1781            , Opt_TypeSynonymInstances
1782            , Opt_StandaloneDeriving
1783            , Opt_DeriveDataTypeable
1784            , Opt_DeriveFunctor
1785            , Opt_DeriveFoldable
1786            , Opt_DeriveTraversable
1787            , Opt_FlexibleContexts
1788            , Opt_FlexibleInstances
1789            , Opt_ConstrainedClassMethods
1790            , Opt_MultiParamTypeClasses
1791            , Opt_FunctionalDependencies
1792            , Opt_MagicHash
1793            , Opt_PolymorphicComponents
1794            , Opt_ExistentialQuantification
1795            , Opt_UnicodeSyntax
1796            , Opt_PostfixOperators
1797            , Opt_PatternGuards
1798            , Opt_LiberalTypeSynonyms
1799            , Opt_RankNTypes
1800            , Opt_TypeOperators
1801            , Opt_DoRec
1802            , Opt_ParallelListComp
1803            , Opt_EmptyDataDecls
1804            , Opt_KindSignatures
1805            , Opt_GeneralizedNewtypeDeriving
1806            , Opt_TypeFamilies ]
1807
1808 #ifdef GHCI
1809 -- Consult the RTS to find whether GHC itself has been built profiled
1810 -- If so, you can't use Template Haskell
1811 foreign import ccall unsafe "rts_isProfiled" rtsIsProfiledIO :: IO CInt
1812
1813 rtsIsProfiled :: Bool
1814 rtsIsProfiled = unsafePerformIO rtsIsProfiledIO /= 0
1815
1816 checkTemplateHaskellOk :: Bool -> DynP ()
1817 checkTemplateHaskellOk turn_on 
1818   | turn_on && rtsIsProfiled
1819   = addErr "You can't use Template Haskell with a profiled compiler"
1820   | otherwise
1821   = return ()
1822 #else
1823 -- In stage 1 we don't know that the RTS has rts_isProfiled, 
1824 -- so we simply say "ok".  It doesn't matter because TH isn't
1825 -- available in stage 1 anyway.
1826 checkTemplateHaskellOk turn_on = return ()
1827 #endif
1828
1829 {- **********************************************************************
1830 %*                                                                      *
1831                 DynFlags constructors
1832 %*                                                                      *
1833 %********************************************************************* -}
1834
1835 type DynP = EwM (CmdLineP DynFlags)
1836
1837 upd :: (DynFlags -> DynFlags) -> DynP ()
1838 upd f = liftEwM (do { dfs <- getCmdLineState
1839                     ; putCmdLineState $! (f dfs) })
1840
1841 --------------- Constructor functions for OptKind -----------------
1842 noArg :: (DynFlags -> DynFlags) -> OptKind (CmdLineP DynFlags)
1843 noArg fn = NoArg (upd fn)
1844
1845 noArgDF :: (DynFlags -> DynFlags) -> String -> OptKind (CmdLineP DynFlags)
1846 noArgDF fn deprec = NoArg (upd fn >> deprecate deprec)
1847
1848 hasArg :: (String -> DynFlags -> DynFlags) -> OptKind (CmdLineP DynFlags)
1849 hasArg fn = HasArg (upd . fn)
1850
1851 hasArgDF :: (String -> DynFlags -> DynFlags) -> String -> OptKind (CmdLineP DynFlags)
1852 hasArgDF fn deprec = HasArg (\s -> do { upd (fn s)
1853                                       ; deprecate deprec })
1854
1855 intSuffix :: (Int -> DynFlags -> DynFlags) -> OptKind (CmdLineP DynFlags)
1856 intSuffix fn = IntSuffix (\n -> upd (fn n))
1857
1858 setDumpFlag :: DynFlag -> OptKind (CmdLineP DynFlags)
1859 setDumpFlag dump_flag = NoArg (setDumpFlag' dump_flag)
1860
1861 --------------------------
1862 setDynFlag, unSetDynFlag :: DynFlag -> DynP ()
1863 setDynFlag   f = upd (\dfs -> dopt_set dfs f)
1864 unSetDynFlag f = upd (\dfs -> dopt_unset dfs f)
1865
1866 --------------------------
1867 setLanguage :: Language -> DynP ()
1868 setLanguage l = upd (\dfs -> dfs { language = Just l })
1869
1870 --------------------------
1871 setExtensionFlag, unSetExtensionFlag :: ExtensionFlag -> DynP ()
1872 setExtensionFlag f = do { upd (\dfs -> xopt_set dfs f)
1873                         ; mapM_ setExtensionFlag deps }
1874   where
1875     deps = [ d | (f', d) <- impliedFlags, f' == f ]
1876         -- When you set f, set the ones it implies
1877         -- NB: use setExtensionFlag recursively, in case the implied flags
1878         --     implies further flags
1879         -- When you un-set f, however, we don't un-set the things it implies
1880         --      (except for -fno-glasgow-exts, which is treated specially)
1881
1882 unSetExtensionFlag f = upd (\dfs -> xopt_unset dfs f)
1883
1884 --------------------------
1885 setDumpFlag' :: DynFlag -> DynP ()
1886 setDumpFlag' dump_flag
1887   = do { setDynFlag dump_flag
1888        ; when want_recomp forceRecompile }
1889   where
1890         -- Certain dumpy-things are really interested in what's going
1891         -- on during recompilation checking, so in those cases we
1892         -- don't want to turn it off.
1893     want_recomp = dump_flag `notElem` [Opt_D_dump_if_trace,
1894                                        Opt_D_dump_hi_diffs]
1895
1896 forceRecompile :: DynP ()
1897 -- Whenver we -ddump, force recompilation (by switching off the 
1898 -- recompilation checker), else you don't see the dump! However, 
1899 -- don't switch it off in --make mode, else *everything* gets
1900 -- recompiled which probably isn't what you want
1901 forceRecompile = do { dfs <- liftEwM getCmdLineState
1902                     ; when (force_recomp dfs) (setDynFlag Opt_ForceRecomp) }
1903         where
1904           force_recomp dfs = isOneShot (ghcMode dfs)
1905
1906 setVerboseCore2Core :: DynP ()
1907 setVerboseCore2Core = do forceRecompile
1908                          setDynFlag Opt_D_verbose_core2core 
1909                          upd (\dfs -> dfs { shouldDumpSimplPhase = Nothing })
1910                          
1911
1912 setDumpSimplPhases :: String -> DynP ()
1913 setDumpSimplPhases s = do forceRecompile
1914                           upd (\dfs -> dfs { shouldDumpSimplPhase = Just spec })
1915   where
1916     spec = case s of { ('=' : s') -> s';  _ -> s }
1917
1918 setVerbosity :: Maybe Int -> DynP ()
1919 setVerbosity mb_n = upd (\dfs -> dfs{ verbosity = mb_n `orElse` 3 })
1920
1921 addCmdlineHCInclude :: String -> DynP ()
1922 addCmdlineHCInclude a = upd (\s -> s{cmdlineHcIncludes =  a : cmdlineHcIncludes s})
1923
1924 extraPkgConf_ :: FilePath -> DynP ()
1925 extraPkgConf_  p = upd (\s -> s{ extraPkgConfs = p : extraPkgConfs s })
1926
1927 exposePackage, exposePackageId, hidePackage, ignorePackage :: String -> DynP ()
1928 exposePackage p =
1929   upd (\s -> s{ packageFlags = ExposePackage p : packageFlags s })
1930 exposePackageId p =
1931   upd (\s -> s{ packageFlags = ExposePackageId p : packageFlags s })
1932 hidePackage p =
1933   upd (\s -> s{ packageFlags = HidePackage p : packageFlags s })
1934 ignorePackage p =
1935   upd (\s -> s{ packageFlags = IgnorePackage p : packageFlags s })
1936
1937 setPackageName :: String -> DynFlags -> DynFlags
1938 setPackageName p s =  s{ thisPackage = stringToPackageId p }
1939
1940 -- If we're linking a binary, then only targets that produce object
1941 -- code are allowed (requests for other target types are ignored).
1942 setTarget :: HscTarget -> DynP ()
1943 setTarget l = upd set
1944   where
1945    set dfs
1946      | ghcLink dfs /= LinkBinary || isObjectTarget l  = dfs{ hscTarget = l }
1947      | otherwise = dfs
1948
1949 -- Changes the target only if we're compiling object code.  This is
1950 -- used by -fasm and -fvia-C, which switch from one to the other, but
1951 -- not from bytecode to object-code.  The idea is that -fasm/-fvia-C
1952 -- can be safely used in an OPTIONS_GHC pragma.
1953 setObjTarget :: HscTarget -> DynP ()
1954 setObjTarget l = upd set
1955   where
1956    set dfs
1957      | isObjectTarget (hscTarget dfs) = dfs { hscTarget = l }
1958      | otherwise = dfs
1959
1960 setOptLevel :: Int -> DynFlags -> DynFlags
1961 setOptLevel n dflags
1962    | hscTarget dflags == HscInterpreted && n > 0
1963         = dflags
1964             -- not in IO any more, oh well:
1965             -- putStr "warning: -O conflicts with --interactive; -O ignored.\n"
1966    | otherwise
1967         = updOptLevel n dflags
1968
1969
1970 -- -Odph is equivalent to
1971 --
1972 --    -O2                               optimise as much as possible
1973 --    -fno-method-sharing               sharing specialisation defeats fusion
1974 --                                      sometimes
1975 --    -fdicts-cheap                     always inline dictionaries
1976 --    -fmax-simplifier-iterations20     this is necessary sometimes
1977 --    -fsimplifier-phases=3             we use an additional simplifier phase
1978 --                                      for fusion
1979 --    -fno-spec-constr-threshold        run SpecConstr even for big loops
1980 --    -fno-spec-constr-count            SpecConstr as much as possible
1981 --    -finline-enough-args              hack to prevent excessive inlining
1982 --
1983 setDPHOpt :: DynFlags -> DynFlags
1984 setDPHOpt dflags = setOptLevel 2 (dflags { maxSimplIterations  = 20
1985                                          , simplPhases         = 3
1986                                          , specConstrThreshold = Nothing
1987                                          , specConstrCount     = Nothing
1988                                          })
1989                    `dopt_set`   Opt_DictsCheap
1990                    `dopt_unset` Opt_MethodSharing
1991
1992 data DPHBackend = DPHPar
1993                 | DPHSeq
1994                 | DPHThis
1995         deriving(Eq, Ord, Enum, Show)
1996
1997 setDPHBackend :: DPHBackend -> DynP ()
1998 setDPHBackend backend 
1999   = do
2000       upd $ \dflags -> dflags { dphBackend = backend }
2001       mapM_ exposePackage (dph_packages backend)
2002   where
2003     dph_packages DPHThis = []
2004     dph_packages DPHPar  = ["dph-prim-par", "dph-par"]
2005     dph_packages DPHSeq  = ["dph-prim-seq", "dph-seq"]
2006
2007 dphPackage :: DynFlags -> PackageId
2008 dphPackage dflags = case dphBackend dflags of
2009                       DPHPar  -> dphParPackageId
2010                       DPHSeq  -> dphSeqPackageId
2011                       DPHThis -> thisPackage dflags
2012
2013 setMainIs :: String -> DynP ()
2014 setMainIs arg
2015   | not (null main_fn) && isLower (head main_fn)
2016      -- The arg looked like "Foo.Bar.baz"
2017   = upd $ \d -> d{ mainFunIs = Just main_fn,
2018                    mainModIs = mkModule mainPackageId (mkModuleName main_mod) }
2019
2020   | isUpper (head arg)  -- The arg looked like "Foo" or "Foo.Bar"
2021   = upd $ \d -> d{ mainModIs = mkModule mainPackageId (mkModuleName arg) }
2022
2023   | otherwise                   -- The arg looked like "baz"
2024   = upd $ \d -> d{ mainFunIs = Just arg }
2025   where
2026     (main_mod, main_fn) = splitLongestPrefix arg (== '.')
2027
2028 -----------------------------------------------------------------------------
2029 -- Paths & Libraries
2030
2031 addImportPath, addLibraryPath, addIncludePath, addFrameworkPath :: FilePath -> DynP ()
2032
2033 -- -i on its own deletes the import paths
2034 addImportPath "" = upd (\s -> s{importPaths = []})
2035 addImportPath p  = upd (\s -> s{importPaths = importPaths s ++ splitPathList p})
2036
2037
2038 addLibraryPath p =
2039   upd (\s -> s{libraryPaths = libraryPaths s ++ splitPathList p})
2040
2041 addIncludePath p =
2042   upd (\s -> s{includePaths = includePaths s ++ splitPathList p})
2043
2044 addFrameworkPath p =
2045   upd (\s -> s{frameworkPaths = frameworkPaths s ++ splitPathList p})
2046
2047 #ifndef mingw32_TARGET_OS
2048 split_marker :: Char
2049 split_marker = ':'   -- not configurable (ToDo)
2050 #endif
2051
2052 splitPathList :: String -> [String]
2053 splitPathList s = filter notNull (splitUp s)
2054                 -- empty paths are ignored: there might be a trailing
2055                 -- ':' in the initial list, for example.  Empty paths can
2056                 -- cause confusion when they are translated into -I options
2057                 -- for passing to gcc.
2058   where
2059 #ifndef mingw32_TARGET_OS
2060     splitUp xs = split split_marker xs
2061 #else
2062      -- Windows: 'hybrid' support for DOS-style paths in directory lists.
2063      --
2064      -- That is, if "foo:bar:baz" is used, this interpreted as
2065      -- consisting of three entries, 'foo', 'bar', 'baz'.
2066      -- However, with "c:/foo:c:\\foo;x:/bar", this is interpreted
2067      -- as 3 elts, "c:/foo", "c:\\foo", "x:/bar"
2068      --
2069      -- Notice that no attempt is made to fully replace the 'standard'
2070      -- split marker ':' with the Windows / DOS one, ';'. The reason being
2071      -- that this will cause too much breakage for users & ':' will
2072      -- work fine even with DOS paths, if you're not insisting on being silly.
2073      -- So, use either.
2074     splitUp []             = []
2075     splitUp (x:':':div:xs) | div `elem` dir_markers
2076                            = ((x:':':div:p): splitUp rs)
2077                            where
2078                               (p,rs) = findNextPath xs
2079           -- we used to check for existence of the path here, but that
2080           -- required the IO monad to be threaded through the command-line
2081           -- parser which is quite inconvenient.  The
2082     splitUp xs = cons p (splitUp rs)
2083                where
2084                  (p,rs) = findNextPath xs
2085
2086                  cons "" xs = xs
2087                  cons x  xs = x:xs
2088
2089     -- will be called either when we've consumed nought or the
2090     -- "<Drive>:/" part of a DOS path, so splitting is just a Q of
2091     -- finding the next split marker.
2092     findNextPath xs =
2093         case break (`elem` split_markers) xs of
2094            (p, _:ds) -> (p, ds)
2095            (p, xs)   -> (p, xs)
2096
2097     split_markers :: [Char]
2098     split_markers = [':', ';']
2099
2100     dir_markers :: [Char]
2101     dir_markers = ['/', '\\']
2102 #endif
2103
2104 -- -----------------------------------------------------------------------------
2105 -- tmpDir, where we store temporary files.
2106
2107 setTmpDir :: FilePath -> DynFlags -> DynFlags
2108 setTmpDir dir dflags = dflags{ tmpDir = normalise dir }
2109   -- we used to fix /cygdrive/c/.. on Windows, but this doesn't
2110   -- seem necessary now --SDM 7/2/2008
2111
2112 -----------------------------------------------------------------------------
2113 -- RTS opts
2114
2115 setRtsOpts :: String -> DynP ()
2116 setRtsOpts arg  = upd $ \ d -> d {rtsOpts = Just arg}
2117
2118 setRtsOptsEnabled :: RtsOptsEnabled -> DynP ()
2119 setRtsOptsEnabled arg  = upd $ \ d -> d {rtsOptsEnabled = arg}
2120
2121 -----------------------------------------------------------------------------
2122 -- Hpc stuff
2123
2124 setOptHpcDir :: String -> DynP ()
2125 setOptHpcDir arg  = upd $ \ d -> d{hpcDir = arg}
2126
2127 -----------------------------------------------------------------------------
2128 -- Via-C compilation stuff
2129
2130 -- There are some options that we need to pass to gcc when compiling
2131 -- Haskell code via C, but are only supported by recent versions of
2132 -- gcc.  The configure script decides which of these options we need,
2133 -- and puts them in the file "extra-gcc-opts" in $topdir, which is
2134 -- read before each via-C compilation.  The advantage of having these
2135 -- in a separate file is that the file can be created at install-time
2136 -- depending on the available gcc version, and even re-generated  later
2137 -- if gcc is upgraded.
2138 --
2139 -- The options below are not dependent on the version of gcc, only the
2140 -- platform.
2141
2142 machdepCCOpts :: DynFlags -> ([String], -- flags for all C compilations
2143                               [String]) -- for registerised HC compilations
2144 machdepCCOpts dflags = let (flagsAll, flagsRegHc) = machdepCCOpts' dflags
2145                        in (cCcOpts ++ flagsAll, flagsRegHc)
2146
2147 machdepCCOpts' :: DynFlags -> ([String], -- flags for all C compilations
2148                                [String]) -- for registerised HC compilations
2149 machdepCCOpts' _dflags
2150 #if alpha_TARGET_ARCH
2151         =       ( ["-w", "-mieee"
2152 #ifdef HAVE_THREADED_RTS_SUPPORT
2153                     , "-D_REENTRANT"
2154 #endif
2155                    ], [] )
2156         -- For now, to suppress the gcc warning "call-clobbered
2157         -- register used for global register variable", we simply
2158         -- disable all warnings altogether using the -w flag. Oh well.
2159
2160 #elif hppa_TARGET_ARCH
2161         -- ___HPUX_SOURCE, not _HPUX_SOURCE, is #defined if -ansi!
2162         -- (very nice, but too bad the HP /usr/include files don't agree.)
2163         = ( ["-D_HPUX_SOURCE"], [] )
2164
2165 #elif m68k_TARGET_ARCH
2166       -- -fno-defer-pop : for the .hc files, we want all the pushing/
2167       --    popping of args to routines to be explicit; if we let things
2168       --    be deferred 'til after an STGJUMP, imminent death is certain!
2169       --
2170       -- -fomit-frame-pointer : *don't*
2171       --     It's better to have a6 completely tied up being a frame pointer
2172       --     rather than let GCC pick random things to do with it.
2173       --     (If we want to steal a6, then we would try to do things
2174       --     as on iX86, where we *do* steal the frame pointer [%ebp].)
2175         = ( [], ["-fno-defer-pop", "-fno-omit-frame-pointer"] )
2176
2177 #elif i386_TARGET_ARCH
2178       -- -fno-defer-pop : basically the same game as for m68k
2179       --
2180       -- -fomit-frame-pointer : *must* in .hc files; because we're stealing
2181       --   the fp (%ebp) for our register maps.
2182         =  let n_regs = stolen_x86_regs _dflags
2183            in
2184                     (
2185                       [ if opt_Static then "-DDONT_WANT_WIN32_DLL_SUPPORT" else ""
2186                       ],
2187                       [ "-fno-defer-pop",
2188                         "-fomit-frame-pointer",
2189                         -- we want -fno-builtin, because when gcc inlines
2190                         -- built-in functions like memcpy() it tends to
2191                         -- run out of registers, requiring -monly-n-regs
2192                         "-fno-builtin",
2193                         "-DSTOLEN_X86_REGS="++show n_regs ]
2194                     )
2195
2196 #elif ia64_TARGET_ARCH
2197         = ( [], ["-fomit-frame-pointer", "-G0"] )
2198
2199 #elif x86_64_TARGET_ARCH
2200         = (
2201                 [],
2202                 ["-fomit-frame-pointer",
2203                  "-fno-asynchronous-unwind-tables",
2204                         -- the unwind tables are unnecessary for HC code,
2205                         -- and get in the way of -split-objs.  Another option
2206                         -- would be to throw them away in the mangler, but this
2207                         -- is easier.
2208                  "-fno-builtin"
2209                         -- calling builtins like strlen() using the FFI can
2210                         -- cause gcc to run out of regs, so use the external
2211                         -- version.
2212                 ] )
2213
2214 #elif sparc_TARGET_ARCH
2215         = ( [], ["-w"] )
2216         -- For now, to suppress the gcc warning "call-clobbered
2217         -- register used for global register variable", we simply
2218         -- disable all warnings altogether using the -w flag. Oh well.
2219
2220 #elif powerpc_apple_darwin_TARGET
2221       -- -no-cpp-precomp:
2222       --     Disable Apple's precompiling preprocessor. It's a great thing
2223       --     for "normal" programs, but it doesn't support register variable
2224       --     declarations.
2225         = ( [], ["-no-cpp-precomp"] )
2226 #else
2227         = ( [], [] )
2228 #endif
2229
2230 picCCOpts :: DynFlags -> [String]
2231 picCCOpts _dflags
2232 #if darwin_TARGET_OS
2233       -- Apple prefers to do things the other way round.
2234       -- PIC is on by default.
2235       -- -mdynamic-no-pic:
2236       --     Turn off PIC code generation.
2237       -- -fno-common:
2238       --     Don't generate "common" symbols - these are unwanted
2239       --     in dynamic libraries.
2240
2241     | opt_PIC
2242         = ["-fno-common", "-U __PIC__","-D__PIC__"]
2243     | otherwise
2244         = ["-mdynamic-no-pic"]
2245 #elif mingw32_TARGET_OS
2246       -- no -fPIC for Windows
2247     | opt_PIC
2248         = ["-U __PIC__","-D__PIC__"]
2249     | otherwise
2250         = []
2251 #else
2252       -- we need -fPIC for C files when we are compiling with -dynamic,
2253       -- otherwise things like stub.c files don't get compiled
2254       -- correctly.  They need to reference data in the Haskell
2255       -- objects, but can't without -fPIC.  See
2256       -- http://hackage.haskell.org/trac/ghc/wiki/Commentary/PositionIndependentCode
2257     | opt_PIC || not opt_Static
2258         = ["-fPIC", "-U __PIC__", "-D__PIC__"]
2259     | otherwise
2260         = []
2261 #endif
2262
2263 -- -----------------------------------------------------------------------------
2264 -- Splitting
2265
2266 can_split :: Bool
2267 can_split = cSplitObjs == "YES"
2268
2269 -- -----------------------------------------------------------------------------
2270 -- Compiler Info
2271
2272 data Printable = String String
2273                | FromDynFlags (DynFlags -> String)
2274
2275 compilerInfo :: [(String, Printable)]
2276 compilerInfo = [("Project name",                String cProjectName),
2277                 ("Project version",             String cProjectVersion),
2278                 ("Booter version",              String cBooterVersion),
2279                 ("Stage",                       String cStage),
2280                 ("Build platform",              String cBuildPlatform),
2281                 ("Host platform",               String cHostPlatform),
2282                 ("Target platform",             String cTargetPlatform),
2283                 ("Have interpreter",            String cGhcWithInterpreter),
2284                 ("Object splitting",            String cSplitObjs),
2285                 ("Have native code generator",  String cGhcWithNativeCodeGen),
2286                 ("Have llvm code generator",    String cGhcWithLlvmCodeGen),
2287                 ("Use archives for ghci",       String (show cUseArchivesForGhci)),
2288                 ("Support SMP",                 String cGhcWithSMP),
2289                 ("Unregisterised",              String cGhcUnregisterised),
2290                 ("Tables next to code",         String cGhcEnableTablesNextToCode),
2291                 ("RTS ways",                    String cGhcRTSWays),
2292                 ("Leading underscore",          String cLeadingUnderscore),
2293                 ("Debug on",                    String (show debugIsOn)),
2294                 ("LibDir",                      FromDynFlags topDir),
2295                 ("Global Package DB",           FromDynFlags systemPackageConfig)
2296                ]
2297