summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Lynagh <igloo@earth.li>2007-08-28 12:47:59 +0000
committerIan Lynagh <igloo@earth.li>2007-08-28 12:47:59 +0000
commit18e4fea8fcd804d0f164d06aec9f96bb9435a338 (patch)
treed7474226fc6d65d1a30ff49887fb32b89d5a7fb7
parent83a8c81a9c000da9bbef3b91572b1820c55ccc19 (diff)
downloadhaskell-18e4fea8fcd804d0f164d06aec9f96bb9435a338.tar.gz
Make some header-installing machinery, and use it to install gmp.h
-rw-r--r--gmp/Makefile11
-rw-r--r--mk/config.mk.in3
-rw-r--r--mk/install.mk8
3 files changed, 20 insertions, 2 deletions
diff --git a/gmp/Makefile b/gmp/Makefile
index f09c52384f..82de987dad 100644
--- a/gmp/Makefile
+++ b/gmp/Makefile
@@ -40,8 +40,9 @@ BUILD_SHARED=no
endif
boot :: stamp.gmp.static
-all :: libgmp.a
-install :: libgmp.a
+all :: gmp.h libgmp.a
+install :: gmp.h libgmp.a
+INSTALL_HEADERS += gmp.h
INSTALL_LIBS += libgmp.a
ifeq "$(BUILD_SHARED)" "yes"
@@ -76,6 +77,9 @@ stamp.gmp.shared:
--enable-shared=yes --disable-static --host=$(PLATFORM) --build=$(PLATFORM)
touch $@
+gmp.h: stamp.gmp.static
+ $(CP) gmpbuild/gmp.h .
+
libgmp.a: stamp.gmp.static
$(MAKE) -C gmpbuild MAKEFLAGS=
$(CP) gmpbuild/.libs/libgmp.a .
@@ -114,6 +118,9 @@ endif
ifneq "$(INSTALL_LIBS)" ""
$(INSTALL_DATA) $(INSTALL_LIBS) $(BIN_DIST_DIR)/gmp/
endif
+ifneq "$(INSTALL_HEADERS)" ""
+ $(INSTALL_HEADER) $(INSTALL_HEADERS) $(BIN_DIST_DIR)/gmp/
+endif
endif
endif
diff --git a/mk/config.mk.in b/mk/config.mk.in
index 741abd3c9c..5b89981c2a 100644
--- a/mk/config.mk.in
+++ b/mk/config.mk.in
@@ -546,6 +546,8 @@ datadir = $(datadir0)/ghc-$(ProjectVersion)
endif # Windows
+headerdir = $(libdir)/include
+
# Default place for putting interface files is $(libdir)
# (overriden for packages in package.mk)
ifacedir = $(libdir)
@@ -608,6 +610,7 @@ INSTALL_PROGRAM = $(INSTALL) -m 755
INSTALL_SCRIPT = $(INSTALL) -m 755
INSTALL_SHLIB = $(INSTALL) -m 755
INSTALL_DATA = $(INSTALL) -m 644
+INSTALL_HEADER = $(INSTALL) -m 644
INSTALL_MAN = $(INSTALL) -m 644
INSTALL_DIR = $(MKDIRHIER)
diff --git a/mk/install.mk b/mk/install.mk
index 61de7a5663..75d0569e3c 100644
--- a/mk/install.mk
+++ b/mk/install.mk
@@ -243,6 +243,14 @@ install:: $(INSTALL_DATAS)
done
endif
+ifneq "$(strip $(INSTALL_HEADERS))" ""
+install:: $(INSTALL_HEADERS)
+ @$(INSTALL_DIR) $(headerdir)
+ for i in $(INSTALL_HEADERS); do \
+ $(INSTALL_HEADER) $(INSTALL_OPTS) $$i $(headerdir); \
+ done
+endif
+
ifneq "$(strip $(INSTALL_IFACES))" ""
install:: $(INSTALL_IFACES)
@$(INSTALL_DIR) $(ifacedir)