Switch when using cabal-dev case. Bugfix of cabal-dev case.
This commit is contained in:
parent
21441da080
commit
748c57f0c1
@ -9,7 +9,7 @@ options ghc-mod uses to check the source. Otherwise just pass it on.
|
|||||||
|
|
||||||
import Data.Maybe (listToMaybe)
|
import Data.Maybe (listToMaybe)
|
||||||
import System.FilePath.Find
|
import System.FilePath.Find
|
||||||
import System.FilePath.Posix (splitPath,joinPath)
|
import System.FilePath.Posix (splitPath,joinPath,(</>))
|
||||||
import System.Posix.Directory (getWorkingDirectory)
|
import System.Posix.Directory (getWorkingDirectory)
|
||||||
import System.Directory
|
import System.Directory
|
||||||
|
|
||||||
@ -29,8 +29,8 @@ findCabalDev =
|
|||||||
|
|
||||||
addPath :: Options -> String -> Options
|
addPath :: Options -> String -> Options
|
||||||
addPath orig_opts path = do
|
addPath orig_opts path = do
|
||||||
let orig_paths = packageConfs orig_opts
|
let orig_ghcopt = ghcOpts orig_opts
|
||||||
orig_opts { packageConfs = orig_paths ++ [path] }
|
orig_opts { ghcOpts = orig_ghcopt ++ ["-package-conf", path] }
|
||||||
|
|
||||||
searchIt :: [FilePath] -> IO (Maybe FilePath)
|
searchIt :: [FilePath] -> IO (Maybe FilePath)
|
||||||
searchIt [] = return Nothing
|
searchIt [] = return Nothing
|
||||||
@ -42,4 +42,4 @@ searchIt path = do
|
|||||||
else
|
else
|
||||||
return Nothing
|
return Nothing
|
||||||
where
|
where
|
||||||
mpath a = joinPath a ++ "cabal-dev/"
|
mpath a = joinPath a </> "cabal-dev/"
|
||||||
|
4
Check.hs
4
Check.hs
@ -1,7 +1,6 @@
|
|||||||
module Check (checkSyntax) where
|
module Check (checkSyntax) where
|
||||||
|
|
||||||
import Cabal
|
import Cabal
|
||||||
import CabalDev (modifyOptions)
|
|
||||||
import Control.Applicative
|
import Control.Applicative
|
||||||
import CoreMonad
|
import CoreMonad
|
||||||
import ErrMsg
|
import ErrMsg
|
||||||
@ -14,8 +13,7 @@ import Types
|
|||||||
|
|
||||||
checkSyntax :: Options -> String -> IO String
|
checkSyntax :: Options -> String -> IO String
|
||||||
checkSyntax opt file = do
|
checkSyntax opt file = do
|
||||||
opt' <- modifyOptions opt
|
unlines <$> check opt file
|
||||||
unlines <$> check opt' file
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
module Main where
|
module Main where
|
||||||
|
|
||||||
|
import CabalDev (modifyOptions)
|
||||||
import Browse
|
import Browse
|
||||||
import Check
|
import Check
|
||||||
import Control.Applicative
|
import Control.Applicative
|
||||||
@ -89,8 +90,8 @@ instance Exception GHCModError
|
|||||||
main :: IO ()
|
main :: IO ()
|
||||||
main = flip catches handlers $ do
|
main = flip catches handlers $ do
|
||||||
args <- getArgs
|
args <- getArgs
|
||||||
let (opt,cmdArg) = parseArgs argspec args
|
let (opt',cmdArg) = parseArgs argspec args
|
||||||
res <- case safelist cmdArg 0 of
|
res <- modifyOptions opt' >>= \opt -> case safelist cmdArg 0 of
|
||||||
"browse" -> concat <$> mapM (browseModule opt) (tail cmdArg)
|
"browse" -> concat <$> mapM (browseModule opt) (tail cmdArg)
|
||||||
"list" -> listModules opt
|
"list" -> listModules opt
|
||||||
"check" -> withFile (checkSyntax opt) (safelist cmdArg 1)
|
"check" -> withFile (checkSyntax opt) (safelist cmdArg 1)
|
||||||
|
Loading…
Reference in New Issue
Block a user