# Build (link) the os.h file
+#os.h: $(SCRIPTS)/Configure-os.h \
+# $(O)/os.h-AIX $(O)/os.h-BSDI $(O)/os.h-cygwin \
+# $(O)/os.h-Darwin $(O)/os.h-DGUX $(O)/os.h-DragonFly \
+# $(O)/os.h-FreeBSD $(O)/os.h-GNU $(O)/os.h-GNUkFreeBSD \
+# $(O)/os.h-GNUkNetBSD $(O)/os.h-HI-OSF \
+# $(O)/os.h-HI-UX $(O)/os.h-HP-UX $(O)/os.h-HP-UX-9 \
+# $(O)/os.h-IRIX $(O)/os.h-IRIX6 $(O)/os.h-IRIX632 \
+# $(O)/os.h-IRIX65 $(O)/os.h-Linux $(O)/os.h-mips \
+# $(O)/os.h-NetBSD $(O)/os.h-NetBSD-a.out \
+# $(O)/os.h-OpenBSD $(O)/os.h-OpenUNIX $(O)/os.h-OSF1 \
+# $(O)/os.h-QNX $(O)/os.h-SCO $(O)/os.h-SCO_SV \
+# $(O)/os.h-SunOS4 $(O)/os.h-SunOS5 $(O)/os.h-SunOS5-hal \
+# $(O)/os.h-ULTRIX $(O)/os.h-UNIX_SV \
+# $(O)/os.h-Unixware7 $(O)/os.h-USG
+# $(SHELL) $(SCRIPTS)/Configure-os.h
+
os.h: $(SCRIPTS)/Configure-os.h \
- $(O)/os.h-AIX $(O)/os.h-BSDI $(O)/os.h-cygwin \
- $(O)/os.h-Darwin $(O)/os.h-DGUX $(O)/os.h-DragonFly \
- $(O)/os.h-FreeBSD $(O)/os.h-GNU $(O)/os.h-GNUkFreeBSD \
- $(O)/os.h-GNUkNetBSD $(O)/os.h-HI-OSF \
- $(O)/os.h-HI-UX $(O)/os.h-HP-UX $(O)/os.h-HP-UX-9 \
- $(O)/os.h-IRIX $(O)/os.h-IRIX6 $(O)/os.h-IRIX632 \
- $(O)/os.h-IRIX65 $(O)/os.h-Linux $(O)/os.h-mips \
- $(O)/os.h-NetBSD $(O)/os.h-NetBSD-a.out \
- $(O)/os.h-OpenBSD $(O)/os.h-OpenUNIX $(O)/os.h-OSF1 \
- $(O)/os.h-QNX $(O)/os.h-SCO $(O)/os.h-SCO_SV \
- $(O)/os.h-SunOS4 $(O)/os.h-SunOS5 $(O)/os.h-SunOS5-hal \
- $(O)/os.h-ULTRIX $(O)/os.h-UNIX_SV \
- $(O)/os.h-Unixware7 $(O)/os.h-USG
+ $(O)/os.h-FreeBSD \
+ $(O)/os.h-Linux \
+ $(O)/os.h-OpenBSD \
+ $(O)/os.h-SunOS5
$(SHELL) $(SCRIPTS)/Configure-os.h
# Build the os.c file
+#os.c: ../src/os.c \
+# $(SCRIPTS)/Configure-os.c \
+# $(O)/os.c-cygwin $(O)/os.c-GNU $(O)/os.c-HI-OSF \
+# $(O)/os.c-IRIX $(O)/os.c-IRIX6 $(O)/os.c-IRIX632 \
+# $(O)/os.c-IRIX65 $(O)/os.c-Linux $(O)/os.c-OSF1
+# $(SHELL) $(SCRIPTS)/Configure-os.c
+
os.c: ../src/os.c \
$(SCRIPTS)/Configure-os.c \
- $(O)/os.c-cygwin $(O)/os.c-GNU $(O)/os.c-HI-OSF \
- $(O)/os.c-IRIX $(O)/os.c-IRIX6 $(O)/os.c-IRIX632 \
- $(O)/os.c-IRIX65 $(O)/os.c-Linux $(O)/os.c-OSF1
+ $(O)/os.c-Linux
$(SHELL) $(SCRIPTS)/Configure-os.c
# Build the config.h file.
# Build the builtin-macros data struct
-MACRO_CSRC = macro_predef.c globals.c readconf.c route.c transport.c \
- drtables.c \
- transports/appendfile.c transports/autoreply.c transports/lmtp.c \
- transports/pipe.c transports/queuefile.c transports/smtp.c \
- routers/accept.c routers/dnslookup.c routers/ipliteral.c \
- routers/iplookup.c routers/manualroute.c routers/queryprogram.c \
- routers/redirect.c \
- auths/auth-spa.c auths/cram_md5.c auths/cyrus_sasl.c auths/dovecot.c \
- auths/gsasl_exim.c auths/heimdal_gssapi.c auths/plaintext.c auths/spa.c \
- auths/tls.c
-MACRO_HSRC = macro_predef.h os.h globals.h config.h \
+MACRO_HSRC = predef.h os.h globals.h config.h \
routers/accept.h routers/dnslookup.h routers/ipliteral.h \
routers/iplookup.h routers/manualroute.h routers/queryprogram.h \
routers/redirect.h
-macro_predef: $(MACRO_CSRC) $(MACRO_HSRC)
- @echo "$(CC) -DMACRO_PREDEF macro_predef.c"
- $(FE)$(CC) $(CFLAGS) -DMACRO_PREDEF -o macro_predef $(MACRO_CSRC)
+OBJ_MACRO_PLAIN = macro-predef.o \
+ macro-globals.o macro-readconf.o macro-route.o macro-transport.o macro-drtables.o \
+ macro-dkim.o
+OBJ_MACRO_TP = \
+ macro-appendfile.o macro-autoreply.o macro-lmtp.o macro-pipe.o macro-queuefile.o \
+ macro-smtp.o
+OBJ_MACRO_RT = \
+ macro-accept.o macro-dnslookup.o macro-ipliteral.o macro-iplookup.o \
+ macro-manualroute.o macro-queryprogram.o macro-redirect.o
+OBJ_MACRO_AU = \
+ macro-auth-spa.o macro-cram_md5.o macro-cyrus_sasl.o macro-dovecot.o macro-gsasl_exim.o \
+ macro-heimdal_gssapi.o macro-plaintext.o macro-spa.o macro-tls.o
+
+OBJ_MACRO = $(OBJ_MACRO_PLAIN) $(OBJ_MACRO_TP) $(OBJ_MACRO_RT) $(OBJ_MACRO_AU)
+$(OBJ_MACRO): $(MACRO_HSRC)
+
+$(OBJ_MACRO_PLAIN): macro-%.o : %.c
+ @echo "$(CC) -DMACRO_PREDEF $<"
+ $(FE)$(CC) -c $(CFLAGS) -DMACRO_PREDEF $(INCLUDE) -o $@ $<
+$(OBJ_MACRO_TP): macro-%.o : transports/%.c
+ @echo "$(CC) -DMACRO_PREDEF $<"
+ $(FE)$(CC) -c $(CFLAGS) -DMACRO_PREDEF $(INCLUDE) -o $@ $<
+$(OBJ_MACRO_RT): macro-%.o : routers/%.c
+ @echo "$(CC) -DMACRO_PREDEF $<"
+ $(FE)$(CC) -c $(CFLAGS) -DMACRO_PREDEF $(INCLUDE) -o $@ $<
+$(OBJ_MACRO_AU): macro-%.o : auths/%.c
+ @echo "$(CC) -DMACRO_PREDEF $<"
+ $(FE)$(CC) -c $(CFLAGS) -DMACRO_PREDEF $(INCLUDE) -o $@ $<
+
+macro_predef: $(OBJ_MACRO)
+ @echo "$(LNCC) -o $@"
+ $(FE)$(LNCC) -o $@ $(LFLAGS) $(OBJ_MACRO)
macro.c: macro_predef
./macro_predef > macro.c
util-store.o \
util-string.o \
util-queue.o \
- tod.o \
+ util-tod.o \
tree.o \
$(MONBIN)
exim_dbmbuild.o: $(HDRS) exim_dbmbuild.c
@echo "$(CC) exim_dbmbuild.c"
- $(FE)$(CC) -c $(CFLAGS) $(INCLUDE) -o exim_dbmbuild.o exim_dbmbuild.c
+ $(FE)$(CC) -c $(CFLAGS) $(INCLUDE) -DCOMPILE_UTILITY \
+ -o exim_dbmbuild.o exim_dbmbuild.c
# Utilities use special versions of some modules - typically with debugging
# calls cut out.
@echo "$(CC) -DCOMPILE_UTILITY queue.c"
$(FE)$(CC) -c $(CFLAGS) $(INCLUDE) -DCOMPILE_UTILITY -o util-queue.o queue.c
+util-tod.o: $(HDRS) tod.c
+ @echo "$(CC) -DCOMPILE_UTILITY tod.c"
+ $(FE)$(CC) -c $(CFLAGS) $(INCLUDE) -DCOMPILE_UTILITY -o util-tod.o tod.c
+
util-os.o: $(HDRS) os.c
@echo "$(CC) -DCOMPILE_UTILITY os.c"
$(FE)$(CC) -c $(CFLAGS) $(INCLUDE) \