mirror of
https://github.com/IHaskell/IHaskell.git
synced 2025-04-19 12:56:08 +00:00
src/IHaskell/Eval/Evaluate.hs: hide ghc-lib{,-parser}
This commit is contained in:
parent
e4fd5807d5
commit
0f5aaa051d
@ -24,6 +24,7 @@ import Control.Concurrent (forkIO, threadDelay)
|
||||
import Data.Foldable (foldMap)
|
||||
import Prelude (head, tail, last, init)
|
||||
import Data.List (nubBy)
|
||||
import qualified Data.Set as Set
|
||||
import Data.Char as Char
|
||||
import Data.Dynamic
|
||||
import qualified Data.Serialize as Serialize
|
||||
@ -116,6 +117,9 @@ ihaskellGlobalImports =
|
||||
, "import qualified IHaskell.Eval.Widgets"
|
||||
]
|
||||
|
||||
hiddenPackageNames :: Set.Set String
|
||||
hiddenPackageNames = Set.fromList ["ghc-lib", "ghc-lib-parser"]
|
||||
|
||||
-- | Interpreting function for testing.
|
||||
testInterpret :: Interpreter a -> IO a
|
||||
testInterpret v = interpret GHC.Paths.libdir False (const v)
|
||||
@ -182,7 +186,8 @@ initializeImports = do
|
||||
(dflgs, _) <- liftIO $ initPackages dflags
|
||||
let db = getPackageConfigs dflgs
|
||||
packageNames = map (packageIdString' dflgs) db
|
||||
|
||||
hiddenPackages = Set.intersection hiddenPackageNames (Set.fromList packageNames)
|
||||
hiddenFlags = fmap HidePackage $ Set.toList hiddenPackages
|
||||
initStr = "ihaskell-"
|
||||
|
||||
#if MIN_VERSION_ghc(8,2,0)
|
||||
@ -222,6 +227,8 @@ initializeImports = do
|
||||
|
||||
displayImports = map toImportStmt displayPkgs
|
||||
|
||||
void $ setSessionDynFlags $ dflgs { packageFlags = hiddenFlags ++ packageFlags dflgs }
|
||||
|
||||
-- Import implicit prelude.
|
||||
importDecl <- parseImportDecl "import Prelude"
|
||||
let implicitPrelude = importDecl { ideclImplicit = True }
|
||||
|
Loading…
x
Reference in New Issue
Block a user