ghc-mod/List.hs
2012-02-14 16:09:53 +09:00

24 lines
582 B
Haskell

module List (listModules) where
import Control.Applicative
import Data.List
import GHC
import GHCApi
import Packages
import Types
import UniqFM
----------------------------------------------------------------
listModules :: Options -> IO String
listModules opt = convert opt . nub . sort <$> list opt
list :: Options -> IO [String]
list opt = withGHC $ do
initSession0 opt
getExposedModules <$> getSessionDynFlags
where
getExposedModules = map moduleNameString
. concatMap exposedModules
. eltsUFM . pkgIdMap . pkgState