]> code.citadel.org Git - citadel.git/blobdiff - citadel/Makefile.in
generate symlinks to .libs in modules directory
[citadel.git] / citadel / Makefile.in
index 2b64808aa84f4babca2761f1a5826182c8c1099f..44de4329a0ebd342768978436c69a4b14eb25e21 100644 (file)
@@ -5,31 +5,94 @@
 # uses "Makefile.in" to generate a "Makefile".  In the rare instance
 # that you have to modify something here, please take note:
 # 1. Edit Makefile.in, -not- Makefile.
-# 2. Send e-mail to ajc@uncnsrd.mt-kisco.ny.us and let me know what you
+# 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$
+#
 ########################################################################
 
 TARGETS=@TARGETS@
+CHKPWD=@CHKPWD@
 
 all: $(TARGETS)
 
-CLIENT_TARGETS=citadel whobbs
-SERVER_TARGETS=citserver setup
-SERV_MODULES=modules/serv_chat.so modules/serv_test.so
-UTIL_TARGETS=aidepost netmailer netproc netsetup msgform \
-       readlog rcit stats citmail netpoll mailinglist userlist
-PROXY_TARGETS=proxy
+.SUFFIXES: .lo .ro .d .c
+
+EXEEXT=@EXEEXT@
+CX=@CX@
+
+CLIENT_TARGETS=citadel$(EXEEXT) whobbs$(EXEEXT)
+SERVER_TARGETS=citserver setup $(CHKPWD)
+SERV_MODULES=modules/serv_chat.la modules/serv_vcard.la \
+       modules/serv_upgrade.la \
+       modules/serv_smtp.la \
+       modules/serv_pop3.la \
+       modules/serv_imap.la \
+       modules/serv_network.la \
+       modules/serv_pas2.la \
+       modules/serv_inetcfg.la \
+       modules/serv_rwho.la \
+       modules/serv_moderate.la \
+       modules/serv_bio.la \
+       modules/serv_expire.la \
+       modules/serv_vandelay.la \
+       modules/serv_ical.la
+UTIL_TARGETS=aidepost netmailer netproc netsetup msgform readlog rcit \
+       stats citmail netpoll mailinglist userlist sendcommand \
+       base64 qpdecode
+
+prefix=@prefix@
+srcdir=@srcdir@
+
+AUTH=@AUTH@
 DEFS=@DEFS@
-CPPFLAGS=@CPPFLAGS@
+CPPFLAGS=@CPPFLAGS@ -I.
 CFLAGS=@CFLAGS@
 CC=@CC@
+GDBM=@GDBM@
+RESOLV=@RESOLV@
 LIBS=@LIBS@
 LDFLAGS=@LDFLAGS@
-SERVER_LDFLAGS=@SERVER_LDFLAGS@
 CURSES=@CURSES@
-SNPRINTF=@SNPRINTF@
-PTHREAD_DEFS=-D_REENTRANT
+NETLIBS=@NETLIBS@
+chkpwd_LIBS=@chkpwd_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@
+SHELL=/bin/sh
+AUTOCONF=@AUTOCONF@
+YACC=@YACC@
+DATABASE=@DATABASE@
+
+LIBTOOL=./libtool
+LTSHARE=$(LIBTOOL) $(CC) -rpath $(prefix)/modules -module -avoid-version
+
+# End configuration section
+
+VPATH=$(srcdir)
+
+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)
 
 client: $(CLIENT_TARGETS)
 
@@ -38,90 +101,154 @@ 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
 
 #
 #
 
-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) $^ $(LDFLAGS) -o citadel
-
-netpoll: netpoll.o config.o ipc_c_tcp.o
-       $(CC) netpoll.o config.o ipc_c_tcp.o $(LDFLAGS) -o netpoll
-
-%.o: %.c
+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)
+
+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 $<
 
+.y.c:
+       $(YACC) $(YFLAGS) $<
+       mv -f y.tab.c $@
+
 #
 #
 
-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
-
-%.ro: %.c
+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) $(LIBTOOL)
+       $(LIBTOOL) --mode=link $(CC) -export-dynamic $(SERV_OBJS) $(LDFLAGS) $(PTHREAD_LIBS) \
+       $(LIBS) $(NETLIBS) $(GDBM) $(RESOLV) -o citserver
+
+.c.ro:
        $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
 
-modules/serv_chat.so: serv_chat.o
-       $(CC) -shared -o modules/serv_chat.so serv_chat.o
+.c.lo: $(LIBTOOL)
+       @test -d modules || mkdir -p modules
+       $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
+
+modules/serv_chat.la: serv_chat.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_chat.la serv_chat.lo
+
+modules/serv_test.la: serv_test.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_test.la serv_test.lo
+
+modules/serv_pop3.la: serv_pop3.lo md5.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_pop3.la serv_pop3.lo md5.lo
+
+modules/serv_inetcfg.la: serv_inetcfg.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_inetcfg.la serv_inetcfg.lo
+
+modules/serv_rwho.la: serv_rwho.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_rwho.la serv_rwho.lo
+
+modules/serv_moderate.la: serv_moderate.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_moderate.la serv_moderate.lo
+
+modules/serv_bio.la: serv_bio.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_bio.la serv_bio.lo
+
+modules/serv_expire.la: serv_expire.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_expire.la serv_expire.lo
+
+modules/serv_vandelay.la: serv_vandelay.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_vandelay.la serv_vandelay.lo
+
+modules/serv_network.la: serv_network.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_network.la serv_network.lo
 
-serv_chat.o: serv_chat.c
-       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -fPIC -c serv_chat.c
+modules/serv_upgrade.la: serv_upgrade.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_upgrade.la serv_upgrade.lo
 
-modules/serv_test.so: serv_test.o
-       $(CC) -shared -o modules/serv_test.so serv_test.o
+modules/serv_vcard.la: serv_vcard.lo vcard.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_vcard.la serv_vcard.lo vcard.lo
+
+modules/serv_smtp.la: serv_smtp.lo domain.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_smtp.la serv_smtp.lo domain.lo
+
+modules/serv_imap.la: serv_imap.lo imap_tools.lo imap_fetch.lo \
+       imap_search.lo imap_store.lo imap_misc.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_imap.la imap_tools.lo serv_imap.lo \
+               imap_fetch.lo imap_search.lo imap_store.lo imap_misc.lo
+
+aidepost: aidepost.o config.o $(LIBOBJS)
+       $(CC) aidepost.o config.o $(LIBOBJS) $(LDFLAGS) -o aidepost
+
+modules/serv_pas2.la: serv_pas2.lo md5.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_pas2.la serv_pas2.lo md5.lo
+
+modules/serv_ical.la: serv_ical.lo $(LIBTOOL)
+       $(LTSHARE) -o modules/serv_ical.la serv_ical.lo
 
-serv_test.o: serv_test.c
-       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -fPIC -c serv_test.c
 
-aidepost: aidepost.o config.o
-       $(CC) aidepost.o config.o $(LDFLAGS) -o aidepost
 
 #
 # '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
-       $(CC) netmailer.o config.o internetmail.o $(LDFLAGS) -o netmailer
-       chmod 4755 netmailer
-
-netproc: netproc.o config.o ipc_c_tcp.o
-       $(CC) netproc.o config.o ipc_c_tcp.o $(LDFLAGS) -o netproc
-
-citmail: citmail.o config.o internetmail.o
-       @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
-       chmod 4755 citmail
+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
-       $(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
+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: whobbs.o ipc_c_tcp.o
-       $(CC) whobbs.o ipc_c_tcp.o $(LDFLAGS) -o whobbs
+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)
 
-userlist: userlist.o ipc_c_tcp.o
-       $(CC) userlist.o ipc_c_tcp.o $(LDFLAGS) -o userlist
+qpdecode: qpdecode.o
+       $(CC) qpdecode.o $(LDFLAGS) -o qpdecode
+
+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
@@ -131,25 +258,88 @@ readlog: readlog.o config.o
 
 rcit: rcit.o config.o
        $(CC) rcit.o config.o $(LDFLAGS) -o rcit
-       @echo "*"
-       @echo "* NOTE: TO RECEIVE CITADEL TRAFFIC VIA THE RCIT PROGRAM (ESPECIALLY"
-       @echo "* IF YOU ARE GATEWAYING TO USENET) YOU MUST LINK RNEWS TO RCIT:"
-       @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-data:
+       @for i in help messages network/spoolin network/spoolout \
+                network/systems; do \
+               $(srcdir)/mkinstalldirs $(root)$(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; \
+       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; \
+       fi
+
+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; \
+       done
+
+install-exec: all weekly
+       @for i in bio bitbucket files images info modules userpics; do \
+               $(srcdir)/mkinstalldirs $(root)$(prefix)/$$i; \
+       done
+       @for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
+                $(SERV_MODULES) ; do \
+               if test -f $$i; then \
+                       echo $(LIBTOOL) --mode=install $(INSTALL) $$i $(root)$(prefix)/$$i; \
+                       $(LIBTOOL) --mode=install $(INSTALL) $$i $(root)$(prefix)/$$i; \
+               fi \
+       done
+       @for i in utilsmenu weekly dnetsetup; do \
+               if test -f $(srcdir)/$$i; then \
+                       echo $(INSTALL) $(srcdir)/$$i $(root)$(prefix)/$$i; \
+                       $(INSTALL) $(srcdir)/$$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:
-       find . -name \*.o -print -exec rm -f {} \;
-       find . -name \*.ro -print -exec rm -f {} \;
+       rm -f *.o *.ro *.lo parsedate.c
 
 cleaner: clean
-       rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
-               $(SERV_MODULES) $(PROXY_TARGETS) so_locations
+       rm -rf $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
+               modules/*.la modules/.libs so_locations
+
+distclean: cleaner
+       find . -name '*~' -o -name '.#*' | xargs rm -f
+       rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
+
+.c.d:
+       @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
+
+config.status: $(srcdir)/configure
+       $(SHELL) ./config.status --recheck
+
+$(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
 
-realclean: cleaner
-       rm -f Makefile sysdep.h config.cache config.log config.status
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+$(LIBTOOL): $(LIBTOOL_DEPS)
+       $(SHELL) ./config.status --recheck
 
-.depend: $(wildcard *.c) $(wildcard *.h)
-       $(CC) -MM *.c > .depend
+-include $(DEP_FILES)