* use AC_CHECK_FUNCS to check for flock()
[citadel.git] / citadel / Makefile.in
index 9cd0dd46b4f6128602ad94fd9b15dd576d502bb6..dc864add20a57f42174d1edefa1657f33c6e0c75 100644 (file)
@@ -1,4 +1,4 @@
-# Makefile for Citadel/UX
+# Makefile for Citadel
 #
 # NOTE: normally you should not have to modify the Makefile.  All
 # system-dependent configuration is in the "configure" script, which
 ########################################################################
 
 TARGETS=@TARGETS@
-CHKPWD=@CHKPWD@
-
+RUN_DIR=@MAKE_RUN_DIR@
+SPOOL_DIR=@MAKE_SPOOL_DIR@
+ETC_DIR=@MAKE_ETC_DIR@
+DATA_DIR=@MAKE_DATA_DIR@
+STATICDATA_DIR=@MAKE_STATICDATA_DIR@
+DOC_DIR=@MAKE_DOC_DIR@
+UTILBIN_DIR=@MAKE_UTILBIN_DIR@
+DEPEND_FLAG=@DEPEND_FLAG@
 all: $(TARGETS)
 
-.SUFFIXES: .lo .ro .d .c
+.SUFFIXES: .o .d .c
 
 EXEEXT=@EXEEXT@
-CX=@CX@
-
-SMTP=@SMTP@
-
-CLIENT_TARGETS=citadel$(EXEEXT) whobbs$(EXEEXT)
-SERVER_TARGETS=libcitserver.la citserver setup $(CHKPWD)
-SERV_MODULES=modules/libchat.la modules/libvcard.la \
-       modules/libupgrade.la \
-       $(SMTP) \
-       modules/libpop3.la \
-       modules/libimap.la \
-       modules/libnetwork.la \
-       modules/libpas2.la \
-       modules/libinetcfg.la \
-       modules/librwho.la \
-       modules/libmoderate.la \
-       modules/libbio.la \
-       modules/libexpire.la \
-       modules/libvandelay.la \
-       modules/libical.la
-UTIL_TARGETS=aidepost netsetup msgform readlog \
-       stats citmail userlist sendcommand \
-       base64 qpdecode
+
+CLIENT_TARGETS=citadel$(EXEEXT) whobbs$(EXEEXT) stress$(EXEEXT)
+SERVER_TARGETS=citserver
+SERV_MODULES=modules/chat/serv_chat.o \
+       modules/upgrade/serv_upgrade.o \
+       modules/smtp/serv_smtp.o \
+       modules/spam/serv_spam.o \
+       modules/pop3/serv_pop3.o \
+       modules/vcard/serv_vcard.o \
+       vcard.o \
+       modules/mrtg/serv_mrtg.o \
+       modules/imap/serv_imap.o \
+       modules/imap/imap_fetch.o \
+       modules/imap/imap_misc.o \
+       modules/imap/imap_search.o \
+       modules/imap/imap_store.o \
+       modules/imap/imap_acl.o \
+       modules/imap/imap_metadata.o \
+       modules/imap/imap_tools.o \
+       modules/imap/imap_list.o \
+       modules/fulltext/serv_fulltext.o \
+       modules/fulltext/ft_wordbreaker.o \
+       crc16.o \
+       modules/network/serv_network.o \
+       modules/listsub/serv_listsub.o \
+       modules/netfilter/serv_netfilter.o \
+       modules/newuser/serv_newuser.o \
+       modules/notes/serv_notes.o \
+       modules/pas2/serv_pas2.o \
+       md5.o \
+       modules/inetcfg/serv_inetcfg.o \
+       modules/rwho/serv_rwho.o \
+       modules/bio/serv_bio.o \
+       modules/expire/serv_expire.o \
+       modules/vandelay/serv_vandelay.o \
+       modules/calendar/serv_calendar.o \
+       modules/crypto/serv_crypto.o \
+       modules/sieve/serv_sieve.o \
+       modules/managesieve/serv_managesieve.o \
+       ical_dezonify.o \
+       modules/ldap/serv_ldap.o \
+       modules/autocompletion/serv_autocompletion.o \
+       modules/funambol/serv_funambol.o \
+       modules/test/serv_test.o
+
+UTIL_TARGETS=aidepost msgform \
+       citmail userlist sendcommand \
+
+UTILBIN_TARGETS= base64 setup chkpw chkpwd
 
 prefix=@prefix@
 srcdir=@srcdir@
 
+ACLOCAL=@ACLOCAL@
 AUTH=@AUTH@
-DEFS=@DEFS@
-CPPFLAGS=@CPPFLAGS@ -I.
-CFLAGS=@CFLAGS@
+AUTOCONF=@AUTOCONF@
+chkpwd_LIBS=@chkpwd_LIBS@
 CC=@CC@
-GDBM=@GDBM@
-RESOLV=@RESOLV@
-LIBS=@LIBS@
+CFLAGS=@CFLAGS@ -I ./include/
+CPPFLAGS=@CPPFLAGS@ -I. -I ./include/
+DATABASE=@DATABASE@
+DEFS=@DEFS@
 LDFLAGS=@LDFLAGS@
-CURSES=@CURSES@
-NETLIBS=@NETLIBS@
-chkpwd_LIBS=@chkpwd_LIBS@
+LIBS=@LIBS@
 LIBOBJS=@LIBOBJS@
-CL_LIBOBJS=@CL_LIBOBJS@
-PTHREAD_DEFS=@PTHREAD_DEFS@
-PTHREAD_LIBS=@PTHREAD_LIBS@
-CLIENT_PTLIBS=@CLIENT_PTLIBS@
 INSTALL=@INSTALL@
 INSTALL_DATA=@INSTALL_DATA@
+RESOLV=@RESOLV@
 SHELL=/bin/sh
-AUTOCONF=@AUTOCONF@
+SERVER_LDFLAGS=@SERVER_LDFLAGS@
+SERVER_LIBS=@SERVER_LIBS@
+SETUP_LIBS=@SETUP_LIBS@
 YACC=@YACC@
-DATABASE=@DATABASE@
-
-LIBTOOL=./libtool
-LTSHARE=cd modules && ../$(LIBTOOL) $(CC) -rpath $(prefix)/modules -no-undefined -avoid-version -module
 
 # End configuration section
 
 VPATH=$(srcdir)
 
-DOMAIN=@DOMAIN@
-
-SOURCES=aidepost.c citadel.c citmail.c citserver.c client_chat.c commands.c \
-       config.c control.c $(DATABASE) dynloader.c file_ops.c \
-       housekeeping.c ipc_c_tcp.c locate_host.c \
-       logging.c messages.c msgbase.c msgform.c \
-       netsetup.c policy.c readlog.c \
-       room_ops.c rooms.c routines.c routines2.c serv_chat.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 sendcommand.c mime_parser.c base64.c qpdecode.c getutline.c \
-       auth.c chkpwd.c html.c vcard.c serv_upgrade.c serv_vandelay.c \
-       serv_smtp.c serv_pop3.c internet_addressing.c parsedate.c genstamp.c \
-       $(DOMAIN) clientsocket.c serv_inetcfg.c serv_rwho.c serv_bio.c \
-       serv_moderate.c client_passwords.c imap_misc.c \
-       serv_imap.c imap_tools.c imap_fetch.c imap_search.c imap_store.c \
-       serv_network.c serv_pas2.c serv_ical.c md5.c server_main.c
-
-DEP_FILES=$(SOURCES:.c=.d)
+SOURCES=aidepost.c auth.c base64.c chkpwd.c chkpw.c citadel.c citadel_ipc.c \
+       citmail.c citserver.c client_chat.c client_passwords.c \
+       clientsocket.c commands.c config.c control.c $(DATABASE) \
+       domain.c serv_extensions.c file_ops.c genstamp.c getutline.c \
+       housekeeping.c html.c ical_dezonify.c \
+       internet_addressing.c ecrash.c \
+       ipc_c_tcp.c locate_host.c md5.c messages.c  \
+       modules/autocompletion/serv_autocompletion.c \
+       mime_parser.c msgbase.c msgform.c parsedate.c policy.c \
+       room_ops.c rooms.c routines.c routines2.c euidindex.c \
+       screen.c sendcommand.c \
+       modules/bio/serv_bio.c \
+       modules/calendar/serv_calendar.c \
+       modules/chat/serv_chat.c \
+       modules/crypto/serv_crypto.c \
+       modules/expire/serv_expire.c \
+       modules/imap/serv_imap.c \
+       modules/imap/imap_search.c \
+       modules/imap/imap_store.c \
+       modules/imap/imap_tools.c \
+       modules/imap/imap_fetch.c \
+       modules/imap/imap_misc.c \
+       modules/imap/imap_acl.c \
+       modules/imap/imap_list.c \
+       modules/imap/imap_metadata.c \
+       modules/inetcfg/serv_inetcfg.c \
+       modules/listsub/serv_listsub.c \
+       modules/mrtg/serv_mrtg.c \
+       modules/netfilter/serv_netfilter.c \
+       modules/network/serv_network.c \
+       modules/ldap/serv_ldap.c \
+       modules/newuser/serv_newuser.c \
+       modules/pas2/serv_pas2.c \
+       modules/pop3/serv_pop3.c \
+       modules/rwho/serv_rwho.c \
+       modules/smtp/serv_smtp.c \
+       modules/spam/serv_spam.c \
+       modules/upgrade/serv_upgrade.c \
+       modules/vandelay/serv_vandelay.c \
+       modules/vcard/serv_vcard.c \
+       modules/managesieve/serv_managesieve.c \
+       server_main.c \
+       modules/sieve/serv_sieve.c \
+       modules/funambol/serv_funambol.c \
+       setup.c snprintf.c \
+       stress.c support.c sysdep.c tools.c user_ops.c userlist.c \
+       whobbs.c vcard.c \
+       modules/notes/serv_notes.c \
+       modules/fulltext/serv_fulltext.c \
+       modules/fulltext/ft_wordbreaker.c \
+       crc16.c journaling.c citadel_dirs.c \
+       modules/test/serv_test.c
+
+DEP_FILES=$(SOURCES:.c=.d) modules_init.d
 
 client: $(CLIENT_TARGETS)
 
-server: $(SERVER_TARGETS)
-
-utils: $(UTIL_TARGETS)
-
-serv_modules: $(SERV_MODULES)
-       @cd modules && mods=`echo .libs/*.s[ol]` && test "$$mods" != '.libs/*.s[ol]' && ln -sf $$mods . || true
-       @cd modules && mods=`echo .libs/*.dll` && test "$$mods" != '.libs/*.dll' && ln -sf $$mods . || true
+server: $(SERVER_TARGETS) $(SERV_MODULES)
 
-#
-#
+utils: $(UTIL_TARGETS) $(UTILBIN_TARGETS)
 
-citadel$(EXEEXT): ipc_c_tcp$(CX) citadel$(CX) rooms$(CX) routines$(CX) \
-       routines2$(CX) messages$(CX)  \
-       client_passwords$(CX) md5$(CX) \
-       commands$(CX) client_chat$(CX) serv_info$(CX) tools$(CX) $(LIBOBJS)
-       $(CC) ipc_c_tcp$(CX) citadel$(CX) rooms$(CX) routines$(CX) \
-       routines2$(CX) messages$(CX) \
-       commands$(CX) client_chat$(CX) serv_info$(CX) tools$(CX) \
-       client_passwords$(CX) md5$(CX) \
-       $(LIBOBJS) $(LDFLAGS) -o citadel $(NETLIBS) $(CLIENT_PTLIBS)
-
-.c.o:
-       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $<
+citadel$(EXEEXT): citadel.o citadel_ipc.o client_chat.o client_passwords.o \
+       commands.o html.o ipc_c_tcp.o md5.o messages.o rooms.o routines.o \
+       routines2.o screen.o tools.o citadel_dirs.o ecrash.o $(LIBOBJS)
+       $(CC) citadel.o citadel_ipc.o client_chat.o client_passwords.o \
+       commands.o html.o ipc_c_tcp.o md5.o messages.o rooms.o routines.o \
+       routines2.o screen.o tools.o citadel_dirs.o ecrash.o $(LIBOBJS) \
+       $(LDFLAGS) -o citadel $(LIBS)
 
 .y.c:
        $(YACC) $(YFLAGS) $<
@@ -131,188 +180,224 @@ citadel$(EXEEXT): ipc_c_tcp$(CX) citadel$(CX) rooms$(CX) routines$(CX) \
 #
 #
 
-SERV_OBJS = server_main.ro
-
-parsedate.ro: parsedate.c
-
-LIBSERV_OBJS = user_ops.lo citserver.lo sysdep.lo dynloader.lo tools.lo $(DATABASE:.c=.lo) \
-       control.lo policy.lo config.lo support.lo room_ops.lo file_ops.lo msgbase.lo \
-       locate_host.lo housekeeping.lo logging.lo mime_parser.lo html.lo internet_addressing.lo \
-       parsedate.lo genstamp.lo clientsocket.lo $(AUTH) $(LIBOBJS:.o=.lo)
-
-libcitserver.la: $(LIBSERV_OBJS)
-       $(LIBTOOL) $(CC) $(LDFLAGS) -rpath $(prefix) -no-undefined -avoid-version \
-       -o libcitserver.la $(LIBSERV_OBJS) $(GDBM) $(LIBS) $(PTHREAD_LIBS) $(NETLIBS) $(RESOLV)
-
-citserver: $(SERV_OBJS) $(LIBTOOL) libcitserver.la
-       $(LIBTOOL) --mode=link $(CC) -export-dynamic $(SERV_OBJS) $(LDFLAGS) libcitserver.la -o \
-       citserver $(PTHREAD_LIBS)
-
-.c.ro:
-       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
-
-.c.lo: $(LIBTOOL)
-       @test -d modules || mkdir -p modules
-       $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
-
-modules/libchat.la: serv_chat.lo libcitserver.la $(LIBTOOL)
-       $(LTSHARE) -o libchat.la ../serv_chat.lo ../libcitserver.la
-
-modules/libtest.la: serv_test.lo libcitserver.la $(LIBTOOL)
-       $(LTSHARE) -o libtest.la ../serv_test.lo ../libcitserver.la
-
-modules/libpop3.la: serv_pop3.lo md5.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libpop3.la ../serv_pop3.lo ../md5.lo ../libcitserver.la
-
-modules/libinetcfg.la: serv_inetcfg.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libinetcfg.la ../serv_inetcfg.lo ../libcitserver.la
-
-modules/librwho.la: serv_rwho.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o librwho.la ../serv_rwho.lo ../libcitserver.la
-
-modules/libmoderate.la: serv_moderate.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libmoderate.la ../serv_moderate.lo ../libcitserver.la
-
-modules/libbio.la: serv_bio.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libbio.la ../serv_bio.lo ../libcitserver.la
+parsedate.o: parsedate.c
 
-modules/libexpire.la: serv_expire.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libexpire.la ../serv_expire.lo ../libcitserver.la
+modules_init.c: mk_module_init.sh $(SOURCES)
+               $(srcdir)/mk_module_init.sh
 
-modules/libvandelay.la: serv_vandelay.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libvandelay.la ../serv_vandelay.lo ../libcitserver.la
+SERV_OBJS = server_main.o \
+       user_ops.o citserver.o sysdep.o serv_extensions.o \
+       tools.o $(DATABASE:.c=.o) domain.o \
+       control.o policy.o config.o support.o room_ops.o \
+       file_ops.o msgbase.o euidindex.o \
+       locate_host.o housekeeping.o mime_parser.o html.o \
+       internet_addressing.o journaling.o \
+       parsedate.o genstamp.o ecrash.o \
+       clientsocket.o modules_init.o $(AUTH) $(SERV_MODULES)
 
-modules/libnetwork.la: serv_network.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libnetwork.la ../serv_network.lo ../libcitserver.la
+citserver: $(SERV_OBJS)
+       $(CC) $(SERV_OBJS) $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) $(SERVER_LIBS) $(RESOLV) -o citserver
 
-modules/libupgrade.la: serv_upgrade.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libupgrade.la ../serv_upgrade.lo ../libcitserver.la
-
-modules/libvcard.la: serv_vcard.lo vcard.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libvcard.la ../serv_vcard.lo ../vcard.lo ../libcitserver.la
-
-modules/libsmtp.la: serv_smtp.lo domain.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libsmtp.la ../serv_smtp.lo ../domain.lo ../libcitserver.la
-
-
-modules/libimap.la: serv_imap.lo imap_tools.lo imap_fetch.lo \
-       imap_search.lo imap_store.lo imap_misc.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libimap.la ../imap_tools.lo ../serv_imap.lo \
-               ../imap_fetch.lo ../imap_search.lo ../imap_store.lo ../imap_misc.lo ../libcitserver.la
-
-aidepost: aidepost.o libcitserver.la $(LIBOBJS)
-       $(LIBTOOL) $(CC) aidepost.o libcitserver.la $(LIBOBJS) $(LDFLAGS) -o aidepost
-
-modules/libpas2.la: serv_pas2.lo md5.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libpas2.la ../serv_pas2.lo ../md5.lo ../libcitserver.la
+.c.o:
+       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $< -o $@
 
-modules/libical.la: serv_ical.lo $(LIBTOOL) libcitserver.la
-       $(LTSHARE) -o libical.la ../serv_ical.lo ../libcitserver.la
+aidepost: aidepost.o config.o
+       $(CC) aidepost.o config.o citadel_dirs.o $(LDFLAGS) -o aidepost $(LIBS)
 
-citmail: citmail.o config.o
-       $(CC) citmail.o config.o $(LDFLAGS) -o citmail $(NETLIBS)
+citmail: citmail.o citadel_dirs.o tools.o
+       $(CC) citmail.o citadel_dirs.o tools.o $(LDFLAGS) -o citmail $(LIBS)
 
-setup: setup.o tools.o
-       $(CC) setup.o tools.o $(CURSES) $(NETLIBS) $(LDFLAGS) -o setup
+# setup does need LIBS defined, because it uses network functions which are in -lsocket -lnsl on Solaris.
+setup: setup.o tools.o citadel_dirs.o
+       $(CC) setup.o tools.o citadel_dirs.o $(LDFLAGS) -o setup $(LIBS) $(SETUP_LIBS)
 
-chkpwd: chkpwd.o auth.o config.o
-       $(CC) chkpwd.o auth.o config.o $(LDFLAGS) -o chkpwd $(chkpwd_LIBS)
+chkpwd: chkpwd.o auth.o
+       $(CC) chkpwd.o auth.o $(LDFLAGS) -o chkpwd $(chkpwd_LIBS)
 
-netsetup: netsetup.o config.o
-       $(CC) netsetup.o config.o $(LDFLAGS) -o netsetup
+chkpw: chkpw.o auth.o citadel_dirs.o
+       $(CC) chkpw.o auth.o citadel_dirs.o $(LDFLAGS) -o chkpw $(chkpwd_LIBS)
 
-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)
+whobbs$(EXEEXT): whobbs.o ipc_c_tcp.o tools.o citadel_ipc.o citadel_dirs.o $(LIBOBJS)
+       $(CC) whobbs.o ipc_c_tcp.o tools.o citadel_ipc.o  citadel_dirs.o $(LIBOBJS) $(LDFLAGS) -o whobbs $(LIBS)
 
-sendcommand: sendcommand.o ipc_c_tcp.o libcitserver.la $(LIBOBJS)
-       $(LIBTOOL) $(CC) sendcommand.o ipc_c_tcp.o libcitserver.la \
-        $(LIBOBJS) $(LDFLAGS) -o sendcommand $(NETLIBS)
+stress$(EXEEXT): stress.o ipc_c_tcp.o tools.o citadel_ipc.o citadel_dirs.o $(LIBOBJS)
+       $(CC) stress.o ipc_c_tcp.o tools.o citadel_ipc.o citadel_dirs.o $(LIBOBJS) $(LDFLAGS) -o stress $(LIBS)
 
-qpdecode: qpdecode.o
-       $(CC) qpdecode.o $(LDFLAGS) -o qpdecode
+sendcommand: sendcommand.o ipc_c_tcp.o citadel_ipc.o tools.o config.o  $(LIBOBJS)
+       $(CC) sendcommand.o ipc_c_tcp.o citadel_ipc.o tools.o config.o  \
+        citadel_dirs.o $(LIBOBJS) $(LDFLAGS) -o sendcommand $(LIBS)
 
 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)
+userlist: userlist.o ipc_c_tcp.o citadel_ipc.o tools.o citadel_dirs.o $(LIBOBJS)
+       $(CC) userlist.o ipc_c_tcp.o citadel_ipc.o tools.o citadel_dirs.o \
+       $(LIBOBJS) $(LDFLAGS) -o userlist $(LIBS)
 
 msgform: msgform.o
        $(CC) msgform.o $(LDFLAGS) -o msgform
 
-readlog: readlog.o config.o
-       $(CC) readlog.o config.o $(LDFLAGS) -o readlog
-
-stats: stats.o ipc_c_tcp.o libcitserver.la $(LIBOBJS)
-       $(LIBTOOL) $(CC) stats.o ipc_c_tcp.o libcitserver.la $(LIBOBJS) $(LDFLAGS) -o stats $(NETLIBS)
-
 .PHONY: install-data install-doc install-exec clean cleaner distclean
 
 install: install-exec install-data install-doc
+       @echo 
+       @echo Installation is complete.
+       @echo Now go to your Citadel directory and run 'setup'.
+       @echo 
+
+install-new: install-exec-new install-data-new install-doc-new
+       @echo 
+       @echo Installation is complete.
+       @echo Now go to your Citadel directory and run 'setup'.
+       @echo 
+
+upgrade: install-exec install-doc
+       @echo
+       @echo Upgrade is complete.
+       @echo Now go to your Citadel directory and run 'setup'.
+       @echo
 
 install-data:
        @for i in help messages network/spoolin network/spoolout \
                 network/systems; do \
-               $(srcdir)/mkinstalldirs $(root)$(prefix)/$$i; \
+               $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/$$i; \
        done
        @for i in citadel.rc public_clients \
-                `find $(srcdir)/help $(srcdir)/messages $(srcdir)/network -type f | grep -v CVS`; do \
-               echo $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
-               $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+                `find $(srcdir)/help $(srcdir)/messages $(srcdir)/network -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
        done
-       -@if test -d $(root)/etc/pam.d; then \
-               echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(root)/etc/pam.d/citadel; \
-               $(INSTALL_DATA) $(srcdir)/citadel.pam $(root)/etc/pam.d/citadel; \
+       -@if test -d $(DESTDIR)/etc/pam.d; then \
+               echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
+               $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
        fi
 
+install-data-new:
+       @for i in network/spoolin network/spoolout network/systems; do \
+               $(srcdir)/mkinstalldirs $(DESTDIR)$(RUN_DIR)/$$i; \
+       done
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(ETC_DIR)/
+       $(INSTALL_DATA) $(srcdir)/public_clients $(DESTDIR)$(ETC_DIR)/public_clients
+       $(INSTALL_DATA) $(srcdir)/citadel.rc $(DESTDIR)$(ETC_DIR)/citadel.rc
+       $(INSTALL_DATA) $(srcdir)/network/mail.aliases $(DESTDIR)$(ETC_DIR)/mail.aliases$
+
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(STATICDATA_DIR)/help
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(STATICDATA_DIR)/messages
+       @for i in  \
+                `find $(srcdir)/help $(srcdir)/messages  -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(STATICDATA_DIR)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(STATICDATA_DIR)/$$i; \
+       done
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(SPOOL_DIR)/network/spoolin
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(SPOOL_DIR)/network/spoolout
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(SPOOL_DIR)/network/systems
+       -@if test -d $(DESTDIR)/etc/pam.d; then \
+               echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
+               $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
+       fi
+       @for i in bio bitbucket files images info userpics; do \
+               $(srcdir)/mkinstalldirs $(DESTDIR)$(DATA_DIR)/$$i; \
+       done
+
 install-doc:
-       @$(srcdir)/mkinstalldirs $(root)$(prefix)/techdoc
-       @for i in `find $(srcdir)/techdoc -type f | grep -v CVS`; do \
-               echo $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
-               $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+       @$(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/docs
+       @for i in `find $(srcdir)/docs -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
+       done
+       @$(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/techdoc
+       @for i in `find $(srcdir)/techdoc -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
+       done
+       echo $(INSTALL_DATA) README.txt $(DESTDIR)$(prefix)/README.txt
+       $(INSTALL_DATA) README.txt $(DESTDIR)$(prefix)/README.txt
+
+install-doc-new:
+       @$(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR)/docs
+       @for i in `find $(srcdir)/docs -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
+       done
+       @$(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR)/techdoc
+       @for i in `find $(srcdir)/techdoc -type f | grep -v .svn`; do \
+               echo $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
+               $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
        done
+       $(INSTALL_DATA) README.txt $(DESTDIR)$(DOC_DIR)/README.txt
 
-install-exec: all weekly
-       @for i in bio bitbucket files images info modules userpics; do \
-               $(srcdir)/mkinstalldirs $(root)$(prefix)/$$i; \
+install-exec: all
+       @for i in bio bitbucket files images info userpics; do \
+               $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/$$i; \
        done
-       @for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS); do \
+       @for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS); do \
                if test -f $$i; then \
-                       echo $(LIBTOOL) --mode=install $(INSTALL) $$i $(root)$(prefix)/$$i; \
-                       $(LIBTOOL) --mode=install $(INSTALL) $$i $(root)$(prefix)/$$i; \
+                       echo $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
+                       $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
                fi \
        done
-       @for i in $(SERV_MODULES) ; do \
+       @for i in utilsmenu database_cleanup.sh citadel-openldap.schema; do \
+               if test -f $(srcdir)/$$i; then \
+                       echo $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(prefix)/$$i; \
+                       $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(prefix)/$$i; \
+               fi \
+       done
+
+install-exec-new: all
+       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/sbin; 
+       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/bin; 
+       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/bin; 
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(UTILBIN_DIR); 
+       $(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR);
+       @for i in $(SERVER_TARGETS) $(UTIL_TARGETS); do \
                if test -f $$i; then \
-                       (cd modules && ../$(LIBTOOL) --mode=install $(INSTALL) `basename $$i` $(root)$(prefix)/$$i) ; \
+                       echo $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
+                       $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
                fi \
        done
-       @for i in utilsmenu weekly dnetsetup; do \
+       @for i in $(UTILBIN_TARGETS); do \
+               if test -f $$i; then \
+                       echo $(INSTALL) $$i $(DESTDIR)/$(UTILBIN_DIR)/$$i; \
+                       $(INSTALL) $$i $(DESTDIR)/$(UTILBIN_DIR)/$$i; \
+               fi \
+       done
+
+       $(INSTALL) citmail $(DESTDIR)/usr/sbin/sendmail;
+       @for i in $(CLIENT_TARGETS); do \
+               if test -f $$i; then \
+                       echo $(INSTALL) $$i $(DESTDIR)/usr/bin/$$i; \
+                       $(INSTALL) $$i $(DESTDIR)/usr/bin/$$i; \
+               fi \
+       done
+       @for i in utilsmenu database_cleanup.sh citadel-openldap.schema ; do \
                if test -f $(srcdir)/$$i; then \
-                       echo $(INSTALL) $(srcdir)/$$i $(root)$(prefix)/$$i; \
-                       $(INSTALL) $(srcdir)/$$i $(root)$(prefix)/$$i; \
+                       echo $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(DOC_DIR)/$$i; \
+                       $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(DOC_DIR)/$$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 *.lo parsedate.c
+       rm -f *.o 
+       for i in $(srcdir)/modules/* ; do \
+               rm -f $$i/*.o ;\
+       done
+       rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS)
+
 
 cleaner: clean
-       rm -rf $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
-               modules/*.la modules/.libs so_locations
+       rm -rf $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS) database_cleanup.sh *.la
+       rm -rf modules_init.c modules_init.h
 
 distclean: cleaner
        find . -name '*~' -o -name '.#*' | xargs rm -f
-       rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
+       rm -f Makefile sysdep.h config.cache config.log config.status *.d 
+       for i in $(srcdir)/modules/* ; do \
+               rm -f $$i/*.d ;\
+       done
 
 .c.d:
        @echo Checking dependencies for $<
-       @$(CC) -M $(CPPFLAGS) $(PTHREAD_DEFS) $< | sed -e 's!$*.o!$*.o $*.ro $*.lo $@!' > $@
+       @$(CC) $(DEPEND_FLAG) $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*/.o $@!' > $@
        @test -s $@ || rm -f $@
 
 Makefile: $(srcdir)/Makefile.in config.status
@@ -324,11 +409,7 @@ config.status: $(srcdir)/configure
 $(srcdir)/configure: $(srcdir)/configure.ac $(srcdir)/aclocal.m4
        cd $(srcdir) && $(AUTOCONF)
 
-weekly: $(srcdir)/weekly.in config.status
-       CONFIG_FILES=weekly CONFIG_HEADERS= $(SHELL) ./config.status
-
-LIBTOOL_DEPS = @LIBTOOL_DEPS@
-$(LIBTOOL): $(LIBTOOL_DEPS)
-       $(SHELL) ./config.status --recheck
+$(srcdir)/aclocal.m4: $(srcdir)/acinclude.m4
+       cd $(srcdir) && $(ACLOCAL)
 
 -include $(DEP_FILES)