projects
/
apps
/
pfixtools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Factorize code.
[apps/pfixtools.git]
/
Makefile
diff --git
a/Makefile
b/Makefile
index
0e9e02c
..
5508e3d
100644
(file)
--- a/
Makefile
+++ b/
Makefile
@@
-34,21
+34,24
@@
all:
LDFLAGS += -Wl,--warn-common
include mk/cflags.mk
LDFLAGS += -Wl,--warn-common
include mk/cflags.mk
+include mk/tc.mk
CFLAGS += --std=gnu99 -D_GNU_SOURCE
prefix ?= /usr/local
PROGRAMS = postlicyd pfix-srsd
CFLAGS += --std=gnu99 -D_GNU_SOURCE
prefix ?= /usr/local
PROGRAMS = postlicyd pfix-srsd
+LIBS = lib
TESTS = tst-rbl
GENERATED = tokens.h tokens.c
TESTS = tst-rbl
GENERATED = tokens.h tokens.c
-postlicyd_SOURCES = common.c threads.c str.c buffer.c rbl.c \
- $(GENERATED) postfix.c main-postlicyd.c
-postlicyd_LIBADD = -lpthread
+lib_SOURCES = str.c buffer.c common.c epoll.c server.c $(GENERATED)
-pfix-srsd_SOURCES = common.c epoll.c buffer.c str.c main-srsd.c
-pfix-srsd_LIBADD = -lsrs2
+postlicyd_SOURCES = greylist.c rbl.c main-postlicyd.c lib.a
+postlicyd_LIBADD = $(TC_LIBS)
+
+pfix-srsd_SOURCES = main-srsd.c lib.a
+pfix-srsd_LIBADD = -lsrs2
tst-rbl_SOURCES = tst-rbl.c
tst-rbl_SOURCES = tst-rbl.c
@@
-62,7
+65,7
@@
install: all
all: $(GENERATED) $(PROGRAMS) | $(GENERATED)
clean:
all: $(GENERATED) $(PROGRAMS) | $(GENERATED)
clean:
- $(RM) $(PROGRAMS) $(TESTS) .*.o .*.dep
+ $(RM) $(
LIBS:=.a) $(
PROGRAMS) $(TESTS) .*.o .*.dep
distclean: clean
$(RM) $(GENERATED)
distclean: clean
$(RM) $(GENERATED)
@@
-71,7
+74,7
@@
tags: .tags
.tags: $(shell git ls-files | egrep '\.[hc]$$')
ctags -o $@ $^
.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 )
headers:
@which headache > /dev/null || \
( echo "package headache not installed" ; exit 1 )
@@
-84,14
+87,19
@@
headers:
./$< $@ || ($(RM) $@; exit 1)
.%.o: %.c Makefile
./$< $@ || ($(RM) $@; exit 1)
.%.o: %.c Makefile
+ $(shell test -d $(@D) || mkdir -p $(@D))
$(CC) $(CFLAGS) -MMD -MT ".$*.dep $@" -MF .$*.dep -g -c -o $@ $<
.%.dep: .%.o
.SECONDEXPANSION:
$(CC) $(CFLAGS) -MMD -MT ".$*.dep $@" -MF .$*.dep -g -c -o $@ $<
.%.dep: .%.o
.SECONDEXPANSION:
+$(LIBS:=.a): $$(patsubst %.c,.%.o,$$($$(patsubst %.a,%,$$@)_SOURCES)) Makefile
+ $(RM) $@
+ $(AR) rcs $@ $(filter %.o,$^)
+
$(PROGRAMS) $(TESTS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile common.ld
$(PROGRAMS) $(TESTS): $$(patsubst %.c,.%.o,$$($$@_SOURCES)) Makefile common.ld
- $(CC) -o $@ $(
CFLAGS) $($@_CFLAGS) $(
filter %.ld,$^) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^)
+ $(CC) -o $@ $(filter %.ld,$^) $(filter %.o,$^) $(LDFLAGS) $($@_LIBADD) $(filter %.a,$^)
-include $(foreach p,$(PROGRAMS) $(TESTS),$(patsubst %.c,.%.dep,$(filter %.c,$($p_SOURCES))))
-include $(foreach p,$(PROGRAMS) $(TESTS),$(patsubst %.c,.%.dep,$(filter %.c,$($p_SOURCES))))