diff options
| author | Sylvain Henry <sylvain@haskus.fr> | 2021-06-01 10:02:06 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-06-01 10:02:06 +0200 | 
| commit | 1ceb34bf20ef4f226a4152264505826d3138957e (patch) | |
| tree | c436143a5c2851f6cdd7fc79cdd2a8a8afb3c3e0 /haddock-api/src/Haddock | |
| parent | c120839debadd7a1427cee84459c01d59c5b85aa (diff) | |
Adapt Haddock to Logger and Parser changes (#1399)
Diffstat (limited to 'haddock-api/src/Haddock')
| -rw-r--r-- | haddock-api/src/Haddock/Backends/Hyperlinker/Parser.hs | 3 | ||||
| -rw-r--r-- | haddock-api/src/Haddock/Interface.hs | 14 | ||||
| -rw-r--r-- | haddock-api/src/Haddock/Parser.hs | 2 | 
3 files changed, 9 insertions, 10 deletions
| diff --git a/haddock-api/src/Haddock/Backends/Hyperlinker/Parser.hs b/haddock-api/src/Haddock/Backends/Hyperlinker/Parser.hs index 94395218..49e2c66f 100644 --- a/haddock-api/src/Haddock/Backends/Hyperlinker/Parser.hs +++ b/haddock-api/src/Haddock/Backends/Hyperlinker/Parser.hs @@ -10,6 +10,7 @@ import Data.List           ( isPrefixOf, isSuffixOf )  import qualified Data.ByteString as BS +import GHC.Platform  import GHC.Types.SourceText  import GHC.Driver.Session  import GHC.Utils.Error     ( mkPlainMsgEnvelope, pprLocMsgEnvelope ) @@ -49,9 +50,11 @@ parse dflags fpath bs = case unP (go False []) initState of      initState = initParserState pflags buf start      buf = stringBufferFromByteString bs      start = mkRealSrcLoc (mkFastString fpath) 1 1 +    arch_os = platformArchOS (targetPlatform dflags)      pflags = mkParserOpts   (warningFlags dflags)                              (extensionFlags dflags)                              (mkPlainMsgEnvelope dflags) +                            (supportedLanguagesAndExtensions arch_os)                              (safeImportsOn dflags)                              False -- lex Haddocks as comment tokens                              True  -- produce comment tokens diff --git a/haddock-api/src/Haddock/Interface.hs b/haddock-api/src/Haddock/Interface.hs index 2486c752..2e9b2f7e 100644 --- a/haddock-api/src/Haddock/Interface.hs +++ b/haddock-api/src/Haddock/Interface.hs @@ -56,7 +56,7 @@ import qualified Data.Set as Set  import GHC hiding (verbosity)  import GHC.Data.FastString (unpackFS)  import GHC.Data.Graph.Directed (flattenSCCs) -import GHC.Driver.Env (hsc_dflags, hsc_home_unit, hsc_logger, hsc_static_plugins, hsc_units) +import GHC.Driver.Env (hscUpdateFlags, hsc_home_unit, hsc_logger, hsc_static_plugins, hsc_units)  import GHC.Driver.Monad (modifySession, withTimingM)  import GHC.Driver.Session hiding (verbosity)  import GHC.HsToCore.Docs (getMainDeclBinder) @@ -145,11 +145,8 @@ createIfaces verbosity modules flags instIfaceMap = do    let      installHaddockPlugin :: HscEnv -> HscEnv -    installHaddockPlugin hsc_env = hsc_env -      { -        hsc_dflags = -          gopt_set (hsc_dflags hsc_env) Opt_PluginTrustworthy -      , hsc_static_plugins = +    installHaddockPlugin hsc_env = hscUpdateFlags (flip gopt_set Opt_PluginTrustworthy) $ hsc_env +      { hsc_static_plugins =            haddockPlugin : hsc_static_plugins hsc_env        } @@ -212,7 +209,7 @@ plugin verbosity flags instIfaceMap = liftIO $ do        | otherwise = do            hsc_env <- getTopEnv            ifaces <- liftIO $ readIORef ifaceMapRef -          (iface, modules) <- withTiming (hsc_logger hsc_env) (hsc_dflags hsc_env) +          (iface, modules) <- withTiming (hsc_logger hsc_env)                                  "processModule" (const ()) $              processModule1 verbosity flags ifaces instIfaceMap hsc_env mod_summary tc_gbl_env @@ -266,9 +263,8 @@ processModule1 verbosity flags ifaces inst_ifaces hsc_env mod_summary tc_gbl_env    (!interface, messages) <- do      logger <- getLogger -    dflags <- getDynFlags      {-# SCC createInterface #-} -     withTiming logger dflags "createInterface" (const ()) $ runIfM (fmap Just . tcLookupGlobal) $ +     withTiming logger "createInterface" (const ()) $ runIfM (fmap Just . tcLookupGlobal) $        createInterface1 flags unit_state mod_summary tc_gbl_env          ifaces inst_ifaces diff --git a/haddock-api/src/Haddock/Parser.hs b/haddock-api/src/Haddock/Parser.hs index ab2fa549..53cf98ad 100644 --- a/haddock-api/src/Haddock/Parser.hs +++ b/haddock-api/src/Haddock/Parser.hs @@ -19,7 +19,7 @@ import Documentation.Haddock.Types  import Haddock.Types  import GHC.Driver.Session ( DynFlags ) -import GHC.Driver.Config +import GHC.Driver.Config.Parser (initParserOpts)  import GHC.Data.FastString   ( fsLit )  import GHC.Parser.Lexer ( initParserState, unP, ParseResult(POk, PFailed) )  import GHC.Parser       ( parseIdentifier ) | 
