* Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
[citadel.git] / citadel / Makefile.in
index 47d05633dc59c32a740b029d47cfd834a1fbbb91..733ff118b6dd67a5889690876e28c30e1ac5cdb9 100644 (file)
@@ -8,36 +8,50 @@
 # 2. Send e-mail to ajc@uncnsrd.mt-kisco.ny.us and let me know what you
 #    did, so any necessary changes can be put into the next release.
 #
+# $Id$
+#
 ########################################################################
 
 TARGETS=@TARGETS@
+CHKPWD=@CHKPWD@
 
 all: $(TARGETS)
 
 .SUFFIXES: .ro .mo .d
 
-CLIENT_TARGETS=citadel whobbs
-SERVER_TARGETS=citserver setup
-SERV_MODULES=modules/serv_chat.so modules/serv_test.so \
-       modules/serv_upgrade.so modules/serv_expire.so
-UTIL_TARGETS=aidepost netmailer netproc netsetup msgform \
-       readlog rcit stats citmail netpoll mailinglist userlist
+EXEEXT=@EXEEXT@
+SO=@SO@
+SERV_ICQ=@SERV_ICQ@
+
+CLIENT_TARGETS=citadel$(EXEEXT) whobbs$(EXEEXT)
+SERVER_TARGETS=citserver setup $(CHKPWD)
+SERV_MODULES=modules/serv_chat$(SO) modules/serv_vcard$(SO) \
+       modules/serv_upgrade$(SO) modules/serv_smtp$(SO) \
+       modules/serv_expire$(SO) $(SERV_ICQ)
+UTIL_TARGETS=aidepost netmailer netproc netsetup msgform readlog rcit \
+       stats citmail netpoll mailinglist userlist sendcommand \
+       base64 qpdecode
 PROXY_TARGETS=proxy
 
 prefix=@prefix@
 srcdir=@srcdir@
 
+AUTH=@AUTH@
 DEFS=@DEFS@
 CPPFLAGS=@CPPFLAGS@ -I.
 CFLAGS=@CFLAGS@
 CC=@CC@
+GDBM=@GDBM@
+LINK_SHARED=@LINK_SHARED@
 LIBS=@LIBS@
 LDFLAGS=@LDFLAGS@
 SERVER_LDFLAGS=@SERVER_LDFLAGS@
 PICFLAGS=@PICFLAGS@
 CURSES=@CURSES@
-SNPRINTF=@SNPRINTF@
-PTHREAD_DEFS=-D_REENTRANT
+NETLIBS=@NETLIBS@
+chkpwd_LIBS=@chkpwd_LIBS@
+LIBOBJS=@LIBOBJS@
+PTHREAD_DEFS=@PTHREAD_DEFS@
 INSTALL=@INSTALL@
 INSTALL_DATA=@INSTALL_DATA@
 SHELL=/bin/sh
@@ -49,13 +63,15 @@ VPATH=$(srcdir)
 
 SOURCES=aidepost.c citadel.c citmail.c citserver.c client_chat.c commands.c \
        config.c control.c cux2ascii.c database.c dynloader.c file_ops.c \
-       housekeeping.c import.c internetmail.c ipc_c_tcp.c locate_host.c \
+       housekeeping.c internetmail.c ipc_c_tcp.c locate_host.c \
        logging.c mailinglist.c messages.c msgbase.c msgform.c netmailer.c \
        netpoll.c netproc.c netsetup.c policy.c proxy.c rcit.c readlog.c \
-       room_ops.c rooms.c roomutil.c routines.c routines2.c serv_chat.c \
-       serv_info.c serv_test.c serv_upgrade.c setup.c snprintf.c stats.c \
+       room_ops.c rooms.c routines.c routines2.c serv_chat.c serv_icq.c \
+       serv_info.c serv_test.c setup.c snprintf.c stats.c serv_vcard.c \
        support.c sysdep.c tools.c user_ops.c userlist.c serv_expire.c \
-       whobbs.c
+       whobbs.c sendcommand.c mime_parser.c base64.c qpdecode.c getutline.c \
+       auth.c chkpwd.c client_icq.c html.c vcard.c serv_upgrade.c \
+       serv_smtp.c internet_addressing.c parsedate.c
 
 DEP_FILES=$(SOURCES:.c=.d)
 
@@ -70,14 +86,17 @@ serv_modules: $(SERV_MODULES)
 #
 #
 
-citadel: ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o messages.o \
-       commands.o client_chat.o serv_info.o tools.o $(SNPRINTF)
-       $(CC) ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o messages.o \
-               commands.o client_chat.o serv_info.o tools.o $(SNPRINTF) $(LDFLAGS) \
-               -o citadel
+citadel$(EXEEXT): ipc_c_tcp.o citadel.o rooms.o routines.o \
+       routines2.o messages.o client_icq.o \
+       commands.o client_chat.o serv_info.o tools.o $(LIBOBJS)
+       $(CC) ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o \
+       messages.o client_icq.o \
+       commands.o client_chat.o serv_info.o tools.o $(LIBOBJS) $(LDFLAGS) \
+       -o citadel $(NETLIBS)
 
-netpoll: netpoll.o config.o ipc_c_tcp.o $(SNPRINTF)
-       $(CC) netpoll.o config.o ipc_c_tcp.o $(SNPRINTF) $(LDFLAGS) -o netpoll
+netpoll: netpoll.o config.o ipc_c_tcp.o tools.o $(LIBOBJS)
+       $(CC) netpoll.o config.o ipc_c_tcp.o tools.o \
+       $(LIBOBJS) $(LDFLAGS) -o netpoll $(NETLIBS)
 
 .c.o:
        $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $<
@@ -85,37 +104,68 @@ netpoll: netpoll.o config.o ipc_c_tcp.o $(SNPRINTF)
 #
 #
 
-citserver: citserver.ro user_ops.ro support.ro room_ops.ro file_ops.ro \
-       msgbase.ro config.ro sysdep.ro locate_host.ro \
-       housekeeping.ro database.ro control.ro logging.ro \
-       policy.ro dynloader.ro $(SNPRINTF:.o=.ro)
-       $(CC) \
-               citserver.ro user_ops.ro room_ops.ro file_ops.ro support.ro \
-               msgbase.ro config.ro sysdep.ro locate_host.ro \
-               housekeeping.ro database.ro control.ro logging.ro \
-               policy.ro dynloader.ro $(SNPRINTF:.o=.ro)\
-               $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) -o citserver
+SERV_OBJS = citserver.ro user_ops.ro support.ro room_ops.ro file_ops.ro \
+       msgbase.ro config.ro sysdep.ro locate_host.ro housekeeping.ro \
+       database.ro control.ro logging.ro policy.ro dynloader.ro tools.ro \
+       mime_parser.ro html.ro internet_addressing.ro \
+       $(AUTH) $(LIBOBJS:.o=.ro)
+
+citserver: $(SERV_OBJS)
+       $(CC) $(SERV_OBJS) $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) $(NETLIBS) $(GDBM) -o citserver
 
 .c.ro:
        $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
 
 modules/serv_chat.so: serv_chat.mo
-       $(CC) -shared -o modules/serv_chat.so serv_chat.mo
+       $(LINK_SHARED) -o modules/serv_chat.so serv_chat.mo
+
+modules/serv_chat.mo: serv_chat.mo
+       ln -f serv_chat.mo modules
 
 .c.mo:
        $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) $(PICFLAGS) -DPIC -c $< -o $@
 
 modules/serv_test.so: serv_test.mo
-       $(CC) -shared -o modules/serv_test.so serv_test.mo
+       $(LINK_SHARED) -o modules/serv_test.so serv_test.mo
 
-modules/serv_upgrade.so: serv_upgrade.mo
-       $(CC) -shared -o modules/serv_upgrade.so serv_upgrade.mo
+modules/serv_test.mo: serv_test.mo
+       ln -f serv_test.mo modules
+
+modules/serv_smtp.so: serv_smtp.mo
+       $(LINK_SHARED) -o modules/serv_smtp.so serv_smtp.mo
+
+modules/serv_smtp.mo: serv_smtp.mo
+       ln -f serv_smtp.mo modules
 
 modules/serv_expire.so: serv_expire.mo
-       $(CC) -shared -o modules/serv_expire.so serv_expire.mo
+       $(LINK_SHARED) -o modules/serv_expire.so serv_expire.mo
+
+modules/serv_expire.mo: serv_expire.mo
+       ln -f serv_expire.mo modules
+
+modules/serv_icq.so: serv_icq.mo
+       $(LINK_SHARED) -o modules/serv_icq.so serv_icq.mo
+
+modules/serv_icq.mo: serv_icq.mo
+       ln -f serv_icq.mo modules
+
+modules/serv_upgrade.so: serv_upgrade.mo
+       $(LINK_SHARED) -o modules/serv_upgrade.so serv_upgrade.mo
+
+modules/serv_upgrade.mo: serv_upgrade.mo
+       ln -f serv_upgrade.mo modules
+
+modules/serv_vcard.so: serv_vcard.mo vcard.mo
+       $(LINK_SHARED) -o modules/serv_vcard.so serv_vcard.mo vcard.mo
+
+modules/serv_vcard.mo: serv_vcard.mo
+       ln -f serv_vcard.mo modules
 
-aidepost: aidepost.o config.o $(SNPRINTF)
-       $(CC) aidepost.o config.o $(SNPRINTF) $(LDFLAGS) -o aidepost
+modules/vcard.mo: vcard.mo
+       ln -f vcard.mo modules
+
+aidepost: aidepost.o config.o $(LIBOBJS)
+       $(CC) aidepost.o config.o $(LIBOBJS) $(LDFLAGS) -o aidepost
 
 #
 # 'netmailer' needs to run setuid because it generates headers for Internet
@@ -125,34 +175,50 @@ aidepost: aidepost.o config.o $(SNPRINTF)
 netmailer: netmailer.o internetmail.o config.o
        $(CC) netmailer.o config.o internetmail.o $(LDFLAGS) -o netmailer
 
-netproc: netproc.o config.o ipc_c_tcp.o $(SNPRINTF)
-       $(CC) netproc.o config.o ipc_c_tcp.o $(SNPRINTF) $(LDFLAGS) -o netproc
+netproc: netproc.o config.o ipc_c_tcp.o tools.o $(LIBOBJS)
+       $(CC) netproc.o config.o ipc_c_tcp.o tools.o \
+       $(LIBOBJS) $(LDFLAGS) -o netproc $(NETLIBS) $(GDBM)
 
-citmail: citmail.o config.o internetmail.o
+citmail: citmail.o config.o internetmail.o parsedate.o $(LIBOBJS)
        @echo "*"
        @echo "*                 ###### IMPORTANT ######"
        @echo "* To allow Citadel users to receive Internet mail, you must"
        @echo "* set this program to be your local mail delivery agent."
        @echo "*"
-       $(CC) citmail.o config.o internetmail.o $(LDFLAGS) -o citmail
+       $(CC) citmail.o config.o internetmail.o parsedate.o \
+               $(LIBOBJS) $(LDFLAGS) -o citmail
 
 mailinglist: mailinglist.o config.o internetmail.o
        $(CC) mailinglist.o config.o internetmail.o $(LDFLAGS) -o mailinglist
 
-setup: setup.o
-       $(CC) setup.o $(CURSES) $(LDFLAGS) -o setup
+setup: setup.o tools.o
+       $(CC) setup.o tools.o $(CURSES) $(NETLIBS) $(LDFLAGS) -o setup
+
+chkpwd: chkpwd.o auth.o config.o
+       $(CC) chkpwd.o auth.o config.o $(LDFLAGS) -o chkpwd $(chkpwd_LIBS)
 
 netsetup: netsetup.o config.o
        $(CC) netsetup.o config.o $(LDFLAGS) -o netsetup
 
 proxy: proxy.o ipc_c_tcp.o
-       $(CC) proxy.o ipc_c_tcp.o $(LDFLAGS) -o proxy
+       $(CC) proxy.o ipc_c_tcp.o $(LDFLAGS) -o proxy $(NETLIBS)
+
+whobbs$(EXEEXT): whobbs.o ipc_c_tcp.o tools.o $(LIBOBJS)
+       $(CC) whobbs.o ipc_c_tcp.o tools.o $(LIBOBJS) $(LDFLAGS) -o whobbs $(NETLIBS)
+
+sendcommand: sendcommand.o ipc_c_tcp.o tools.o config.o $(LIBOBJS)
+       $(CC) sendcommand.o ipc_c_tcp.o tools.o config.o \
+        $(LIBOBJS) $(LDFLAGS) -o sendcommand $(NETLIBS)
 
-whobbs: whobbs.o ipc_c_tcp.o $(SNPRINTF)
-       $(CC) whobbs.o ipc_c_tcp.o $(SNPRINTF) $(LDFLAGS) -o whobbs
+qpdecode: qpdecode.o
+       $(CC) qpdecode.o $(LDFLAGS) -o qpdecode
 
-userlist: userlist.o ipc_c_tcp.o $(SNPRINTF)
-       $(CC) userlist.o ipc_c_tcp.o $(SNPRINTF) $(LDFLAGS) -o userlist
+base64: base64.o
+       $(CC) base64.o $(LDFLAGS) -o base64
+
+userlist: userlist.o ipc_c_tcp.o tools.o $(LIBOBJS)
+       $(CC) userlist.o ipc_c_tcp.o tools.o \
+       $(LIBOBJS) $(LDFLAGS) -o userlist $(NETLIBS)
 
 msgform: msgform.o
        $(CC) msgform.o $(LDFLAGS) -o msgform
@@ -168,40 +234,67 @@ rcit: rcit.o config.o
        @echo "* ln -s rcit /usr/bin/rnews"
        @echo "*"
 
-stats: stats.o config.o
-       $(CC) stats.o config.o $(LDFLAGS) -o stats
+stats: stats.o ipc_c_tcp.o tools.o config.o $(LIBOBJS)
+       $(CC) stats.o ipc_c_tcp.o tools.o config.o $(LIBOBJS) $(LDFLAGS) -o stats $(NETLIBS)
+
+.PHONY: install-data install-doc install-exec clean cleaner distclean
+
+install: install-exec install-data install-doc
 
-install: all
-       for i in modules techdoc bio bitbucket files help images info \
-                messages network/spoolin network/spoolout network/systems \
-                userpics; do \
-               ./mkinstalldirs $(prefix)/$$i; \
+install-data:
+       @for i in help messages network/spoolin network/spoolout \
+                network/systems; do \
+               ./mkinstalldirs $(root)$(prefix)/$$i; \
        done
-       for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
+       @for i in citadel.rc public_clients \
+                `find help messages network -type f | grep -v CVS`; do \
+               echo $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+               $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+       done
+       -@if test -d $(root)/etc/pam.d; then \
+               echo $(INSTALL_DATA) citadel.pam $(root)/etc/pam.d/citadel; \
+               $(INSTALL_DATA) citadel.pam $(root)/etc/pam.d/citadel; \
+       fi
+
+install-doc:
+       @./mkinstalldirs $(root)$(prefix)/techdoc
+       @for i in *.txt `find techdoc -type f | grep -v CVS`; do \
+               echo $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+               $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+       done
+
+install-exec: all weekly
+       @for i in bio bitbucket files images info modules userpics; do \
+               ./mkinstalldirs $(root)$(prefix)/$$i; \
+       done
+       @for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
                 $(PROXY_TARGETS) $(SERV_MODULES) utilsmenu weekly \
                 dnetsetup; do \
-               test -f $$i && $(INSTALL) $$i $(prefix)/$$i; \
-       done
-       test -f netmailer && chmod 4755 $(prefix)/netmailer $(prefix)/citmail
-       for i in *.txt citadel.rc public_clients \
-                `find help messages network techdoc -type f | \
-                 grep -v CVS`; do \
-               $(INSTALL_DATA) $$i $(prefix)/$$i; \
+               if test -f $$i; then \
+                       echo $(INSTALL) $$i $(root)$(prefix)/$$i; \
+                       $(INSTALL) $$i $(root)$(prefix)/$$i; \
+               fi \
        done
+       @if test x`find $(root)$(prefix)/chkpwd -user root` = x$(root)$(prefix)/chkpwd; then \
+               echo chmod u+s $(root)$(prefix)/chkpwd; \
+               chmod u+s $(root)$(prefix)/chkpwd; \
+       fi
 
 clean:
        rm -f *.o *.ro *.mo
 
 cleaner: clean
        rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
-               $(SERV_MODULES) $(PROXY_TARGETS) so_locations
+               modules/*.[ms]o $(PROXY_TARGETS) so_locations
 
 distclean: cleaner
-       rm -f Makefile sysdep.h config.cache config.log config.status *.d
+       find . -name '*~' -or -name '.#*' | xargs rm -f
+       rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
 
 .c.d:
-       $(CC) -M $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*.ro $*.mo $@!' > $@
-       test -s $@ || rm -f $@
+       @echo Checking dependencies for $<
+       @$(CC) -M $(CPPFLAGS) $(PTHREAD_DEFS) $< | sed -e 's!$*.o!$*.o $*.ro $*.mo $@!' > $@
+       @test -s $@ || rm -f $@
 
 Makefile: $(srcdir)/Makefile.in config.status
        CONFIG_FILES=Makefile CONFIG_HEADERS= $(SHELL) ./config.status
@@ -212,4 +305,7 @@ config.status: $(srcdir)/configure
 $(srcdir)/configure: $(srcdir)/configure.in $(srcdir)/aclocal.m4
        cd $(srcdir) && $(AUTOCONF)
 
+weekly: $(srcdir)/weekly.in config.status
+       CONFIG_FILES=weekly CONFIG_HEADERS= $(SHELL) ./config.status
+
 -include $(DEP_FILES)