From 2d7dd0285bbc364f89d4d97928674f7ea73ed2c8 Mon Sep 17 00:00:00 2001 From: Matthew Pickering Date: Sun, 10 Mar 2019 17:43:10 +0000 Subject: Hadrian: Add ./hadrian/ghci.sh script for fast development feedback Running the `./hadrian/ghci` target will load the main compiler into a ghci session. This is intended for fast development feedback, modules are only typechecked so it isn't possible to run any functions in the repl. You can also use this target with `ghcid`. The first time this command is run hadrian will need to compile a few dependencies which will take 1-2 minutes. Loading GHC into GHCi itself takes about 30 seconds. Internally this works by calling a new hadrian target called `tool-args`. This target prints out the package and include flags which are necessary to load files into ghci. The same target is intended to be used by other tooling which uses the GHC API in order to set up the correct GHC API session. For example, using this target it is also possible to use HIE when developing on GHC. --- hadrian/src/Rules.hs | 35 ++++++++++++++++++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) (limited to 'hadrian/src/Rules.hs') diff --git a/hadrian/src/Rules.hs b/hadrian/src/Rules.hs index c5be5a7ff9..e4de23f34d 100644 --- a/hadrian/src/Rules.hs +++ b/hadrian/src/Rules.hs @@ -1,4 +1,5 @@ -module Rules (buildRules, oracleRules, packageTargets, topLevelTargets) where +module Rules (buildRules, oracleRules, packageTargets, topLevelTargets + , toolArgsTarget ) where import qualified Hadrian.Oracles.ArgsHash import qualified Hadrian.Oracles.Cabal.Rules @@ -26,6 +27,38 @@ import Target import UserSettings import Utilities + +-- | @tool-args@ is used by tooling in order to get the arguments necessary +-- to set up a GHC API session which can compile modules from GHC. When +-- run, the target prints out the arguments that would be passed to @ghc@ +-- during normal compilation to @stdout@. +-- +-- This target is called by the `ghci.sh` script in order to load all of GHC's +-- modules into GHCi. +toolArgsTarget :: Rules () +toolArgsTarget = do + "tool-args" ~> do + let fake_target = target (Context Stage0 compiler dynamic) + (Ghc ToolArgs Stage0) [] ["ignored"] + + -- need the autogenerated files so that they are precompiled + generatedGhcDependencies Stage0 >>= need + interpret fake_target Rules.Generate.compilerDependencies >>= need + + root <- buildRoot + let dir = buildDir (vanillaContext Stage0 compiler) + need [ root dir -/- "Config.hs" ] + need [ root dir -/- "Fingerprint.hs" ] + need [ root dir -/- "Parser.hs" ] + need [ root dir -/- "Lexer.hs" ] + need [ root dir -/- "CmmParse.hs" ] + need [ root dir -/- "CmmLex.hs" ] + + -- Find out the arguments that are needed to load a module into the + -- session + arg_list <- interpret fake_target getArgs + liftIO $ putStrLn (intercalate " " arg_list) + allStages :: [Stage] allStages = [minBound .. maxBound] -- cgit v1.2.1