summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Lynagh <ian@well-typed.com>2013-03-11 20:12:36 +0000
committerIan Lynagh <ian@well-typed.com>2013-03-11 23:27:27 +0000
commiteabd61a476cfe6d546360cd5d0ab0074282a19f7 (patch)
tree7f4fef81f73012c27a028790e8a1e542cc5a5a6d
parent8aefdc085bea0e20f79d16c417507a36ba2d0f8f (diff)
downloadhaskell-eabd61a476cfe6d546360cd5d0ab0074282a19f7.tar.gz
Update Cabal
m---------libraries/Cabal0
-rw-r--r--rules/build-package-data.mk13
-rw-r--r--utils/ghc-cabal/Main.hs33
-rw-r--r--utils/ghc-cabal/ghc.mk2
-rw-r--r--utils/ghctags/Main.hs9
5 files changed, 33 insertions, 24 deletions
diff --git a/libraries/Cabal b/libraries/Cabal
-Subproject 7e2bdc37dbb3c6bafc0287e93fd922360818cda
+Subproject 24bdc9b8862d228656ea2b5b0bd6307cb985819
diff --git a/rules/build-package-data.mk b/rules/build-package-data.mk
index 0380f7c5e5..bcd863fe62 100644
--- a/rules/build-package-data.mk
+++ b/rules/build-package-data.mk
@@ -18,8 +18,14 @@ $(call profStart, build-package-data($1,$2,$3))
# $2 = distdir
# $3 = GHC stage to use (0 == bootstrapping compiler)
+$1_$2_CONFIGURE_OPTS += --disable-library-for-ghci
ifeq "$$(filter v,$$($1_$2_WAYS))" "v"
$1_$2_CONFIGURE_OPTS += --enable-library-vanilla
+ifeq "$$(GhcWithInterpreter)" "YES"
+ifneq "$$(DYNAMIC_BY_DEFAULT)" "YES"
+$1_$2_CONFIGURE_OPTS += --enable-library-for-ghci
+endif
+endif
else
$1_$2_CONFIGURE_OPTS += --disable-library-vanilla
endif
@@ -36,13 +42,6 @@ else
$1_$2_CONFIGURE_OPTS += --disable-shared
endif
-$1_$2_CONFIGURE_OPTS += --disable-library-for-ghci
-ifeq "$$(GhcWithInterpreter)" "YES"
-ifneq "$$(DYNAMIC_BY_DEFAULT)" "YES"
-$1_$2_CONFIGURE_OPTS += --enable-library-for-ghci
-endif
-endif
-
ifeq "$$(HSCOLOUR_SRCS)" "YES"
$1_$2_CONFIGURE_OPTS += --with-hscolour="$$(HSCOLOUR_CMD)"
endif
diff --git a/utils/ghc-cabal/Main.hs b/utils/ghc-cabal/Main.hs
index 6878afe3bb..3ecae9bbc4 100644
--- a/utils/ghc-cabal/Main.hs
+++ b/utils/ghc-cabal/Main.hs
@@ -218,18 +218,15 @@ doRegister ghc ghcpkg topdir directory distDir
let Just ghcPkgProg = lookupProgram ghcPkgProgram' progs'
instInfos <- dump verbosity ghcPkgProg GlobalPackageDB
let installedPkgs' = PackageIndex.fromList instInfos
- let mlc = libraryConfig lbi
- mlc' = case mlc of
- Just lc ->
- let cipds = componentPackageDeps lc
- cipds' = [ (fixupPackageId instInfos ipid, pid)
- | (ipid,pid) <- cipds ]
- in Just $ lc {
- componentPackageDeps = cipds'
- }
- Nothing -> Nothing
+ let updateComponentConfig (cn, clbi, deps)
+ = (cn, updateComponentLocalBuildInfo clbi, deps)
+ updateComponentLocalBuildInfo (ComponentLocalBuildInfo cpds)
+ = ComponentLocalBuildInfo
+ [ (fixupPackageId instInfos ipid, pid)
+ | (ipid,pid) <- cpds ]
+ ccs' = map updateComponentConfig (componentsConfigs lbi)
lbi' = lbi {
- libraryConfig = mlc',
+ componentsConfigs = ccs',
installedPkgs = installedPkgs',
installDirTemplates = idts,
withPrograms = progs'
@@ -309,8 +306,13 @@ generate config_args distdir directory
-- generate Paths_<pkg>.hs and cabal-macros.h
writeAutogenFiles verbosity pd lbi
+ let findLibraryConfig [] = Nothing
+ findLibraryConfig ((CLibName, clbi, _) : _) = Just clbi
+ findLibraryConfig (_ : xs) = findLibraryConfig xs
+ mLibraryConfig = findLibraryConfig (componentsConfigs lbi)
+
-- generate inplace-pkg-config
- case (library pd, libraryConfig lbi) of
+ case (library pd, mLibraryConfig) of
(Nothing, Nothing) -> return ()
(Just lib, Just clbi) -> do
cwd <- getCurrentDirectory
@@ -323,7 +325,12 @@ generate config_args distdir directory
}
content = Installed.showInstalledPackageInfo final_ipi ++ "\n"
writeFileAtomic (distdir </> "inplace-pkg-config") (BS.pack $ toUTF8 content)
- _ -> error "Inconsistent lib components; can't happen?"
+ (Just _, Nothing) ->
+ -- There is a library, but we aren't building it
+ -- Happens e.g. with haddock, which has both a library
+ -- and executable in its .cabal file.
+ return ()
+ (Nothing, Just _) -> die ["Library local build info, but no library in package description"]
let
libBiModules lib = (libBuildInfo lib, libModules lib)
diff --git a/utils/ghc-cabal/ghc.mk b/utils/ghc-cabal/ghc.mk
index c80c4ef7ef..bb0a35ecd6 100644
--- a/utils/ghc-cabal/ghc.mk
+++ b/utils/ghc-cabal/ghc.mk
@@ -14,7 +14,7 @@
# Euch, hideous hack:
# XXX This should be in a different Makefile
-CABAL_DOTTED_VERSION := $(shell grep "^Version:" libraries/Cabal/Cabal/Cabal.cabal | sed "s/^Version: //")
+CABAL_DOTTED_VERSION := $(shell grep "^version:" libraries/Cabal/Cabal/Cabal.cabal | sed "s/^version: //")
CABAL_VERSION := $(subst .,$(comma),$(CABAL_DOTTED_VERSION))
CABAL_CONSTRAINT := --constraint="Cabal == $(CABAL_DOTTED_VERSION)"
diff --git a/utils/ghctags/Main.hs b/utils/ghctags/Main.hs
index 514f2998c0..a4cb302c92 100644
--- a/utils/ghctags/Main.hs
+++ b/utils/ghctags/Main.hs
@@ -18,13 +18,12 @@ import FastString
import MonadUtils ( liftIO )
import SrcLoc
--- Every GHC comes with Cabal anyways, so this is not a bad new dependency
import Distribution.Simple.GHC ( componentGhcOptions )
import Distribution.Simple.Configure ( getPersistBuildConfig )
import Distribution.Simple.Compiler ( compilerVersion )
import Distribution.Simple.Program.GHC ( renderGhcOptions )
import Distribution.PackageDescription ( library, libBuildInfo )
-import Distribution.Simple.LocalBuildInfo ( localPkgDescr, buildDir, libraryConfig, compiler )
+import Distribution.Simple.LocalBuildInfo
import qualified Distribution.Verbosity as V
import Control.Monad hiding (mapM)
@@ -183,7 +182,11 @@ flagsFromCabal :: FilePath -> IO [String]
flagsFromCabal distPref = do
lbi <- getPersistBuildConfig distPref
let pd = localPkgDescr lbi
- case (library pd, libraryConfig lbi) of
+ findLibraryConfig [] = Nothing
+ findLibraryConfig ((CLibName, clbi, _) : _) = Just clbi
+ findLibraryConfig (_ : xs) = findLibraryConfig xs
+ mLibraryConfig = findLibraryConfig (componentsConfigs lbi)
+ case (library pd, mLibraryConfig) of
(Just lib, Just clbi) ->
let bi = libBuildInfo lib
odir = buildDir lbi