summaryrefslogtreecommitdiff
path: root/utils/mkUserGuidePart/Options/OptimizationLevels.hs
diff options
context:
space:
mode:
authorAdam Gundry <adam@well-typed.com>2015-10-16 13:58:52 +0100
committerAdam Gundry <adam@well-typed.com>2015-10-16 13:58:52 +0100
commit5a1b4f814f74ec1c48152d97523744518e212777 (patch)
tree7c2207ecacbd37f12c78dbcf9d4334827164e0fb /utils/mkUserGuidePart/Options/OptimizationLevels.hs
parent6757950cdd8bb0af0355539987ee78401a6a8f6b (diff)
parent808bbdf08058785ae5bc59b5b4f2b04951d4cbbf (diff)
downloadhaskell-wip/orf-reboot.tar.gz
Merge remote-tracking branch 'origin/master' into wip/orf-rebootwip/orf-reboot
Conflicts: compiler/rename/RnNames.hs compiler/typecheck/TcRnMonad.hs utils/haddock
Diffstat (limited to 'utils/mkUserGuidePart/Options/OptimizationLevels.hs')
-rw-r--r--utils/mkUserGuidePart/Options/OptimizationLevels.hs29
1 files changed, 29 insertions, 0 deletions
diff --git a/utils/mkUserGuidePart/Options/OptimizationLevels.hs b/utils/mkUserGuidePart/Options/OptimizationLevels.hs
new file mode 100644
index 0000000000..a57fc5291b
--- /dev/null
+++ b/utils/mkUserGuidePart/Options/OptimizationLevels.hs
@@ -0,0 +1,29 @@
+module Options.OptimizationLevels where
+
+import Types
+
+optimizationLevelsOptions :: [Flag]
+optimizationLevelsOptions =
+ [ flag { flagName = "-O0"
+ , flagDescription = "Disable optimisations (default)"
+ , flagType = DynamicFlag
+ , flagReverse = "-O"
+ }
+ , flag { flagName = "-O, -O1"
+ , flagDescription = "Enable level 1 optimisations"
+ , flagType = DynamicFlag
+ , flagReverse = "-O0"
+ }
+ , flag { flagName = "-O2"
+ , flagDescription = "Enable level 2 optimisations"
+ , flagType = DynamicFlag
+ , flagReverse = "-O0"
+ }
+ , flag { flagName = "-Odph"
+ , flagDescription =
+ "Enable level 2 optimisations, set "++
+ "``-fmax-simplifier-iterations=20`` "++
+ "and ``-fsimplifier-phases=3``."
+ , flagType = DynamicFlag
+ }
+ ]