X-Git-Url: https://the.earth.li/gitweb/?a=blobdiff_plain;f=Makefile.in;h=ceb936783b191c5a758ff02346c655149fd50c36;hb=adc800dbc424a1e246dd4a82a0c2e88eeda25531;hp=a7a5c08e48a5ef2377f9e4529c02d05a8185d568;hpb=edae27083dd4a70b1b7b8c968949ffb7dc11c508;p=onak.git diff --git a/Makefile.in b/Makefile.in index a7a5c08..ceb9367 100644 --- a/Makefile.in +++ b/Makefile.in @@ -6,31 +6,38 @@ CC = @CC@ CFLAGS += @CFLAGS@ -Wall -pedantic -fPIC # Uncomment to enable profiling. LDFLAGS += @LDFLAGS@ -# Can be "pg" for Postgresql, "file" for flat files or "db2" for pksd db2 style. +# Can be "pg" for Postgresql, "file" for flat files or "db4" for Berkeley DB. DBTYPE = @DBTYPE@ # -LIBS = @LIBS@ +LIBS = @LIBS@ @NETTLE_LIBS@ DB4LIBS = @DB4LIBS@ +CURLLIBS = @LIBCURL@ #MAKEDEPEND = makedepend -f- -- MAKEDEPEND = $(CC) -MM prefix ?= @prefix@ exec_prefix ?= @exec_prefix@ -PROGS = add lookup gpgwww onak splitkeys onak-mail.pl stripkey -CORE_OBJS = armor.o charfuncs.o decodekey.o getcgi.o hash.o \ - keyid.o keyindex.o ll.o mem.o onak-conf.o parsekey.o sha1.o md5.o \ - log.o photoid.o wordlist.o cleanup.o merge.o sendsync.o keyarray.o +PROGS = add lookup hashquery gpgwww onak splitkeys onak-mail.pl stripkey \ + wotsap +CORE_OBJS = armor.o charfuncs.o decodekey.o getcgi.o hash.o marshal.o \ + keyid.o keyindex.o ll.o mem.o onak-conf.o parsekey.o sigcheck.o \ + log.o photoid.o wordlist.o cleanup.o merge.o sendsync.o keyarray.o \ + sha1x.o cleankey.o +ifeq (x@NETTLE_LIBS@, x) +CORE_OBJS += md5.o sha1.o +endif SRCS = armor.c parsekey.c merge.c keyid.c md5.c sha1.c main.c getcgi.c mem.c \ keyindex.c stats.c lookup.c add.c keydb_$(DBTYPE).c ll.c hash.c \ - gpgwww.c onak-conf.c charfuncs.c sendsync.c log.c photoid.c \ - wordlist.c cleankey.c cleanup.c keyarray.c \ + gpgwww.c onak-conf.c charfuncs.c sendsync.c log.c photoid.c sigcheck.c \ + wordlist.c cleankey.c cleanup.c keyarray.c hashquery.c marshal.c \ + sha1x.c \ $(foreach be,@BACKENDS@,keydb_$(be).c) PROGS_LDFLAGS_EXTRA = ifeq (x@KEYD@, xyes) -PROGS += keyd +PROGS += keyd keydctl KEYDB_OBJ = keydb_keyd.o -SRCS += keyd.c keydb_keyd.c +SRCS += keyd.c keydb_keyd.c keydctl.c else KEYDB_OBJ = keydb_$(DBTYPE).o endif @@ -38,48 +45,65 @@ endif ifeq (x@DBTYPE@, xdynamic) LIBS += -ldl BACKENDS = $(foreach be,@BACKENDS@,libkeydb_$(be).so) -PROGS += keyd +PROGS += keyd keydctl PROGS_LDFLAGS_EXTRA = -rdynamic -SRCS += keyd.c +SRCS += keyd.c keydctl.c +endif + +ifeq (x@GOSSIP@, xyes) +SRCS += gossip-server.c +GOSSIP_OBJS = gossip-server.o +else +GOSSIP_OBJS = endif -OBJS = stats.o cleankey.o $(CORE_OBJS) $(KEYDB_OBJ) +OBJS = stats.o $(CORE_OBJS) $(KEYDB_OBJ) $(GOSSIP_OBJS) -all: .depend $(PROGS) testparse maxpath sixdegrees splitkeys onak.conf \ - $(BACKENDS) +all: .depend $(PROGS) testparse maxpath sixdegrees splitkeys onak.ini \ + wotsap $(BACKENDS) -install: $(PROGS) onak.conf $(BACKENDS) +test: onak $(BACKENDS) + perl -cw onak-mail.pl + @./runtests + +install: $(PROGS) onak.ini $(BACKENDS) install -d $(DESTDIR)/@bindir@ install -d $(DESTDIR)/@libdir@/onak/backends install -d $(DESTDIR)/@localstatedir@/lib/onak install -d $(DESTDIR)/@mandir@/man1 install -d $(DESTDIR)/@mandir@/man8 install -d $(DESTDIR)/@sysconfdir@ - install onak-mail.pl $(DESTDIR)/@libdir@/onak + install -m 755 onak-mail.pl $(DESTDIR)/@libdir@/onak install onak splitkeys $(DESTDIR)/@bindir@ install onak.1 splitkeys.1 $(DESTDIR)/@mandir@/man1 - install keyd.8 onak-mail.pl.8 $(DESTDIR)/@mandir@/man8 + install keyd.8 keydctl.8 onak-mail.pl.8 $(DESTDIR)/@mandir@/man8 ifeq (x@DBTYPE@, xdynamic) install $(BACKENDS) $(DESTDIR)/@libdir@/onak/backends install -d $(DESTDIR)/@sbindir@ install keyd $(DESTDIR)/@sbindir@ + install keydctl $(DESTDIR)/@bindir@ endif -keyd: keyd.o $(CORE_OBJS) keydb_$(DBTYPE).o +keyd: keyd.o $(CORE_OBJS) $(GOSSIP_OBJS) keydb_$(DBTYPE).o + $(CC) $(LDFLAGS) $(PROGS_LDFLAGS_EXTRA) \ + -o keyd keyd.o $(CORE_OBJS) $(GOSSIP_OBJS) keydb_$(DBTYPE).o \ + $(LIBS) @SYSTEMD_LIBS@ + +keydctl: keydctl.o onak-conf.o ll.o log.o $(CC) $(LDFLAGS) $(PROGS_LDFLAGS_EXTRA) \ - -o keyd keyd.o $(CORE_OBJS) keydb_$(DBTYPE).o $(LIBS) + -o keydctl keydctl.o onak-conf.o ll.o log.o $(LIBS) -libkeydb_db4.so: keydb_db4.o - $(CC) -shared $(DB4LIBS) -o libkeydb_db4.so keydb_db4.o $(CORE_OBJS) +libkeydb_db4.so: keydb_db4.o $(CORE_OBJS) + $(CC) $(LDFLAGS) -shared -o libkeydb_db4.so keydb_db4.o $(DB4LIBS) $(CORE_OBJS) -libkeydb_pg.so: keydb_pg.o - $(CC) -shared $(PQLIBS) -o libkeydb_pg.so keydb_pg.o $(CORE_OBJS) +libkeydb_hkp.so: keydb_hkp.o $(CORE_OBJS) + $(CC) $(LDFLAGS) -shared -o libkeydb_hkp.so keydb_hkp.o $(CURLLIBS) $(CORE_OBJS) -libkeydb_%.so: keydb_%.o - $(CC) -shared -o $@ $< $(CORE_OBJS) +libkeydb_pg.so: keydb_pg.o $(CORE_OBJS) + $(CC) $(LDFLAGS) -shared -o libkeydb_pg.so keydb_pg.o $(PQLIBS) $(CORE_OBJS) -keydb_%.o: keydb_%.c - $(CC) -c -fPIC $(LDFLAGS) -o $@ $< +libkeydb_%.so: keydb_%.o $(CORE_OBJS) + $(CC) $(LDFLAGS) -shared -o $@ $< $(CORE_OBJS) splitkeys: splitkeys.o $(CORE_OBJS) $(KEYDB_OBJ) $(CC) $(LDFLAGS) -o splitkeys splitkeys.o $(CORE_OBJS) $(KEYDB_OBJ) \ @@ -97,6 +121,10 @@ sixdegrees: sixdegrees.o $(OBJS) $(CC) $(LDFLAGS) -o sixdegrees sixdegrees.o $(OBJS) $(LIBS) \ $(PROGS_LDFLAGS_EXTRA) +wotsap: wotsap.o $(OBJS) + $(CC) $(LDFLAGS) -o wotsap wotsap.o $(OBJS) $(LIBS) \ + $(PROGS_LDFLAGS_EXTRA) + stripkey: stripkey.o $(OBJS) $(CC) $(LDFLAGS) -o stripkey stripkey.o $(OBJS) $(LIBS) \ $(PROGS_LDFLAGS_EXTRA) @@ -105,46 +133,69 @@ gpgwww: gpgwww.o $(OBJS) $(CC) $(LDFLAGS) -o gpgwww gpgwww.o $(OBJS) $(LIBS) \ $(PROGS_LDFLAGS_EXTRA) -lookup: lookup.o cleankey.o $(CORE_OBJS) $(KEYDB_OBJ) - $(CC) $(LDFLAGS) -o lookup lookup.o cleankey.o $(CORE_OBJS) \ +hashquery: hashquery.o $(CORE_OBJS) $(KEYDB_OBJ) + $(CC) $(LDFLAGS) -o hashquery hashquery.o $(CORE_OBJS) \ + $(KEYDB_OBJ) $(LIBS) $(PROGS_LDFLAGS_EXTRA) + +lookup: lookup.o $(CORE_OBJS) $(KEYDB_OBJ) + $(CC) $(LDFLAGS) -o lookup lookup.o $(CORE_OBJS) \ $(KEYDB_OBJ) $(LIBS) $(PROGS_LDFLAGS_EXTRA) -add: add.o cleankey.o $(CORE_OBJS) $(KEYDB_OBJ) - $(CC) $(LDFLAGS) -o add add.o cleankey.o \ +add: add.o $(CORE_OBJS) $(KEYDB_OBJ) + $(CC) $(LDFLAGS) -o add add.o \ $(CORE_OBJS) $(KEYDB_OBJ) $(LIBS) $(PROGS_LDFLAGS_EXTRA) -onak: onak.o cleankey.o $(CORE_OBJS) $(KEYDB_OBJ) - $(CC) $(LDFLAGS) -o onak onak.o cleankey.o \ +onak: onak.o $(CORE_OBJS) $(KEYDB_OBJ) + $(CC) $(LDFLAGS) -o onak onak.o \ $(CORE_OBJS) $(KEYDB_OBJ) $(LIBS) $(PROGS_LDFLAGS_EXTRA) onak-conf.o: onak-conf.c onak-conf.h - $(CC) $(CFLAGS) -DCONFIGFILE=\"@sysconfdir@/onak.conf\" \ - -DDBFUNCS=keydb_@DBTYPE@_funcs -c onak-conf.c + $(CC) $(CFLAGS) -DCONFIGDIR=\"@sysconfdir@\" \ + -DDBINIT=keydb_@DBTYPE@_init -c onak-conf.c -onak-mail.pl: onak-mail.pl.in - sed 's:@CONFIG@:@sysconfdir@/onak.conf:g' < onak-mail.pl.in > onak-mail.pl - chmod +x onak-mail.pl +# HACK: onak-conf.o needs to be able to see keydb_@DBTYPE@_funcs, but +# keydctl doesn't want to link against the DB stuff. To be fixed more cleanly. +keydctl.o: keydctl.c keyd.h + $(CC) $(CFLAGS) -DDBINIT=keydb_@DBTYPE@_init -c keydctl.c -onak.conf: onak.conf.in +%: %.in sed -e 's:@BINDIR@:@bindir@:g' \ + -e 's:@CONFIG@:@sysconfdir@/onak.ini:g' \ + -e 's:@CONFIGOLD@:@sysconfdir@/onak.conf:g' \ -e 's:@LIBDIR@:@libdir@:g' \ + -e 's:@RUNDIR@:@runstatedir@:g' \ + -e 's:@SBINDIR@:@sbindir@:g' \ -e 's:@STATEDIR@:@localstatedir@:g' \ - < onak.conf.in > onak.conf + < $< > $@ clean: $(RM) $(PROGS) $(OBJS) Makefile.bak testparse maxpath *.core core \ gpgwww.o add.o lookup.o main.o maxpath.o onak.o sixdegrees \ - sixdegrees.o splitkeys.o stripkey.o onak.conf keyd.o \ + sixdegrees.o splitkeys.o stripkey.o onak.ini keyd.o \ + keydctl.o hashquery.o wotsap.o version.h \ + TAGS cscope.out cscope.files \ $(foreach be,@BACKENDS@,keydb_$(be).o) *.so ifeq (x@KEYD@, xyes) $(RM) keyd.o keydb_$(DBTYPE).o endif distclean: clean - $(RM) -f Makefile .depend config.{log,status,h} + $(RM) -f Makefile .depend config.log config.status config.h $(RM) -r autom4te.cache -.depend: $(SRCS) +doxygen-docs: *.c *.h Doxyfile + doxygen + +version.h: $(SRCS) + @echo '#include "config.h"' > version.h + @if [ -e .git ]; then \ + echo "#define ONAK_VERSION \"`git describe --tags --dirty | cut -d - -f 2-`\"" \ + >> version.h; \ + else \ + echo "#define ONAK_VERSION PACKAGE_VERSION" >> version.h; \ + fi + +.depend: $(SRCS) version.h rm -f .depend $(MAKEDEPEND) $(CFLAGS) $(SRCS) > .depend