-#################################################################################
+################################################################################
#
# paths.mk
#
# This file defines Make variables for standard directories
# and file lists
#
-#################################################################################
+################################################################################
-
-#-----------------------------------------------------------------
-#
-# Installation setup
-#
-
-#-----------------------------------------------------------------------------
-# install configuration
-#
-# The install standard target is guided by the following four variables
-#
-# INSTALL_PROGS (installed in $(bindir))
-# INSTALL_LIBS (installed in $(libdir))
-# INSTALL_LIBEXECS (installed in $(libexecdir))
-# INSTALL_DATAS (installed in $(datadir))
-# INSTALL_IFACES (installed in $(ifacedir))
-#
-# see target.mk for more information.
-#
-
-#
-# Setting user/group ownership for the installed entities
-#
-# this stuff about "who" does the installing doesn't have make vars
-# as it is not intended to be run-time changeable.
-#
-ifneq "$(OWNER)" ""
-INSTALL_OWNER = -o $(OWNER)
-else
-INSTALL_OWNER =
-endif
-
-ifneq "$(GROUP)" ""
-INSTALL_GROUP = -g $(GROUP)
-else
-INSTALL_GROUP =
-endif
-
-SRC_INSTALL_OPTS += $(INSTALL_OWNER) $(INSTALL_GROUP)
-
-#
-# Invocations of `install' for the four different classes
-# of targets:
-#
-
-INSTALL_PROGRAM = $(INSTALL) -m 755
-INSTALL_SCRIPT = $(INSTALL) -m 755
-INSTALL_SHLIB = $(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.
-#
-
-#################################################################################
+################################################################################
#
# Standard variable names
#
-#################################################################################
+################################################################################
# The fptools mk setup defines a set of standard names which are used
# by the standard targets provided by mk. One example of this is the
# use of standard names for specifying what files to compile, their
ALL_SRCS = $(wildcard $(patsubst ./%, %, \
$(patsubst %,%/*.hs, . $(ALL_DIRS)) \
$(patsubst %,%/*.lhs, . $(ALL_DIRS)) \
+ $(patsubst %,%/*.hs-boot, . $(ALL_DIRS)) \
+ $(patsubst %,%/*.lhs-boot, . $(ALL_DIRS)) \
$(patsubst %,%/*.y, . $(ALL_DIRS)) \
$(patsubst %,%/*.ly, . $(ALL_DIRS)) \
$(patsubst %,%/*.x, . $(ALL_DIRS)) \
PRE_HS_SRCS = $(filter %.hs, $(PRE_SRCS))
PRE_LHS_SRCS = $(filter %.lhs, $(PRE_SRCS))
+PRE_HS_BOOT_SRCS = $(filter %.hs-boot, $(PRE_SRCS)) \
+ $(filter %.lhs-boot, $(PRE_SRCS))
+
GC_SRCS = $(filter %.gc, $(PRE_SRCS))
HSC_SRCS = $(filter %.hsc, $(PRE_SRCS))
HAPPY_Y_SRCS = $(filter %.y, $(PRE_SRCS))
HS_OBJS = $(addsuffix .$(way_)o,$(basename $(HS_SRCS)))
HS_IFACES = $(addsuffix .$(way_)hi,$(basename $(HS_SRCS)))
+HI_BOOTS = $(patsubst %.hs-boot, %.$(way_)hi-boot, \
+ $(patsubst %.lhs-boot, %.$(way_)hi-boot, $(PRE_HS_BOOT_SRCS)))
+
+O_BOOTS = $(patsubst %.hs-boot, %.$(way_)o-boot, \
+ $(patsubst %.lhs-boot, %.$(way_)o-boot, $(PRE_HS_BOOT_SRCS)))
+
GC_C_OBJS = $(addsuffix _stub_ffi.$(way_)o,$(basename $(filter %.gc,$(SRCS))))
HSC_C_OBJS = $(addsuffix _hsc.$(way_)o,$(basename $(filter %.hsc,$(SRCS))))
endif
# These are droppings from hsc2hs - ignore them if we see them.
-EXCLUDED_C_SRCS = $(patsubst %.hsc, %_hsc_make.c, $(HSC_SRCS))
+EXCLUDED_C_SRCS += $(patsubst %.hsc, %_hsc_make.c, $(HSC_SRCS))
-C_SRCS = $(filter-out $(EXCLUDED_C_SRCS),$(filter %.c,$(SRCS)))
+C_SRCS = $(filter-out $(EXCLUDED_C_SRCS),$(filter %.c %.S,$(SRCS)))
C_OBJS = $(addsuffix .$(way_)o,$(basename $(C_SRCS)))
# SCRIPT_SRCS: list of raw script files (in literate form)
#
# NOTE: $(SCRIPT_OBJS) is not in MOSTLY_CLEAN_FILES, because in some
# places in the tree it appears that we have source files in $(SCRIPT_OBJS).
-# Specifically glafp-utils/mkdependC/mkdependC.prl and others in ghc/driver and
+# Specifically glafp-utils/mkdependC/mkdependC.prl and others in driver/ and
# possibly others elsewhere in the tree. ToDo: fix this properly.
MOSTLY_CLEAN_FILES += $(HS_OBJS) $(C_OBJS) $(HSC_C_OBJS) $(GC_C_OBJS)
CLEAN_FILES += $(HS_PROG) $(C_PROG) $(SCRIPT_PROG) $(SCRIPT_LINK) \
$(PROG) $(LIBRARY) a.out \
$(DERIVED_HSC_SRCS) \
$(DERIVED_GC_SRCS) \
- $(patsubst %,%/*.$(way_)hi, . $(ALL_DIRS))
+ $(patsubst %,%/*.$(way_)hi, . $(ALL_DIRS)) \
+ $(HI_BOOTS) $(O_BOOTS)
# we delete *all* the .hi files we can find, rather than just
# $(HS_IFACES), because stale interfaces left around by modules which
*.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.
-#
-SRC_DIST_NAME=$(ProjectNameShort)-$(ProjectVersion)
-
-#
-# Binary distributions proceeds as follows:
-#
-# Fromthe top of a build tree, you do `make binary-dist'. The
-# canned rule for this (in target.mk) will then do a binary
-# install to a temporary directory before packaging it all up.
-# The following variables guide the binary-dist:
-#
-# BIN_DIST_TMPDIR= the absolute path to where the temporary directory
-# structure of a binary distribution should be created.
-# [Default: toplevel from which you issue `make binary-dist']
-# BIN_DIST_NAME= what to call the thing.
-#
-# 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)
-#
-# The layout of a binary distribution is described in the
-# installation documentation.
-#
-
# 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
+#------------------------------------------------------------------
+#
+# Stylesheet for HTML generated from DocBook XML
+#
+
+FPTOOLS_CSS = fptools.css
+FPTOOLS_CSS_ABS = $(FPTOOLS_TOP)/mk/$(FPTOOLS_CSS)