summaryrefslogtreecommitdiff
path: root/compiler/GHC/Runtime
diff options
context:
space:
mode:
authorRoland Senn <rsx@bluewin.ch>2021-05-27 16:04:13 +0200
committerMarge Bot <ben+marge-bot@smart-cactus.org>2021-06-02 04:39:23 -0400
commitfcd124d5c7c1c4ea8488587f65112b7a66b7da83 (patch)
tree00d87b0161e2a8245d057ff98cbebc29dd6cc46f /compiler/GHC/Runtime
parent6b6c4b9ab0f773011a04c19f3cd5131a1aab2a41 (diff)
downloadhaskell-fcd124d5c7c1c4ea8488587f65112b7a66b7da83.tar.gz
Allow primops in a :print (and friends) command. Fix #19394
* For primops from `GHC.Prim` lookup the HValues in `GHC.PrimopWrappers`. * Add short error messages if a user tries to use a *Non-Id* value or a `pseudoop` in a `:print`, `:sprint` or `force`command. * Add additional test cases for `Magic Ids`.
Diffstat (limited to 'compiler/GHC/Runtime')
-rw-r--r--compiler/GHC/Runtime/Debugger.hs42
1 files changed, 32 insertions, 10 deletions
diff --git a/compiler/GHC/Runtime/Debugger.hs b/compiler/GHC/Runtime/Debugger.hs
index be6241acb8..99f189e079 100644
--- a/compiler/GHC/Runtime/Debugger.hs
+++ b/compiler/GHC/Runtime/Debugger.hs
@@ -38,6 +38,7 @@ import GHC.Utils.Exception
import GHC.Utils.Logger
import GHC.Types.Id
+import GHC.Types.Id.Make (ghcPrimIds)
import GHC.Types.Name
import GHC.Types.Var hiding ( varName )
import GHC.Types.Var.Set
@@ -47,7 +48,7 @@ import GHC.Types.TyThing
import Control.Monad
import Control.Monad.Catch as MC
-import Data.List ( (\\) )
+import Data.List ( (\\), partition )
import Data.Maybe
import Data.IORef
@@ -60,25 +61,46 @@ pprintClosureCommand bindThings force str = do
mapM (\w -> GHC.parseName w >>=
mapM GHC.lookupName)
(words str)
- let ids = [id | AnId id <- tythings]
+
+ -- Sort out good and bad tythings for :print and friends
+ let (pprintables, unpprintables) = partition can_pprint tythings
-- Obtain the terms and the recovered type information
+ let ids = [id | AnId id <- pprintables]
(subst, terms) <- mapAccumLM go emptyTCvSubst ids
-- Apply the substitutions obtained after recovering the types
modifySession $ \hsc_env ->
hsc_env{hsc_IC = substInteractiveContext (hsc_IC hsc_env) subst}
- -- Finally, print the Terms
- unqual <- GHC.getPrintUnqual
+ -- Finally, print the Results
docterms <- mapM showTerm terms
- dflags <- getDynFlags
- logger <- getLogger
- liftIO $ (printOutputForUser logger dflags unqual . vcat)
- (zipWith (\id docterm -> ppr id <+> char '=' <+> docterm)
- ids
- docterms)
+ let sdocTerms = zipWith (\id docterm -> ppr id <+> char '=' <+> docterm)
+ ids
+ docterms
+ printSDocs $ (no_pprint <$> unpprintables) ++ sdocTerms
where
+ -- Check whether a TyThing can be processed by :print and friends.
+ -- Take only Ids, exclude pseudoops, they don't have any HValues.
+ can_pprint :: TyThing -> Bool -- #19394
+ can_pprint (AnId x)
+ | x `notElem` ghcPrimIds = True
+ | otherwise = False
+ can_pprint _ = False
+
+ -- Create a short message for a TyThing, that cannot processed by :print
+ no_pprint :: TyThing -> SDoc
+ no_pprint tything = ppr tything <+>
+ text "is not eligible for the :print, :sprint or :force commands."
+
+ -- Helper to print out the results of :print and friends
+ printSDocs :: GhcMonad m => [SDoc] -> m ()
+ printSDocs sdocs = do
+ logger <- getLogger
+ dflags <- getDynFlags
+ unqual <- GHC.getPrintUnqual
+ liftIO $ printOutputForUser logger dflags unqual $ vcat sdocs
+
-- Do the obtainTerm--bindSuspensions-computeSubstitution dance
go :: GhcMonad m => TCvSubst -> Id -> m (TCvSubst, Term)
go subst id = do