[commit: ghc] master: detect 'autoreconf' path during configure, and use it in hadrian (f77229e)
git at git.haskell.org
git at git.haskell.org
Mon Mar 4 21:04:50 UTC 2019
Repository : ssh://git@git.haskell.org/ghc
On branch : master
Link : http://ghc.haskell.org/trac/ghc/changeset/f77229e3c30fa9e353c061dc038a5d0b2ee01c48/ghc
>---------------------------------------------------------------
commit f77229e3c30fa9e353c061dc038a5d0b2ee01c48
Author: Alp Mestanogullari <alpmestan at gmail.com>
Date: Tue Feb 26 11:21:55 2019 +0100
detect 'autoreconf' path during configure, and use it in hadrian
>---------------------------------------------------------------
f77229e3c30fa9e353c061dc038a5d0b2ee01c48
configure.ac | 3 +++
hadrian/cfg/system.config.in | 2 +-
hadrian/src/Builder.hs | 14 +++++++++++++-
3 files changed, 17 insertions(+), 2 deletions(-)
diff --git a/configure.ac b/configure.ac
index e5ea091..1aae465 100644
--- a/configure.ac
+++ b/configure.ac
@@ -817,6 +817,9 @@ dnl ** check for patch
dnl if GNU patch is named gpatch, look for it first
AC_PATH_PROGS(PatchCmd,gpatch patch, patch)
+dnl ** check for autoreconf
+AC_PATH_PROG(AutoreconfCmd, autoreconf, autoreconf)
+
dnl ** check for dtrace (currently only implemented for Mac OS X)
AC_ARG_ENABLE(dtrace,
[AC_HELP_STRING([--enable-dtrace],
diff --git a/hadrian/cfg/system.config.in b/hadrian/cfg/system.config.in
index 7b92b29..4cae2b6 100644
--- a/hadrian/cfg/system.config.in
+++ b/hadrian/cfg/system.config.in
@@ -7,7 +7,7 @@
alex = @AlexCmd@
ar = @ArCmd@
-autoreconf = autoreconf
+autoreconf = @AutoreconfCmd@
cc = @CC@
happy = @HappyCmd@
hs-cpp = @HaskellCPPCmd@
diff --git a/hadrian/src/Builder.hs b/hadrian/src/Builder.hs
index 02edb19..38d21b3 100644
--- a/hadrian/src/Builder.hs
+++ b/hadrian/src/Builder.hs
@@ -288,7 +288,7 @@ systemBuilderPath builder = case builder of
Alex -> fromKey "alex"
Ar _ Stage0 -> fromKey "system-ar"
Ar _ _ -> fromKey "ar"
- Autoreconf _ -> fromKey "autoreconf"
+ Autoreconf _ -> stripExe =<< fromKey "autoreconf"
Cc _ Stage0 -> fromKey "system-cc"
Cc _ _ -> fromKey "cc"
-- We can't ask configure for the path to configure!
@@ -329,6 +329,18 @@ systemBuilderPath builder = case builder of
(True , True ) -> fixAbsolutePathOnWindows fullPath
(True , False) -> fixAbsolutePathOnWindows fullPath <&> (<.> exe)
+ -- Without this function, on Windows we can observe a bad builder path
+ -- for 'autoreconf'. If the relevant system.config field is set to
+ -- /usr/bin/autoreconf in the file, the path that we read
+ -- is C:/msys64/usr/bin/autoreconf.exe. A standard msys2 set up happens
+ -- to have an executable named 'autoreconf' there, without the 'exe'
+ -- extension. Hence this function.
+ stripExe s = do
+ let sNoExt = dropExtension s
+ exists <- doesFileExist s
+ if exists then return s else return sNoExt
+
+
-- | Was the path to a given system 'Builder' specified in configuration files?
isSpecified :: Builder -> Action Bool
isSpecified = fmap (not . null) . systemBuilderPath
More information about the ghc-commits
mailing list