Build: tidying
[users/jgh/exim.git] / src / OS / Makefile-Base
index b4345e86f541043c1e89aaaa8353c48b49f94651..26f06eca6eaf45901d2af7d0bb48e00f2d90d28a 100644 (file)
@@ -123,24 +123,43 @@ config.h: Makefile buildconfig ../src/config.h.defaults $(EDITME)
 
 # 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 $(INCLUDE) -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