X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=libraries%2Fcabal-bin.hs;h=664480f5a2d5a088ce599294dcd48db26f27c5df;hp=ed72a1e6e78cbcf3428a0643effd0c24480c45fa;hb=d305c6b68e06368c2a8d89900a2123388fc39ae1;hpb=a452fa83dd70fa01a049fbb59d1c829832af0191 diff --git a/libraries/cabal-bin.hs b/libraries/cabal-bin.hs index ed72a1e..664480f 100644 --- a/libraries/cabal-bin.hs +++ b/libraries/cabal-bin.hs @@ -23,12 +23,12 @@ main = do unprocessedArgs <- getArgs let verbosity = verbose case unprocessedArgs of - ghc : packageConf : args -> - doit verbosity ghc packageConf args + ghc : packageConf : useCabalVersion : args -> + doit verbosity ghc packageConf useCabalVersion args _ -> die "Bad args" -doit :: Verbosity -> FilePath -> FilePath -> [String] -> IO () -doit verbosity ghc packageConf args = do +doit :: Verbosity -> FilePath -> FilePath -> String -> [String] -> IO () +doit verbosity ghc packageConf useCabalVersion args = do exists <- doesFileExist setupProg if exists then rawSystemExit verbosity setupProg args else do @@ -42,16 +42,19 @@ doit verbosity ghc packageConf args = do _ | packageName pd == PackageName "Cabal" -> -- Cabal is special...*sigh* Simple.defaultMainArgs args - | otherwise -> runSetup verbosity ghc packageConf args + | otherwise -> + runSetup verbosity ghc packageConf useCabalVersion args -runSetup :: Verbosity -> FilePath -> FilePath -> [String] -> IO () -runSetup verbosity ghc packageConf args = do +runSetup :: Verbosity -> FilePath -> FilePath -> String -> [String] -> IO () +runSetup verbosity ghc packageConf useCabalVersion args = do -- Don't bother building Setup if we are cleaning. If we need to -- build Setup in order to build, and Setup isn't built already, -- then there shouldn't be anything to clean anyway. unless cleaning $ rawSystemExit verbosity ghc ["-package-conf", packageConf, - "--make", "Setup", "-o", "Setup"] + "--make", "Setup", + "-package", "Cabal-" ++ useCabalVersion, + "-o", "Setup"] rawSystemExit verbosity "./Setup" args where cleaning = case args of "clean" : _ -> True