# of targets:
#
-INSTALL_PROGRAM = $(INSTALL)
+INSTALL_PROGRAM = $(INSTALL) -m 755
+INSTALL_SCRIPT = $(INSTALL) -m 755
INSTALL_DATA = $(INSTALL) -m 644
INSTALL_DIR = $(FPTOOLS_TOP)/glafp-utils/mkdirhier/mkdirhier
#
# The install variables does not have any defaults,
# what files to install have to be specified in the Makefiles.
-#
+#
#INSTALL_PROGS += $(HS_PROG) $(C_PROG)
#INSTALL_LIBS += $(LIBRARY)
#INSTALL_DATAS += $(HS_IFACES)
-#-----------------------------------------------------------------------------
-# Man pages & Documentation
-#
-# (AFAIK, not currently used)
-#
-
-#man1dir = $(mandir)/man1
-#manext = '.1'
-#man1ext = '.1'
-#man2dir = $(mandir)/man2
-#man2ext = '.2'
-#man3dir = $(mandir)/man3
-#man3ext = '.3'
-#man4dir = $(mandir)/man4
-#man4ext = '.4'
-#man5dir = $(mandir)/man5
-#man5ext = '.5'
-#man6dir = $(mandir)/man6
-#man6ext = '.6'
-#man7dir = $(mandir)/man7
-#man7ext = '.7'
-#man8dir = $(mandir)/man8
-#man8ext = '.8'
-
-## top of manual page tree to install in
-## NB: not necessarily the same place as to look for man pages (?)
-#INSTALL_MAN_ROOT = $(mandir)
-
-## prefix for man page _sources_ (vs .../cat)
-#INSTALL_MAN_SRCROOT = $(INSTALL_MAN_ROOT)/man
-
-## man pages for commands
-#INSTALL_COMMAND_DIR = $(INSTALL_MAN_SRCROOT)$(COMMANSUFFIX)
-
-## man pages for library routines
-#INSTALL_LIB_MANDIR = $(INSTALL_MAN_SRCROOT)$(LIBMANSUFFIX)
-
-## man pages for system commands
-#INSTALL_SYS_MANDIR = $(INSTALL_MAN_SRCROOT)$(SYSMANSUFFIX)
-
-## suffix for installing commands'/etcs' man pages
-#COMMANSUFFIX = 1
-#LIBMANSUFFIX = 3
-#SYSMANSUFFIX = 8
-
-INSTALL_INFO_DIR = $(infodir)
-
-
-INSTALL_FILE_OPTS =
-INSTALL_STRIP =
-INSTALL_BIN_OPTS = \
- -m 0755 $(INSTALL_OWNER) $(INSTALL_GROUP) $(INSTALL_FILE_FLAGS) $(INSTALL_STRIP)
-
-
-
-
-
#################################################################################
#
# Standard variable names
# link your program.
#
# The general rules:
-#
+#
# SRCS - sources, might be prefixed to indicate what type of source
# they are.
# OBJS - object files (possibly prefixed).
#
# PROG - name of final executable
-#
-#
+
+# We attempt to automatically devine the list of sources $(SRCS) to
+# compile by looking in the current directory. This is complicated by
+# the fact that a .hsc file gives rise to a .hs file (which needs to
+# be automatically included in $(SRCS)), but the .hs file might
+# already be present in the current directory and we don't want to
+# compile it twice.
+
+# So we figure out the sources in three stages: first figure out
+# what's in the current directory (this is $(PRE_SRCS)). Then figure
+# out all the "derived" sources (eg. A.hsc generates A.hs and
+# A_hsc.c), and finally put all these together and remove duplicates
+# (GNU make's handy sort function does the duplicate removing).
#
# BOOT_SRCS: list of machine generated Haskell modules.
# HS_SRCS: list of Haskell modules you want to compile.
# (caveat: assuming no funny use of -hisuf and that
# file name and module name match)
-SRCS=$(wildcard *.lhs *.hs *.c *.lc *.prl *.lprl *.lit *.verb)
+PRE_SRCS = $(wildcard *.lhs *.hs *.c *.prl *.lprl *.lit *.verb *.hsc)
+
+HSC_SRCS = $(filter %.hsc, $(PRE_SRCS))
+DERIVED_SRCS = $(patsubst %.hsc, %.hs, $(HSC_SRCS)) \
+ $(patsubst %.hsc, %_hsc.c, $(HSC_SRCS)) \
+ $(patsubst %.hsc, %_hsc.h, $(HSC_SRCS))
+
+# EXCLUDED_SRCS can be set in the Makefile, otherwise it defaults to empty.
+EXCLUDED_HSC_SRCS = $(filter %.hsc, $(EXCLUDED_SRCS))
+EXCLUDED_DERIVED_SRCS = $(patsubst %.hsc, %.hs, $(EXCLUDED_HSC_SRCS)) \
+ $(patsubst %.hsc, %_hsc.h, $(EXCLUDED_HSC_SRCS)) \
+ $(patsubst %.hsc, %_hsc.c, $(HSC_SRCS))
+# Exclude _hsc.c files; they get built as part of the cbits library,
+# not part of the main library
+
+CLOSED_EXCLUDED_SRCS = $(sort $(EXCLUDED_SRCS) $(EXCLUDED_DERIVED_SRCS))
-HS_SRCS=$(filter %.lhs %.hs %.hc,$(SRCS))$(BOOT_SRCS)
-HS_OBJS=$(addsuffix .$(way_)o,$(basename $(HS_SRCS)))
-HS_IFACES=$(addsuffix .$(way_)hi,$(basename $(HS_SRCS)))
+SRCS = $(filter-out $(CLOSED_EXCLUDED_SRCS), \
+ $(sort $(PRE_SRCS) $(DERIVED_SRCS)))
-C_SRCS=$(filter %.lc %.c,$(SRCS))
-C_OBJS=$(addsuffix .$(way_)o,$(basename $(C_SRCS)))
+HS_SRCS = $(filter %.lhs %.hs %.hc,$(sort $(SRCS) $(BOOT_SRCS)))
+HS_OBJS = $(addsuffix .$(way_)o,$(basename $(HS_SRCS)))
+HS_HCS = $(addsuffix .$(way_)hc,$(basename $(HS_SRCS)))
+HS_SS = $(addsuffix .$(way_)s,$(basename $(HS_SRCS)))
+HS_IFACES = $(addsuffix .$(way_)hi,$(basename $(HS_SRCS)))
+
+HSC_C_OBJS = $(addsuffix _hsc.$(way_)o,$(basename $(filter %.hsc,$(SRCS))))
+
+C_SRCS = $(filter %.c,$(SRCS))
+C_OBJS = $(addsuffix .$(way_)o,$(basename $(C_SRCS)))
# SCRIPT_SRCS: list of raw script files (in literate form)
# SCRIPT_OBJS: de-litted scripts
#
#------------------------------------------------------------------
+#
+# make depend defaults
+#
+# The default set of files for the dependency generators to work on
+# is just their source equivalents.
+#
+
+ifneq "$(BootingFromHc)" "YES"
+MKDEPENDHS_SRCS=$(HS_SRCS)
+else
+MKDEPENDHS_SRCS=
+endif
+
+MKDEPENDC_SRCS=$(C_SRCS)
+
+#------------------------------------------------------------------
+#
+# make TAGS defaults
+#
+# The default set of files for the dependency generators to work on
+# is just their source equivalents.
+#
+TAGS_HS_SRCS=$(HS_SRCS)
+TAGS_C_SRCS=$(C_SRCS)
+
+#------------------------------------------------------------------
# Clean file make-variables.
#
# The following three variables are used to control
-# what gets removed when doing `make clean'
+# what gets removed when doing `make clean'
#
# MOSTLYCLEAN_FILES object code etc., but not stuff
# that is slow to recompile and/or stable
# that may require extra tools to create.
#
#
-MOSTLY_CLEAN_FILES += $(HS_OBJS) $(C_OBJS)
-CLEAN_FILES += $(HS_PROG) $(C_PROG) $(SCRIPT_PROG) $(PROG) $(LIBRARY) \
- $(HS_IFACES) \
- a.out core
-MAINTAINER_CLEAN_FILES += .depend $(BOOT_SRCS)
+MOSTLY_CLEAN_FILES += $(HS_OBJS) $(C_OBJS) $(HSC_C_OBJS)
+CLEAN_FILES += $(HS_PROG) $(C_PROG) $(SCRIPT_PROG) $(SCRIPT_LINK) \
+ $(PROG) $(LIBRARY) $(HS_IFACES) $(HS_SS) a.out \
+ $(DERIVED_SRCS)
+
+# Don't clean the .hc files if we're bootstrapping
+ifneq "$(BootingFromHc)" "YES"
+CLEAN_FILES += $(HS_HCS)
+endif
+
+DIST_CLEAN_FILES += .depend
+MAINTAINER_CLEAN_FILES += $(BOOT_SRCS)
#
# `Standard' set of files to clean out.
#
MOSTLY_CLEAN_FILES += \
- *.CKP *.ln *.BAK *.bak *.o core a.out errs ,* *.a .emacs_* \
+ *.CKP *.ln *.BAK *.bak .*.bak *.o core a.out errs ,* *.a .emacs_* \
tags TAGS *.ind *.ilg *.idx *.idx-prev *.aux *.aux-prev *.dvi *.log \
- *.toc *.lot *.lof *.blg *.info *.itxi *.itex *.ihtml *.cb
-
-#------------------------------------------------------------------
-# Documentation setup.
-#
-# Documentation is not normally produced via the default target, but
-# selectively through a set of standard targets (e.g, dvi, html, etc., see
-# target.mk). Here we define the variables (and their default settings),
-# that control the operation of these standard targets.
-#
-# Documentation variables:
-#
-# DOC_SRCS = list of documents you want to generate various
-# forms of documentation from.
-# DOC_DVI = list of DVI files to generate.
-# DOC_HTML = list of HTML files to generate
-# DOC_TEXI = list of TexInfo files to generate
-# DOC_TEXT = list of simple text files to generate
-#
-DOC_SRCS=$(wildcard *.tex *.lit)
-DOC_DVI =$(addsuffix .dvi,$(basename $(DOC_SRCS)))
-DOC_PS =$(addsuffix .ps,$(basename $(DOC_SRCS)))
-DOC_TEXI=$(addsuffix .texi,$(basename $(DOC_SRCS)))
-DOC_HTML=$(addsuffix .html,$(basename $(DOC_SRCS)))
-DOC_TEXT=$(addsuffix .txt,$(basename $(DOC_SRCS)))
-
-CLEAN_FILES += $(DOC_TEXT) $(DOC_HTML) $(DOC_TEXI) $(DOC_PS) $(DOC_DVI)
+ *.toc *.lot *.lof *.blg *.cb *_stub.c *_stub.h *.raw_s *.a.list
#------------------------------------------------------------------
#
# Distribution setup
-#
+#
# Following variables are used for creating source and binary distributions:
#
# SRC_DIST_NAME && BIN_DIST_NAME -- the package names
#
# SRC_DIST_FILES = list of extra files to include from a build tree into a source
# distribution
-#
+#
# SRC_DIST_DIR = what the current directory in the source/build tree
# maps to in the source distrib. tree being created.
#
#
# BIN_DIST_DIRS= at the toplevel, list of directories to descend into when
# building the distribution tree.
-#
+#
# An extra directory variable that is set during bin-dists is $(bindist_top), giving
# the abs. path to the root of the binary installation tree. (useful when punting
# stuff like README and ANNOUNCE into a distrib, for instance)
#
+# Directory in which DLLs are dumped so as not to get picked up by running
+# programs (e.g. ghc or hsc) that run in the build tree
+
+DLL_PEN = $(FPTOOLS_TOP)/dll
+