ghc-mod/CabalDev.hs

53 lines
1.5 KiB
Haskell
Raw Normal View History

module CabalDev (modifyOptions) where
{-
2012-02-06 06:13:41 +00:00
If the directory 'cabal-dev/packages-X.X.X.conf' exists, add it to the
options ghc-mod uses to check the source. Otherwise just pass it on.
-}
2012-02-16 05:44:20 +00:00
import Control.Applicative ((<$>))
2012-02-15 05:52:48 +00:00
import Control.Exception (throwIO)
2012-02-16 05:44:20 +00:00
import Control.Exception.IOChoice
2012-02-15 05:52:48 +00:00
import Data.List (find)
import System.Directory
2012-02-15 05:52:48 +00:00
import System.FilePath (splitPath,joinPath,(</>))
import Text.Regex.Posix ((=~))
import Types
modifyOptions :: Options -> IO Options
2012-02-16 05:44:20 +00:00
modifyOptions opts = found ||> notFound
2012-02-06 06:13:41 +00:00
where
2012-04-10 00:43:02 +00:00
found = addPath opts <$> findCabalDev (sandbox opts)
2012-02-15 05:52:48 +00:00
notFound = return opts
findCabalDev :: Maybe String -> IO FilePath
2013-02-15 01:47:45 +00:00
findCabalDev Nothing = getCurrentDirectory >>= searchIt . splitPath
findCabalDev (Just path) = do
2012-04-10 00:43:02 +00:00
exist <- doesDirectoryExist path
if exist then
findConf path
else
findCabalDev Nothing
addPath :: Options -> String -> Options
2013-02-15 01:47:45 +00:00
addPath orig_opts path = orig_opts { ghcOpts = opts' }
where
orig_ghcopt = ghcOpts orig_opts
opts' = orig_ghcopt ++ ["-package-conf", path, "-no-user-package-conf"]
searchIt :: [FilePath] -> IO FilePath
searchIt [] = throwIO $ userError "Not found"
searchIt path = do
2012-07-06 07:55:14 +00:00
exist <- doesDirectoryExist cabalDir
if exist then
findConf cabalDir
2012-02-06 06:13:41 +00:00
else
searchIt $ init path
2011-11-02 01:43:34 +00:00
where
2013-02-18 04:49:12 +00:00
cabalDir = joinPath path </> "cabal-dev/"
2011-11-26 13:38:46 +00:00
findConf :: FilePath -> IO FilePath
2011-11-26 13:38:46 +00:00
findConf path = do
Just f <- find (=~ "packages.*\\.conf") <$> getDirectoryContents path
return $ path </> f