X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=Makefile;h=a0f9786804638cd00e2bd365706e5cc854a1b8f2;hb=fe76fd38b19d62a8b4cdaba0b4d02a847c53e389;hp=d51a0ce8a9b98986cd93a876401ff46d73193601;hpb=adfa05b77d1516ddeb61694d81de291cb76f0f2b;p=apps%2Fpfixtools.git diff --git a/Makefile b/Makefile index d51a0ce..a0f9786 100644 --- 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 # # ~~~~~~~~~ # # ________________________________________________________________________ # # # @@ -29,31 +29,43 @@ # THE POSSIBILITY OF SUCH DAMAGE. # ############################################################################## +all: + LDFLAGS += -Wl,--warn-common include mk/cflags.mk -include mk/dflags.mk +include mk/tc.mk -CFLAGS += --std=gnu99 -D_GNU_SOURCE -D_FORTIFY_SOURCE=2 +CFLAGS += --std=gnu99 -D_GNU_SOURCE +prefix ?= /usr/local -PROGRAMS = postlicyd +PROGRAMS = postlicyd pfix-srsd +LIBS = lib +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) +lib_SOURCES = threads.c str.c buffer.c common.c epoll.c $(GENERATED) + +postlicyd_SOURCES = greylist.c rbl.c main-postlicyd.c lib.a +postlicyd_LIBADD = -lpthread $(TC_LIBS) + +pfix-srsd_SOURCES = main-srsd.c lib.a +pfix-srsd_LIBADD = -lsrs2 -postlicyd_LIBADD = -lanl +tst-rbl_SOURCES = tst-rbl.c + +install: all + install -d $(DESTDIR)$(prefix)/sbin + install $(PROGRAMS) $(DESTDIR)$(prefix)/sbin + install -d $(DESTDIR)/etc/pfixtools # RULES ###################################################################{{{ -all: $(PROGRAMS) $(GENERATED) | $(GENERATED) +all: $(GENERATED) $(PROGRAMS) | $(GENERATED) clean: - $(RM) $(PROGRAMS) - $(RM) .*.o + $(RM) $(LIBS:=.a) $(PROGRAMS) $(TESTS) .*.o .*.dep distclean: clean $(RM) $(GENERATED) @@ -62,7 +74,7 @@ tags: .tags .tags: $(shell git ls-files | egrep '\.[hc]$$') ctags -o $@ $^ -headers: HEADACHEOPTS=-c mk/headache.cfg -h COPYING +headers: HEADACHEOPTS=-c mk/headache.cfg -h mk/COPYING headers: @which headache > /dev/null || \ ( echo "package headache not installed" ; exit 1 ) @@ -74,20 +86,21 @@ headers: %.c: %.sh ./$< $@ || ($(RM) $@; exit 1) -.%.o: %.d Makefile - $(DC) $(DFLAGS) -g -c -o $@ $< - .%.o: %.c Makefile + $(shell test -d $(@D) || mkdir -p $(@D)) $(CC) $(CFLAGS) -MMD -MT ".$*.dep $@" -MF .$*.dep -g -c -o $@ $< -%.dep: %.c Makefile - $(CC) $(CFLAGS) -MM -MT ".$*.dep $@" -MF .$*.dep $< +.%.dep: .%.o .SECONDEXPANSION: -$(PROGRAMS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile - $(DC) -o $@ $(CFLAGS) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^) +$(LIBS:=.a): $$(patsubst %.c,.%.o,$$($$(patsubst %.a,%,$$@)_SOURCES)) Makefile + $(RM) $@ + $(AR) rcs $@ $(filter %.o,$^) + +$(PROGRAMS) $(TESTS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile common.ld + $(CC) -o $@ $(filter %.ld,$^) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^) --include $(foreach p,$(PROGRAMS),$(patsubst %.c,.%.dep,$(filter %.c,$($p_SOURCES)))) +-include $(foreach p,$(PROGRAMS) $(TESTS),$(patsubst %.c,.%.dep,$(filter %.c,$($p_SOURCES)))) ###########################################################################}}}