summaryrefslogtreecommitdiff
path: root/libraries/cabal-bin.hs
diff options
context:
space:
mode:
authorIan Lynagh <igloo@earth.li>2008-12-03 12:32:08 +0000
committerIan Lynagh <igloo@earth.li>2008-12-03 12:32:08 +0000
commita7ccc4e6878c9256d4634a91776f2f09ad60b117 (patch)
tree44992c5dab131d504c2b712997da165da01d176f /libraries/cabal-bin.hs
parent74f14cbc3c51135809977b29427c7c6a2af2cc34 (diff)
downloadhaskell-a7ccc4e6878c9256d4634a91776f2f09ad60b117.tar.gz
We need to tell cabal-bin which version of Cabal to use
Otherwise, if the bootstrapping compiler has a newer version, we get a mismatch between the version used to compile ghc-prim's Setup.hs and the version that installPackage uses.
Diffstat (limited to 'libraries/cabal-bin.hs')
-rw-r--r--libraries/cabal-bin.hs19
1 files changed, 11 insertions, 8 deletions
diff --git a/libraries/cabal-bin.hs b/libraries/cabal-bin.hs
index ed72a1e6e7..664480f5a2 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