-# 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
# 2. Send e-mail to ajc@uncensored.citadel.org and let me know what you
# did, so any necessary changes can be put into the next release.
#
-# $Id$
-#
########################################################################
+prefix=@prefix@
+srcdir=@srcdir@
+VPATH=$(srcdir)
+
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@
+HELP_DIR=@MAKE_HELP_DIR@
+DOC_DIR=@MAKE_DOC_DIR@
+UTILBIN_DIR=@MAKE_UTILBIN_DIR@
+DEPEND_FLAG=@DEPEND_FLAG@
+all: buildinfo $(TARGETS)
+
+.SUFFIXES: .o .d .c
-all: $(TARGETS)
+EXEEXT=@EXEEXT@
-.SUFFIXES: .ro .mo .d .c
+SERVER_TARGETS=citserver$(EXEEXT)
-EXEEXT=@EXEEXT@
-SO=@SO@
-CX=@CX@
-
-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_pop3$(SO) \
- modules/serv_imap$(SO) \
- modules/serv_network$(SO) \
- modules/serv_pas2$(SO) \
- modules/serv_inetcfg$(SO) \
- modules/serv_rwho$(SO) \
- modules/serv_moderate$(SO) \
- modules/serv_bio$(SO) \
- modules/serv_expire$(SO) \
- modules/serv_vandelay$(SO) \
- modules/serv_ical$(SO)
-UTIL_TARGETS=aidepost netmailer netproc netsetup msgform readlog rcit \
- stats citmail netpoll mailinglist userlist sendcommand \
- base64 qpdecode
+include Make_modules
+
+UTIL_TARGETS=citmail$(EXEEXT) sendcommand$(EXEEXT)
+
+UTILBIN_TARGETS= base64$(EXEEXT) setup$(EXEEXT) \
+ chkpw$(EXEEXT) chkpwd$(EXEEXT) \
+ aidepost$(EXEEXT) msgform$(EXEEXT) \
+ ctdlmigrate$(EXEEXT)
-prefix=@prefix@
-srcdir=@srcdir@
-AUTH=@AUTH@
-DEFS=@DEFS@
-CPPFLAGS=@CPPFLAGS@ -I.
-CFLAGS=@CFLAGS@
+ACLOCAL=@ACLOCAL@
+AUTOCONF=@AUTOCONF@
+chkpwd_LIBS=@chkpwd_LIBS@
CC=@CC@
-GDBM=@GDBM@
-RESOLV=@RESOLV@
-LINK_SHARED=@LINK_SHARED@
-LIBS=@LIBS@
+CFLAGS=@CFLAGS@ -I ./include/
+CPPFLAGS=@CPPFLAGS@ -I. -I ./include/
+DATABASE=@DATABASE@
+DEFS=@DEFS@ -DDIFF=\"@DIFF@\" -DPATCH=\"@PATCH@\"
LDFLAGS=@LDFLAGS@
-SERVER_LDFLAGS=@SERVER_LDFLAGS@
-PICFLAGS=@PICFLAGS@
-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@
+DIFF=@DIFF@
+PATCH=@PATCH@
+LOCALEDIR=@LOCALEDIR@
# End configuration section
-VPATH=$(srcdir)
+.SILENT:
-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 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 rcit.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.c 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
-DEP_FILES=$(SOURCES:.c=.d)
+SOURCES=utils/aidepost.c utils/citmail.c \
+ utils/setup.c utils/msgform.c utils/chkpw.c \
+ utils/sendcommand.c \
+ utils/ctdlmigrate.c utils/base64.c utils/chkpwd.c \
+ utillib/citadel_dirs.c \
+ citserver.c clientsocket.c config.c control.c $(DATABASE) \
+ domain.c serv_extensions.c genstamp.c \
+ housekeeping.c ical_dezonify.c internet_addressing.c ecrash.c \
+ locate_host.c auth.c msgbase.c parsedate.c \
+ room_ops.c euidindex.c server_main.c ldap.c \
+ support.c sysdep.c user_ops.c journaling.c threads.c \
+ context.c netconfig.c nttlist.c md5.c
-client: $(CLIENT_TARGETS)
-server: $(SERVER_TARGETS)
+include Make_sources
-utils: $(UTIL_TARGETS)
+# for VPATH builds (invoked by configure)
+mkdir-init:
+ DIRS=`/bin/ls $(VPATH)/modules/`
+ echo $(DIRS)
+ @for d in `/bin/ls $(VPATH)/modules/`; do \
+ (mkdir -p modules/$$d ) ; \
+ done
+ DIRS=`/bin/ls $(VPATH)/user_modules/`
+ echo $(DIRS)
+ @for d in `/bin/ls $(VPATH)/user_modules/`; do \
+ (mkdir -p user_modules/$$d ) ; \
+ done
+ mkdir -p utils utillib
+ mkdir locale
-serv_modules: $(SERV_MODULES)
+svn_revision.c: ${SOURCES}
+ $(srcdir)/scripts/mk_svn_revision.sh
-#
-#
+DEP_FILES=$(SOURCES:.c=.d) modules_init.d modules_upgrade.d
-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)
+noinst: $(NOINST_TARGETS)
-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)
+server: $(SERVER_TARGETS) $(SERV_MODULES)
-.c.o:
- $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $<
+utils: $(UTIL_TARGETS) $(UTILBIN_TARGETS)
.y.c:
$(YACC) $(YFLAGS) $<
#
#
-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:.c=.ro) control.ro logging.ro policy.ro dynloader.ro tools.ro \
- mime_parser.ro html.ro internet_addressing.ro \
- parsedate.ro genstamp.ro clientsocket.ro \
- $(AUTH) $(LIBOBJS:.o=.ro)
-
-parsedate.ro: parsedate.c
-
-citserver: $(SERV_OBJS)
- $(CC) $(SERV_OBJS) $(LDFLAGS) $(SERVER_LDFLAGS) $(PTHREAD_LIBS) \
- $(LIBS) $(NETLIBS) $(GDBM) $(RESOLV) -o citserver
-
-.c.ro:
- $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
-
-.c.mo:
- @test -d modules || mkdir -p modules
- $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) $(PICFLAGS) -DPIC -c $< -o $@
-
-modules/serv_chat.so: serv_chat.mo
- $(LINK_SHARED) -o modules/serv_chat.so serv_chat.mo
-
-modules/serv_test.so: serv_test.mo
- $(LINK_SHARED) -o modules/serv_test.so serv_test.mo
-
-modules/serv_pop3.so: serv_pop3.mo md5.mo
- $(LINK_SHARED) -o modules/serv_pop3.so serv_pop3.mo md5.mo
-
-modules/serv_inetcfg.so: serv_inetcfg.mo
- $(LINK_SHARED) -o modules/serv_inetcfg.so serv_inetcfg.mo
-
-modules/serv_rwho.so: serv_rwho.mo
- $(LINK_SHARED) -o modules/serv_rwho.so serv_rwho.mo
-
-modules/serv_moderate.so: serv_moderate.mo
- $(LINK_SHARED) -o modules/serv_moderate.so serv_moderate.mo
-
-modules/serv_bio.so: serv_bio.mo
- $(LINK_SHARED) -o modules/serv_bio.so serv_bio.mo
-
-modules/serv_expire.so: serv_expire.mo
- $(LINK_SHARED) -o modules/serv_expire.so serv_expire.mo
-
-modules/serv_vandelay.so: serv_vandelay.mo
- $(LINK_SHARED) -o modules/serv_vandelay.so serv_vandelay.mo
-
-modules/serv_network.so: serv_network.mo
- $(LINK_SHARED) -o modules/serv_network.so serv_network.mo
-
-modules/serv_upgrade.so: serv_upgrade.mo
- $(LINK_SHARED) -o modules/serv_upgrade.so serv_upgrade.mo
+parsedate.o: parsedate.c
-modules/serv_vcard.so: serv_vcard.mo vcard.mo
- $(LINK_SHARED) -o modules/serv_vcard.so serv_vcard.mo vcard.mo
+Make_sources: modules_init.c
-modules/serv_smtp.so: serv_smtp.mo domain.mo
- $(LINK_SHARED) -o modules/serv_smtp.so serv_smtp.mo domain.mo
+Make_modules: modules_init.c
-modules/serv_imap.so: serv_imap.mo imap_tools.mo imap_fetch.mo \
- imap_search.mo imap_store.mo imap_misc.mo
- $(LINK_SHARED) -o modules/serv_imap.so imap_tools.mo serv_imap.mo \
- imap_fetch.mo imap_search.mo imap_store.mo imap_misc.mo
+modules_upgrade.c: modules_init.c
-aidepost: aidepost.o config.o $(LIBOBJS)
- $(CC) aidepost.o config.o $(LIBOBJS) $(LDFLAGS) -o aidepost
+SERV_OBJS = server_main.o utillib/citadel_dirs.o \
+ user_ops.o citserver.o sysdep.o serv_extensions.o \
+ $(DATABASE:.c=.o) domain.o \
+ control.o config.o support.o room_ops.o \
+ msgbase.o euidindex.o \
+ locate_host.o housekeeping.o ical_dezonify.o \
+ internet_addressing.o journaling.o \
+ parsedate.o genstamp.o ecrash.o threads.o context.o \
+ clientsocket.o modules_init.o modules_upgrade.o $(SERV_MODULES) \
+ svn_revision.o ldap.o netconfig.o nttlist.o md5.o
-modules/serv_pas2.so: serv_pas2.mo md5.mo
- $(LINK_SHARED) -o modules/serv_pas2.so serv_pas2.mo md5.mo
+citserver$(EXEEXT): $(SERV_OBJS)
+ $(CC) $(SERV_OBJS) $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) $(SERVER_LIBS) $(RESOLV) -o citserver$(EXEEXT)
-modules/serv_ical.so: serv_ical.mo
- $(LINK_SHARED) -o modules/serv_ical.so serv_ical.mo
+%.o: %.c ${HEADERS}
+ echo "CC $<"
+ $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $< -o $@
+aidepost$(EXEEXT): utils/aidepost.o utillib/citadel_dirs.o
+ $(CC) utils/aidepost.o utillib/citadel_dirs.o \
+ $(LDFLAGS) -o aidepost$(EXEEXT) $(LIBS)
+citmail$(EXEEXT): utils/citmail.o utillib/citadel_dirs.o
+ $(CC) utils/citmail.o utillib/citadel_dirs.o \
+ $(LDFLAGS) -o citmail$(EXEEXT) $(LIBS)
-#
-# 'netmailer' needs to run setuid because it generates headers for Internet
-# mail. If it is not run setuid, all outgoing mail may always show as coming
-# from your BBSUID rather than the actual sending user.
-#
-netmailer: netmailer.o internetmail.o config.o genstamp.o
- $(CC) netmailer.o config.o internetmail.o genstamp.o \
- $(LDFLAGS) -o netmailer
-
-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)
-
-citmail: citmail.o config.o
- $(CC) citmail.o config.o $(LDFLAGS) -o citmail $(NETLIBS)
-
-mailinglist: mailinglist.o config.o internetmail.o
- $(CC) mailinglist.o config.o internetmail.o $(LDFLAGS) -o mailinglist
-
-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$(EXEEXT): utils/setup.o utillib/citadel_dirs.o
+ $(CC) utils/setup.o utillib/citadel_dirs.o \
+ $(LDFLAGS) -o setup$(EXEEXT) $(LIBS) $(SETUP_LIBS)
-chkpwd: chkpwd.o auth.o config.o
- $(CC) chkpwd.o auth.o config.o $(LDFLAGS) -o chkpwd $(chkpwd_LIBS)
+ctdlmigrate$(EXEEXT): utils/ctdlmigrate.o utillib/citadel_dirs.o
+ $(CC) utils/ctdlmigrate.o utillib/citadel_dirs.o \
+ $(LDFLAGS) -o ctdlmigrate$(EXEEXT) $(LIBS)
-netsetup: netsetup.o config.o
- $(CC) netsetup.o config.o $(LDFLAGS) -o netsetup
+chkpwd$(EXEEXT): utils/chkpwd.o auth.o
+ $(CC) utils/chkpwd.o auth.o $(LDFLAGS) -o chkpwd$(EXEEXT) $(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)
+chkpw$(EXEEXT): utils/chkpw.o auth.o utillib/citadel_dirs.o
+ $(CC) utils/chkpw.o auth.o utillib/citadel_dirs.o \
+ $(LDFLAGS) -o chkpw$(EXEEXT) $(chkpwd_LIBS)
-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)
+sendcommand$(EXEEXT): utils/sendcommand.o utillib/citadel_dirs.o $(LIBOBJS)
+ $(CC) utils/sendcommand.o utillib/citadel_dirs.o \
+ $(LIBOBJS) $(LDFLAGS) -o sendcommand$(EXEEXT) $(LIBS)
-qpdecode: qpdecode.o
- $(CC) qpdecode.o $(LDFLAGS) -o qpdecode
+base64$(EXEEXT): utils/base64.o
+ $(CC) utils/base64.o $(LDFLAGS) -o base64$(EXEEXT)
-base64: base64.o
- $(CC) base64.o $(LDFLAGS) -o base64
+msgform$(EXEEXT): utils/msgform.o
+ $(CC) utils/msgform.o $(LDFLAGS) -o msgform$(EXEEXT)
-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
-
-readlog: readlog.o config.o
- $(CC) readlog.o config.o $(LDFLAGS) -o readlog
+.PHONY: install-data install-doc install-exec clean cleaner distclean
-rcit: rcit.o config.o
- $(CC) rcit.o config.o $(LDFLAGS) -o rcit
+install-locale:
+ cd po/citadel-setup; $(MAKE)
+ for i in `find locale -type d | grep -v .svn` \
+ ; do \
+ test -d $(DESTDIR)$(LOCALEDIR)/$$i || mkdir -p $(DESTDIR)$(LOCALEDIR)/$$i; \
+ done
+ for i in `find locale -type f | grep -v .svn`; do \
+ $(INSTALL) $$i $(DESTDIR)$(LOCALEDIR)/$$i; \
+ done
-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)
+install: install-exec install-data install-doc install-locale
+ @echo
+ @echo Installation is complete.
+ @echo Now go to your Citadel directory and run 'setup'.
+ @echo
-.PHONY: install-data install-doc install-exec clean cleaner distclean
+install-new: install-exec-new install-data-new install-doc-new install-locale
+ @echo
+ @echo Installation is complete.
+ @echo Now go to your Citadel directory and run 'setup'.
+ @echo
-install: install-exec install-data install-doc
+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; \
+ @for i in funambol_newmail_soap.xml notify_about_newmail.js public_clients citadel_urlshorteners.rc \
+ `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_urlshorteners.rc $(DESTDIR)$(ETC_DIR)/citadel_urlshorteners.rc
+ $(INSTALL_DATA) $(srcdir)/network/mail.aliases $(DESTDIR)$(ETC_DIR)/mail.aliases$
+
+ $(srcdir)/mkinstalldirs $(DESTDIR)$(STATICDATA_DIR)/messages
+ @for i in \
+ `find $(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)$(HELP_DIR)/help
+ @for i in funambol_newmail_soap.xml notify_about_newmail.js \
+ `find $(srcdir)/help -type f | grep -v .svn`; do \
+ echo $(INSTALL_DATA) $$i $(DESTDIR)$(HELP_DIR)/$$i; \
+ $(INSTALL_DATA) $$i $(DESTDIR)$(HELP_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 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
+ @for i in `cd openldap; find $(srcdir)/ -type f | grep -v .svn`; do \
+ echo $(INSTALL_DATA) openldap/$$i $(DESTDIR)$(prefix)/$$i; \
+ $(INSTALL_DATA) openldap/$$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
+ @for i in `cd openldap; find $(srcdir)/ -type f | grep -v .svn`; do \
+ echo $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
+ $(INSTALL_DATA) openldap/$$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 files images info userpics; do \
+ $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/$$i; \
done
- @for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
- $(SERV_MODULES) ; do \
+ @for i in $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS); do \
if test -f $$i; then \
- echo $(INSTALL) $$i $(root)$(prefix)/$$i; \
- $(INSTALL) $$i $(root)$(prefix)/$$i; \
+ echo $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
+ $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
fi \
done
- @for i in utilsmenu weekly dnetsetup; do \
+ $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/unstripped
+ cp $(SERVER_TARGETS) $(DESTDIR)$(prefix)/unstripped/
+
+ @for i in utilsmenu database_cleanup.sh migrate_aliases.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)$(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 \
+ echo $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
+ $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
+ fi \
+ done
+ cp citserver $(DESTDIR)/$(UTILBIN_DIR)/citserver.unstripped
+ cp migrate_aliases.sh $(DESTDIR)/$(UTILBIN_DIR)/
+ @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 utilsmenu database_cleanup.sh citadel-openldap.schema ; do \
+ if test -f $(srcdir)/$$i; then \
+ 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 *.mo parsedate.c
+ rm -vfr locale/*
+ rm -vf *.o
+ rm -vf utils/*.o ;\
+ rm -vf utillib/*.o ;\
+ for i in $(srcdir)/modules/* ; do \
+ rm -vf $$i/*.o ;\
+ done
+ if test -d $(srcdir)/user_modules ; then \
+ for i in $(srcdir)/user_modules/* ; do \
+ rm -vf $$i/*.o ;\
+ done \
+ fi
+ rm -vf $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS) $(NOINST_TARGETS)
+
cleaner: clean
- rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
- modules/*.[ms]o so_locations
+ rm -vrf $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS) $(NOINST_TARGETS) database_cleanup.sh *.la
+ rm -vrf modules_upgrade.c modules_init.c modules_init.h Make_modules Make_sources
distclean: cleaner
- find . -name '*~' -o -name '.#*' | xargs rm -f
- rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
+ find . -name '*~' -o -name '.#*' | xargs rm -vf
+ rm -vf po/Makefile
+ rm -vf Makefile configure sysdep.h config.cache config.log config.status *.d
+ rm -vf utils/*.d ;
+ rm -vf utillib/*.d ;
+ for i in $(srcdir)/modules/* ; do \
+ rm -vf $$i/*.d ;\
+ done
+ if test -d $(srcdir)/user_modules ; then \
+ for i in $(srcdir)/user_modules/* ; do \
+ rm -vf $$i/*.o ;\
+ done \
+ fi
.c.d:
@echo Checking dependencies for $<
- @$(CC) -M $(CPPFLAGS) $(PTHREAD_DEFS) $< | sed -e 's!$*.o!$*.o $*.ro $*.mo $@!' > $@
+ @$(CC) $(DEPEND_FLAG) $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*/.o $@!' > $@
@test -s $@ || rm -f $@
Makefile: $(srcdir)/Makefile.in config.status
$(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
+$(srcdir)/aclocal.m4: $(srcdir)/acinclude.m4
+ cd $(srcdir) && $(ACLOCAL)
+
+buildinfo:
+ echo
+ echo "Dependencies: $(CC) $(DEPEND_FLAG) $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*/.o $@!' > $@"
+ echo "Compile: $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $< -o $@ "
+ echo "LDFLAGS: $(LDFLAGS)"
+ echo
-include $(DEP_FILES)