diff options
| author | Roland Senn <rsx@bluewin.ch> | 2018-12-27 15:14:31 +0100 | 
|---|---|---|
| committer | Ben Gamari <ben@smart-cactus.org> | 2019-01-16 14:10:49 -0500 | 
| commit | f78048f6575b370f078bcddc6b9e64bfe23932eb (patch) | |
| tree | 9c2cba8431a6adfd43fb38d86ed11a42b9d33388 | |
| parent | 9fb744bdc54c75cf5b91aa783b18233ba8da04a6 (diff) | |
| download | haskell-f78048f6575b370f078bcddc6b9e64bfe23932eb.tar.gz | |
Change comments as requested by code review. #10857
| -rw-r--r-- | compiler/main/DynFlags.hs | 2 | ||||
| -rw-r--r-- | ghc/GHCi/UI.hs | 33 | 
2 files changed, 28 insertions, 7 deletions
| diff --git a/compiler/main/DynFlags.hs b/compiler/main/DynFlags.hs index ccc2a05e50..78be688ec3 100644 --- a/compiler/main/DynFlags.hs +++ b/compiler/main/DynFlags.hs @@ -2382,7 +2382,7 @@ xopt_unset dfs f        in dfs { extensions = onoffs,                 extensionFlags = flattenExtensionFlags (language dfs) onoffs } --- | Set or unset a 'LangExt.Extension', unless it has been explicitely +-- | Set or unset a 'LangExt.Extension', unless it has been explicitly  --   set or unset before.  xopt_set_unlessExplSpec          :: LangExt.Extension diff --git a/ghc/GHCi/UI.hs b/ghc/GHCi/UI.hs index 3a26dfefc8..0c09844c1b 100644 --- a/ghc/GHCi/UI.hs +++ b/ghc/GHCi/UI.hs @@ -433,12 +433,7 @@ interactiveUI config srcs maybe_exprs = do     -- The initial set of DynFlags used for interactive evaluation is the same     -- as the global DynFlags, plus -XExtendedDefaultRules and     -- -XNoMonomorphismRestriction. -   -- However we set/unset these two extensions only, if they were not already -   -- explicitely specified before. The function 'xopt_set_unlessExplSpec' -   -- inspects the data field DynFlags.extensions. -   -- At this point of the GHCi initialization this data field contains only -   -- the extensions specified at the command line. -   -- The ghci config file has not yet been processed. (#10857) +   -- See note [Changing language extensions for interactive evaluation] #10857     dflags <- getDynFlags     let dflags' = (xopt_set_unlessExplSpec                        LangExt.ExtendedDefaultRules xopt_set) @@ -509,6 +504,32 @@ interactiveUI config srcs maybe_exprs = do     return () +{- +Note [Changing language extensions for interactive evaluation] +-------------------------------------------------------------- +GHCi maintains two sets of options: + +- The "loading options" apply when loading modules +- The "interactive options" apply when evaluating expressions and commands +    typed at the GHCi prompt. + +The loading options are mostly created in ghc/Main.hs:main' from the command +line flags. In the function ghc/GHCi/UI.hs:interactiveUI the loading options +are copied to the interactive options. + +These interactive options (but not the loading options!) are supplemented +unconditionally by setting ExtendedDefaultRules ON and +MonomorphismRestriction OFF. The unconditional setting of these options +eventually overwrite settings already specified at the command line. + +Therefore instead of unconditionally setting ExtendedDefaultRules and +NoMonomorphismRestriction for the interactive options, we use the function +'xopt_set_unlessExplSpec' to first check whether the extension has already +specified at the command line. + +The ghci config file has not yet been processed. +-} +  resetLastErrorLocations :: GHCi ()  resetLastErrorLocations = do      st <- getGHCiState | 
