summaryrefslogtreecommitdiff
path: root/hadrian
diff options
context:
space:
mode:
authorAlp Mestanogullari <alpmestan@gmail.com>2019-02-28 15:20:14 +0100
committerBen Gamari <ben@well-typed.com>2019-03-04 10:18:41 -0500
commit22c2713bcc30cea9da7d8b95f3ea99357d1551f7 (patch)
treea94938d22842886530265ddf6f8a7c49261cb954 /hadrian
parente2ae52c34e81123dce9991fad393d96fd7b7af6a (diff)
downloadhaskell-22c2713bcc30cea9da7d8b95f3ea99357d1551f7.tar.gz
Hadrian: track mingw, ship it in bindists, more robust install script
Diffstat (limited to 'hadrian')
-rw-r--r--hadrian/src/Base.hs8
-rw-r--r--hadrian/src/Builder.hs4
-rw-r--r--hadrian/src/Rules/BinaryDist.hs82
-rw-r--r--hadrian/src/Rules/Program.hs13
-rw-r--r--hadrian/src/Settings/Builders/Cabal.hs4
5 files changed, 84 insertions, 27 deletions
diff --git a/hadrian/src/Base.hs b/hadrian/src/Base.hs
index 7949fcf4b2..47d9107669 100644
--- a/hadrian/src/Base.hs
+++ b/hadrian/src/Base.hs
@@ -25,7 +25,7 @@ module Base (
hadrianPath, configPath, configFile, sourcePath, shakeFilesDir,
generatedDir, generatedPath, stageBinPath, stageLibPath, templateHscPath,
ghcDeps, includesDependencies, haddockDeps, relativePackageDbPath,
- packageDbPath, packageDbStamp,
+ packageDbPath, packageDbStamp, mingwStamp,
ghcSplitPath
) where
@@ -143,3 +143,9 @@ templateHscPath stage = stageLibPath stage <&> (-/- "template-hsc.h")
-- to the build root under which we will copy @ghc-split@.
ghcSplitPath :: Stage -> FilePath
ghcSplitPath stage = stageString stage -/- "bin" -/- "ghc-split"
+
+-- | We use this stamp file to track whether we've moved the mingw toolchain
+-- under the build root (to make it accessible to the GHCs we build on
+-- Windows). See "Rules.Program".
+mingwStamp :: FilePath
+mingwStamp = "mingw" -/- ".stamp"
diff --git a/hadrian/src/Builder.hs b/hadrian/src/Builder.hs
index 38d21b3fdd..b56f9c1071 100644
--- a/hadrian/src/Builder.hs
+++ b/hadrian/src/Builder.hs
@@ -186,6 +186,10 @@ instance H.Builder Builder where
++ ghcdeps
++ ghcgens
++ [ touchyPath | win ]
+ ++ [ root -/- mingwStamp | win ]
+ -- proxy for the entire mingw toolchain that
+ -- we have in inplace/mingw initially, and then at
+ -- root -/- mingw.
Hsc2Hs stage -> (\p -> [p]) <$> templateHscPath stage
Make dir -> return [dir -/- "Makefile"]
diff --git a/hadrian/src/Rules/BinaryDist.hs b/hadrian/src/Rules/BinaryDist.hs
index 03740cdad9..d54ac3d140 100644
--- a/hadrian/src/Rules/BinaryDist.hs
+++ b/hadrian/src/Rules/BinaryDist.hs
@@ -100,6 +100,7 @@ bindistRules = do
targetPlatform <- setting TargetPlatformFull
distDir <- Context.distDir
rtsDir <- pkgIdentifier rts
+ windows <- windowsHost
let ghcBuildDir = root -/- stageString Stage1
bindistFilesDir = root -/- "bindist" -/- ghcVersionPretty
@@ -115,6 +116,12 @@ bindistRules = do
copyDirectory (rtsIncludeDir) bindistFilesDir
need ["docs"]
copyDirectory (root -/- "docs") bindistFilesDir
+ when windows $ do
+ copyDirectory (root -/- "mingw") bindistFilesDir
+ -- we use that opportunity to delete the .stamp file that we use
+ -- as a proxy for the whole mingw toolchain, there's no point in
+ -- shipping it
+ removeFile (bindistFilesDir -/- mingwStamp)
-- We copy the binary (<build root>/stage1/bin/haddock) to
-- the bindist's bindir (<build root>/bindist/ghc-.../bin/).
@@ -132,7 +139,8 @@ bindistRules = do
, "runghc"]
-- Finally, we create the archive <root>/bindist/ghc-X.Y.Z-platform.tar.xz
- command [Cwd $ root -/- "bindist"] "tar"
+ tarPath <- builderPath (Tar Create)
+ cmd [Cwd $ root -/- "bindist"] tarPath
[ "-c", "--xz", "-f"
, ghcVersionPretty <.> "tar.xz"
, ghcVersionPretty ]
@@ -224,19 +232,19 @@ bindistMakefile = unlines
, "# to it. This implementation is a bit hacky and depends on consistency"
, "# of program names. For hadrian build this will work as programs have a"
, "# consistent naming procedure."
- , "\trm -f $2"
- , "\t$(CREATE_SCRIPT) $2"
- , "\t@echo \"#!$(SHELL)\" >> $2"
- , "\t@echo \"exedir=\\\"$4\\\"\" >> $2"
- , "\t@echo \"exeprog=\\\"$1\\\"\" >> $2"
- , "\t@echo \"executablename=\\\"$5\\\"\" >> $2"
- , "\t@echo \"bindir=\\\"$3\\\"\" >> $2"
- , "\t@echo \"libdir=\\\"$6\\\"\" >> $2"
- , "\t@echo \"docdir=\\\"$7\\\"\" >> $2"
- , "\t@echo \"includedir=\\\"$8\\\"\" >> $2"
- , "\t@echo \"\" >> $2 "
- , "\tcat wrappers/$1 >> $2"
- , "\t$(EXECUTABLE_FILE) $2 ;"
+ , "\trm -f '$2'"
+ , "\t$(CREATE_SCRIPT) '$2'"
+ , "\t@echo \"#!$(SHELL)\" >> '$2'"
+ , "\t@echo \"exedir=\\\"$4\\\"\" >> '$2'"
+ , "\t@echo \"exeprog=\\\"$1\\\"\" >> '$2'"
+ , "\t@echo \"executablename=\\\"$5\\\"\" >> '$2'"
+ , "\t@echo \"bindir=\\\"$3\\\"\" >> '$2'"
+ , "\t@echo \"libdir=\\\"$6\\\"\" >> '$2'"
+ , "\t@echo \"docdir=\\\"$7\\\"\" >> '$2'"
+ , "\t@echo \"includedir=\\\"$8\\\"\" >> '$2'"
+ , "\t@echo \"\" >> '$2'"
+ , "\tcat wrappers/$1 >> '$2'"
+ , "\t$(EXECUTABLE_FILE) '$2' ;"
, "endef"
, ""
, "# Hacky function to patch up the 'haddock-interfaces' and 'haddock-html'"
@@ -245,10 +253,10 @@ bindistMakefile = unlines
, "# $1 = package name (ex: 'bytestring')"
, "# $2 = path to .conf file"
, "# $3 = Docs Directory"
- , "\tcat $2 | sed 's|haddock-interfaces.*|haddock-interfaces: $3/html/libraries/$1/$1.haddock|' \\"
- , "\t | sed 's|haddock-html.*|haddock-html: $3/html/libraries/$1|' \\"
- , "\t > $2.copy"
- , "\tmv $2.copy $2"
+ , "\tcat '$2' | sed 's|haddock-interfaces.*|haddock-interfaces: $3/html/libraries/$1/$1.haddock|' \\"
+ , "\t | sed 's|haddock-html.*|haddock-html: $3/html/libraries/$1|' \\"
+ , "\t > '$2.copy'"
+ , "\tmv '$2.copy' '$2'"
, "endef"
, ""
, "# QUESTION : should we use shell commands?"
@@ -257,7 +265,7 @@ bindistMakefile = unlines
, ".PHONY: install"
, "install: install_lib install_bin install_includes"
, "install: install_docs install_wrappers install_ghci"
- , "install: update_package_db"
+ , "install: install_mingw update_package_db"
, ""
, "ActualBinsDir=${ghclibdir}/bin"
, "WrapperBinsDir=${bindir}"
@@ -273,10 +281,10 @@ bindistMakefile = unlines
, ""
, "install_ghci:"
, "\t@echo \"Copying and installing ghci\""
- , "\t$(CREATE_SCRIPT) $(WrapperBinsDir)/ghci"
- , "\t@echo \"#!$(SHELL)\" >> $(WrapperBinsDir)/ghci"
- , "\tcat wrappers/ghci-script >> $(WrapperBinsDir)/ghci"
- , "\t$(EXECUTABLE_FILE) $(WrapperBinsDir)/ghci"
+ , "\t$(CREATE_SCRIPT) '$(WrapperBinsDir)/ghci'"
+ , "\t@echo \"#!$(SHELL)\" >> '$(WrapperBinsDir)/ghci'"
+ , "\tcat wrappers/ghci-script >> '$(WrapperBinsDir)/ghci'"
+ , "\t$(EXECUTABLE_FILE) '$(WrapperBinsDir)/ghci'"
, ""
, "LIBRARIES = $(wildcard ./lib/*)"
, "install_lib:"
@@ -302,7 +310,7 @@ bindistMakefile = unlines
, "\t\tcp -R $$i \"$(docdir)/\"; \\"
, "\tdone"
, ""
- , "BINARY_NAMES=$(shell ls ./bin/)"
+ , "BINARY_NAMES=$(shell ls ./wrappers/)"
, "install_wrappers:"
, "\t@echo \"Installing Wrapper scripts\""
, "\t$(INSTALL_DIR) \"$(WrapperBinsDir)\""
@@ -318,8 +326,16 @@ bindistMakefile = unlines
, "\t\t$(call patchpackageconf," ++
"$(shell echo $(notdir $p) | sed 's/-\\([0-9]*[0-9]\\.\\)*conf//g')," ++
"$p,$(docdir)))"
- , "\t$(WrapperBinsDir)/ghc-pkg recache"
+ , "\t'$(WrapperBinsDir)/ghc-pkg' recache"
, ""
+ , "# The 'foreach' that copies the mingw directory will only trigger a copy"
+ , "# when the wildcard matches, therefore only on Windows."
+ , "MINGW = $(wildcard ./mingw)"
+ , "install_mingw:"
+ , "\t@echo \"Installing MingGW\""
+ , "\t$(INSTALL_DIR) \"$(prefix)/mingw\""
+ , "\t$(foreach d, $(MINGW),\\"
+ , "\t\tcp -R ./mingw \"$(prefix)\")"
, "# END INSTALL"
, "# ----------------------------------------------------------------------"
]
@@ -385,3 +401,19 @@ ghciScriptWrapper = unlines
[ "DIR=`dirname \"$0\"`"
, "executable=\"$DIR/ghc\""
, "exec $executable --interactive \"$@\"" ]
+
+-- | When not on Windows, we want to ship the 3 flavours of the iserv program
+-- in binary distributions. This isn't easily achievable by just asking for
+-- the package to be built, since here we're generating 3 different
+-- executables out of just one package, so we need to specify all 3 contexts
+-- explicitly and 'need' the result of building them.
+needIservBins :: Action ()
+needIservBins = do
+ windows <- windowsHost
+ when (not windows) $ do
+ rtsways <- interpretInContext (vanillaContext Stage1 ghc) getRtsWays
+ need =<< traverse programPath
+ [ Context Stage1 iserv w
+ | w <- [vanilla, profiling, dynamic]
+ , w `elem` rtsways
+ ]
diff --git a/hadrian/src/Rules/Program.hs b/hadrian/src/Rules/Program.hs
index 51bc2e9959..86ac88f1bb 100644
--- a/hadrian/src/Rules/Program.hs
+++ b/hadrian/src/Rules/Program.hs
@@ -8,6 +8,7 @@ import Context
import Expression hiding (stage, way)
import Oracles.Flag
import Oracles.ModuleFiles
+import Oracles.Setting (topDirectory)
import Packages
import Settings
import Settings.Default
@@ -18,6 +19,18 @@ import Utilities
buildProgramRules :: [(Resource, Int)] -> Rules ()
buildProgramRules rs = do
root <- buildRootRules
+
+ -- Proxy rule for the whole mingw toolchain on Windows.
+ -- We 'need' configure because that's when the inplace/mingw
+ -- folder gets filled with the toolchain. This "proxy" rule
+ -- is listed as a runtime dependency for stage >= 1 GHCs.
+ root -/- mingwStamp %> \stampPath -> do
+ top <- topDirectory
+ need [ top -/- "configure" ]
+ copyDirectory (top -/- "inplace" -/- "mingw") root
+ writeFile' stampPath "OK"
+
+ -- Rules for programs that are actually built by hadrian.
forM_ [Stage0 ..] $ \stage ->
[ root -/- stageString stage -/- "bin" -/- "*"
, root -/- stageString stage -/- "lib/bin" -/- "*" ] |%> \bin -> do
diff --git a/hadrian/src/Settings/Builders/Cabal.hs b/hadrian/src/Settings/Builders/Cabal.hs
index 8eedcde2b3..e759206029 100644
--- a/hadrian/src/Settings/Builders/Cabal.hs
+++ b/hadrian/src/Settings/Builders/Cabal.hs
@@ -16,6 +16,8 @@ cabalBuilderArgs = builder (Cabal Setup) ? do
pkg <- getPackage
path <- getContextPath
stage <- getStage
+ windows <- expr windowsHost
+ let prefix = "${pkgroot}" ++ (if windows then "" else "/..")
mconcat [ arg "configure"
-- Don't strip libraries when cross compiling.
-- TODO: We need to set @--with-strip=(stripCmdPath :: Action FilePath)@,
@@ -32,7 +34,7 @@ cabalBuilderArgs = builder (Cabal Setup) ? do
, arg "--ipid"
, arg "$pkg-$version"
, arg "--prefix"
- , arg "${pkgroot}/.."
+ , arg prefix
-- NB: this is valid only because Hadrian puts the @docs@ and
-- @libraries@ folders in the same relative position: