aboutsummaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
authorJohannes Berg <johannes@sipsolutions.net>2008-05-31 11:27:02 +0200
committerJohannes Berg <johannes@sipsolutions.net>2008-05-31 11:27:02 +0200
commitd1553f1417896deea5f534518a19ad92d9ecbcb9 (patch)
tree8e4650c8127b674790ca481307885a0a06214d18 /Makefile
parent5a2cb64e4da591bea59a38fc4363ace858063930 (diff)
downloaddovecot-antispam-d1553f1417896deea5f534518a19ad92d9ecbcb9.tar.gz
dovecot-antispam-d1553f1417896deea5f534518a19ad92d9ecbcb9.tar.xz
dovecot-antispam-d1553f1417896deea5f534518a19ad92d9ecbcb9.zip
auto-detect dovecot version
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile53
1 files changed, 26 insertions, 27 deletions
diff --git a/Makefile b/Makefile
index e73b6a1..866c739 100644
--- a/Makefile
+++ b/Makefile
@@ -8,16 +8,16 @@ INSTALLDIR ?= $(moduledir)/imap
CFLAGS := $(CFLAGSORIG)
# includes/flags we need for building a dovecot plugin
-CFLAGS += -DHAVE_CONFIG_H
-CFLAGS += -I$(DOVECOT)/
-CFLAGS += -I$(DOVECOT)/src/
-CFLAGS += -I$(DOVECOT)/src/lib/
-CFLAGS += -I$(DOVECOT)/src/lib-storage/
-CFLAGS += -I$(DOVECOT)/src/lib-mail/
-CFLAGS += -I$(DOVECOT)/src/lib-imap/
-CFLAGS += -I$(DOVECOT)/src/lib-dict/
-CFLAGS += -I$(DOVECOT)/src/lib-index/
-CFLAGS += -I$(DOVECOT)/src/imap/
+INCS += -DHAVE_CONFIG_H
+INCS += -I$(DOVECOT)/
+INCS += -I$(DOVECOT)/src/
+INCS += -I$(DOVECOT)/src/lib/
+INCS += -I$(DOVECOT)/src/lib-storage/
+INCS += -I$(DOVECOT)/src/lib-mail/
+INCS += -I$(DOVECOT)/src/lib-imap/
+INCS += -I$(DOVECOT)/src/lib-dict/
+INCS += -I$(DOVECOT)/src/lib-index/
+INCS += -I$(DOVECOT)/src/imap/
# output name
LIBRARY_NAME ?= lib90_$(PLUGINNAME)_plugin.so
@@ -35,16 +35,6 @@ ifeq ("$(DEBUG_VERBOSE)", "1")
CFLAGS += -DCONFIG_DEBUG_VERBOSE
endif
-# dovecot version rules
-objs += antispam-storage-$(DOVECOT_VERSION).o
-ifeq ("$(DOVECOT_VERSION)", "1.0")
-CFLAGS += -DCONFIG_DOVECOT_10
-else
-ifeq ("$(DOVECOT_VERSION)", "1.1")
-CFLAGS += -DCONFIG_DOVECOT_11
-endif
-endif
-
# backend error check
ifeq ("$(BACKEND)", "")
error: verify_config
@@ -66,20 +56,29 @@ endif
# main make rules
CFLAGS += -fPIC -shared -Wall -Wextra -DPLUGINNAME=$(PLUGINNAME)
CC ?= "gcc"
+HOSTCC ?= "gcc"
-objs += antispam-plugin.o $(BACKEND).o
-ALL = $(LIBRARY_NAME)
+objs += antispam-plugin.o antispam-storage.o $(BACKEND).o
-all: verify_config $(ALL)
+all: verify_config $(LIBRARY_NAME)
-%.o: %.c $(CONFIG) antispam-plugin.h
- $(CC) -c $(CFLAGS) -o $@ $<
+antispam-storage.o: antispam-storage.c antispam-storage-*.c $(CONFIG) antispam-plugin.h dovecot-version.h
+ $(CC) -c $(CFLAGS) $(INCS) -o $@ $<
+
+%.o: %.c $(CONFIG) antispam-plugin.h dovecot-version.h
+ $(CC) -c $(CFLAGS) $(INCS) -o $@ $<
$(LIBRARY_NAME): $(objs)
- $(CC) $(CFLAGS) $(objs) -o $(LIBRARY_NAME) $(LDFLAGS)
+ $(CC) $(CFLAGS) $(INCS) $(objs) -o $(LIBRARY_NAME) $(LDFLAGS)
+
+dovecot-version: dovecot-version.c $(CONFIG)
+ $(HOSTCC) $(INCS) -o dovecot-version dovecot-version.c
+
+dovecot-version.h: dovecot-version
+ ./dovecot-version > dovecot-version.h
clean:
- rm -f *.so *.o *~
+ rm -f *.so *.o *~ dovecot-version dovecot-version.h
install: all
install -o $(USER) -g $(GROUP) -m 0660 $(LIBRARY_NAME) $(INSTALLDIR)/