Rename project -> pfixtools.
[apps/pfixtools.git] / Makefile
index 2f96388..948c575 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,5 +1,5 @@
 ##############################################################################
-#          postlicyd: a postfix policy daemon with a lot of features         #
+#          pfixtools: a collection of postfix related tools                  #
 #          ~~~~~~~~~                                                         #
 #  ________________________________________________________________________  #
 #                                                                            #
 #  THE POSSIBILITY OF SUCH DAMAGE.                                           #
 ##############################################################################
 
+LDFLAGS += -Wl,--warn-common
+
 include mk/cflags.mk
-CFLAGS += --std=gnu99 -D_GNU_SOURCE -D_FORTIFY_SOURCE=2
 
-PROGRAMS = postlicyd
+CFLAGS += --std=gnu99 -D_GNU_SOURCE
+
+PROGRAMS = postlicyd srsd
+TESTS    = tst-rbl
 
 GENERATED = tokens.h tokens.c
 
-postlicyd_SOURCES = \
-               str.h buffer.h job.h postfix.h gai.h \
-               str.c buffer.c job.c postfix.c gai.c \
-               postlicyd.c $(GENERATED)
+postlicyd_SOURCES = common.c str.c buffer.c daemon.c rbl.c postfix.c \
+                   $(GENERATED) postlicyd.c
+postlicyd_LIBADD = -lpthread
 
-postlicyd_LIBADD = -lanl
+srsd_SOURCES = common.c buffer.c str.c daemon.c srsd.c
+srsd_LIBADD = -lsrs2
+
+tst-rbl_SOURCES = tst-rbl.c
 
 # RULES ###################################################################{{{
 
-all: $(PROGRAMS)
+all: $(PROGRAMS) $(GENERATED) | $(GENERATED)
 
 clean:
-       $(RM) $(PROGRAMS)
-       $(RM) .*.o
+       $(RM) $(PROGRAMS) $(TESTS) .*.o .*.dep
 
 distclean: clean
        $(RM) $(GENERATED)
@@ -64,23 +69,22 @@ headers:
                ( echo "package headache not installed" ; exit 1 )
        @git ls-files | egrep '(\.h|\.c|Makefile|*\.mk)$$' | xargs -t headache $(HEADACHEOPTS)
 
-%.c: %.sh
+%.h: %.sh
        ./$< $@ || ($(RM) $@; exit 1)
 
-%.h: %.sh
+%.c: %.sh
        ./$< $@ || ($(RM) $@; exit 1)
 
 .%.o: %.c Makefile
-       $(CC) $(CFLAGS) -MMD -MT ".$*.d $@" -MF .$*.d -g -c -o $@ $<
+       $(CC) $(CFLAGS) -MMD -MT ".$*.dep $@" -MF .$*.dep -g -c -o $@ $<
 
-%.d: %.c Makefile
-       $(CC) $(CFLAGS) -MM -MT ".$*.d $@" -MF .$*.d $<
+.%.dep: .%.o
 
 .SECONDEXPANSION:
 
-$(PROGRAMS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile
-       $(CC) -o $@ $(CFLAGS) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^)
+$(PROGRAMS) $(TESTS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile common.ld
+       $(CC) -o $@ $(CFLAGS) $($@_CFLAGS) $(filter %.ld,$^) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^)
 
--include $(foreach p,$(PROGRAMS),$(patsubst %.c,.%.d,$(filter %.c,$($p_SOURCES))))
+-include $(foreach p,$(PROGRAMS) $(TESTS),$(patsubst %.c,.%.dep,$(filter %.c,$($p_SOURCES))))
 
 ###########################################################################}}}