summaryrefslogtreecommitdiff
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
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.
-rw-r--r--libraries/cabal-bin.hs19
-rw-r--r--mk/cabal-flags.mk2
2 files changed, 12 insertions, 9 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
diff --git a/mk/cabal-flags.mk b/mk/cabal-flags.mk
index bfa11a84b0..e1ef084b46 100644
--- a/mk/cabal-flags.mk
+++ b/mk/cabal-flags.mk
@@ -7,7 +7,7 @@ GHC_PKG_INSTALL_PROG = $(FPTOOLS_TOP_ABS)/utils/ghc-pkg/dist-install/build/ghc-p
LIBRARIES_ABS = $(FPTOOLS_TOP_ABS)/libraries
UTILS_ABS = $(FPTOOLS_TOP_ABS)/utils
-CABAL = $(LIBRARIES_ABS)/cabal-bin $(GHC) $(LIBRARIES_ABS)/bootstrapping.conf
+CABAL = $(LIBRARIES_ABS)/cabal-bin $(GHC) $(LIBRARIES_ABS)/bootstrapping.conf $(CABAL_DOTTED_VERSION)
INSTALL_PACKAGE = \
$(UTILS_ABS)/installPackage/install-inplace/bin/installPackage
STAGE3_PACKAGE_CONF = $(FPTOOLS_TOP_ABS)/stage3.package.conf