[Git][ghc/ghc][master] prevent GHCi (and runghc) from suggesting other symbols when not finding main
Marge Bot (@marge-bot)
gitlab at gitlab.haskell.org
Tue Feb 13 19:09:52 UTC 2024
Marge Bot pushed to branch master at Glasgow Haskell Compiler / GHC
Commits:
500d8cb8 by Jade at 2024-02-13T14:09:07-05:00
prevent GHCi (and runghc) from suggesting other symbols when not finding main
Fixes: #23996
- - - - -
2 changed files:
- ghc/GHCi/UI.hs
- testsuite/tests/ghc-e/should_fail/T18441fail18.stderr
Changes:
=====================================
ghc/GHCi/UI.hs
=====================================
@@ -1622,13 +1622,24 @@ pprInfo (thing, fixity, cls_insts, fam_insts, docs)
runMain :: GhciMonad m => String -> m ()
runMain s = case toArgsNoLoc s of
- Left err -> liftIO (hPutStrLn stderr err)
- Right args ->
- do dflags <- getDynFlags
- let main = fromMaybe "main" (mainFunIs dflags)
- -- Wrap the main function in 'void' to discard its value instead
- -- of printing it (#9086). See Haskell 2010 report Chapter 5.
- doWithArgs args $ "Control.Monad.void (" ++ main ++ ")"
+ Left err -> liftIO (hPutStrLn stderr err)
+ Right args -> doWithMain (doWithArgs args)
+ where
+ doWithMain fun = do
+ dflags <- getDynFlags
+ let main = fromMaybe "main" (mainFunIs dflags)
+ handleSourceError printErrAndMaybeExit $ do
+ -- doing this will prevent the main to run when it is not in scope
+ -- this might seem useless, but it doesn't suggest other functions
+ -- to be used, which is exactly what we want here. See #23996.
+ _ <- GHC.parseName main
+
+ -- Wrap the main function in 'void' to discard its value instead
+ -- of printing it (#9086). See Haskell 2010 report Chapter 5.
+ fun $ "Control.Monad.void (" ++ main ++ ")"
+
+
+
-----------------------------------------------------------------------------
-- :run
=====================================
testsuite/tests/ghc-e/should_fail/T18441fail18.stderr
=====================================
@@ -1,5 +1,4 @@
-<interactive>:0:53: error: [GHC-88464]
- Variable not in scope: main :: IO a0
- Suggested fix: Perhaps use ‘min’ (imported from Prelude)
+<interactive>:1:1: error: [GHC-76037]
+ Not in scope: ‘main’
1
View it on GitLab: https://gitlab.haskell.org/ghc/ghc/-/commit/500d8cb8d27ee1b1ec2d9a523f04ca798aa7e497
--
View it on GitLab: https://gitlab.haskell.org/ghc/ghc/-/commit/500d8cb8d27ee1b1ec2d9a523f04ca798aa7e497
You're receiving this email because of your account on gitlab.haskell.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.haskell.org/pipermail/ghc-commits/attachments/20240213/dac73d00/attachment-0001.html>
More information about the ghc-commits
mailing list