ghc-mod/Check.hs

93 lines
2.6 KiB
Haskell
Raw Normal View History

2010-03-11 10:03:17 +00:00
module Check (checkSyntax) where
2010-04-28 12:43:32 +00:00
import Bag
2010-03-11 10:03:17 +00:00
import Control.Applicative
2010-04-28 12:43:32 +00:00
import Data.IORef
import DynFlags
import ErrUtils
2010-04-28 12:59:27 +00:00
import Exception
2010-04-28 12:43:32 +00:00
import FastString
import GHC
import GHC.Paths (libdir)
import HscTypes
import Outputable hiding (showSDoc)
2010-03-11 13:39:07 +00:00
import Param
2010-04-28 12:43:32 +00:00
import Pretty
2010-03-11 10:03:17 +00:00
----------------------------------------------------------------
2010-03-11 13:39:07 +00:00
checkSyntax :: Options -> String -> IO String
2010-04-29 03:39:48 +00:00
checkSyntax _ file = unlines <$> check file
2010-04-28 12:43:32 +00:00
----------------------------------------------------------------
2010-04-29 03:39:48 +00:00
check :: String -> IO [String]
check fileName = ghandle ignore $ runGhc (Just libdir) $ do
2010-04-28 12:43:32 +00:00
ref <- liftIO $ newIORef []
initSession
setTargetFile fileName
loadWithLogger (refLogger ref) LoadAllTargets
liftIO $ readIORef ref
2010-03-11 10:03:17 +00:00
where
-- I don't know why, but parseDynamicFlags must be used.
2010-04-28 12:43:32 +00:00
initSession = do
dflags <- getSessionDynFlags
(dflags',_,_) <- parseDynamicFlags dflags cmdOptions
2010-04-30 06:09:24 +00:00
setSessionDynFlags $ setFlags dflags'
2010-04-28 12:43:32 +00:00
setTargetFile file = do
target <- guessTarget file Nothing
setTargets [target]
2010-04-28 12:59:27 +00:00
ignore :: SomeException -> IO [String]
ignore _ = return []
2010-04-28 12:43:32 +00:00
2010-04-30 09:09:26 +00:00
-- I don't know why, but parseDynamicFlags must be used.
cmdOptions :: [Located String]
cmdOptions = map noLoc ["-Wall","-fno-warn-unused-do-bind"]
2010-04-28 12:43:32 +00:00
----------------------------------------------------------------
refLogger :: IORef [String] -> WarnErrLogger
refLogger ref Nothing = do
2010-04-30 06:09:24 +00:00
warns <- map showErrMsg . reverse . bagToList <$> getWarnings
2010-04-28 12:43:32 +00:00
liftIO $ writeIORef ref warns
clearWarnings
refLogger ref (Just e) = do
2010-04-30 06:09:24 +00:00
let errs = map showErrMsg . reverse . bagToList . srcErrorMessages $ e
2010-04-28 12:43:32 +00:00
liftIO $ writeIORef ref errs
clearWarnings
----------------------------------------------------------------
2010-04-30 06:09:24 +00:00
setFlags :: DynFlags -> DynFlags
setFlags d = d {
importPaths = importPaths d ++ importDirs
, packageFlags = ghcPackage : packageFlags d
2010-04-29 03:30:23 +00:00
, ghcLink = NoLink
2010-04-30 06:11:41 +00:00
-- GHC.desugarModule does not produces the pattern warnings, why?
-- , hscTarget = HscNothing
, hscTarget = HscInterpreted
2010-04-29 03:30:23 +00:00
}
2010-04-29 03:39:48 +00:00
importDirs :: [String]
importDirs = ["..","../..","../../..","../../../../.."]
ghcPackage :: PackageFlag
ghcPackage = ExposePackage "ghc"
2010-04-28 12:43:32 +00:00
----------------------------------------------------------------
showErrMsg :: ErrMsg -> String
showErrMsg err = file ++ ":" ++ line ++ ":" ++ col ++ ":" ++ msg
where
spn = head (errMsgSpans err)
file = unpackFS (srcSpanFile spn)
line = show (srcSpanStartLine spn)
col = show (srcSpanStartCol spn)
msg = showSDoc (errMsgShortDoc err)
style :: PprStyle
style = mkUserStyle neverQualify AllTheWay
showSDoc :: SDoc -> String
showSDoc d = Pretty.showDocWith OneLineMode (d style)