# 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)
-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
+.SUFFIXES: .ro .mo .d
+
+SUFFIX=@SUFFIX@
+SO=@SO@
+
+CLIENT_TARGETS=citadel$(SUFFIX) whobbs$(SUFFIX)
+SERVER_TARGETS=citserver setup $(CHKPWD)
+SERV_MODULES=modules/serv_chat$(SO) \
+ modules/serv_upgrade$(SO) modules/serv_expire$(SO)
+UTIL_TARGETS=aidepost netmailer netproc netsetup msgform readlog rcit \
+ stats citmail netpoll mailinglist userlist sendcommand \
+ base64 qpdecode
PROXY_TARGETS=proxy
-CFLAGS=@CFLAGS@ @DEFS@
+
+prefix=@prefix@
+srcdir=@srcdir@
+
+AUTH=@AUTH@
+DEFS=@DEFS@
+CPPFLAGS=@CPPFLAGS@ -I.
+CFLAGS=@CFLAGS@
CC=@CC@
-SERVER_LFLAGS=@LIBS@
+LIBS=@LIBS@
+LDFLAGS=@LDFLAGS@
+SERVER_LDFLAGS=@SERVER_LDFLAGS@
+PICFLAGS=@PICFLAGS@
CURSES=@CURSES@
+chkpwd_LIBS=@chkpwd_LIBS@
+LIBOBJS=@LIBOBJS@
+PTHREAD_DEFS=-D_REENTRANT
+INSTALL=@INSTALL@
+INSTALL_DATA=@INSTALL_DATA@
+SHELL=/bin/sh
+AUTOCONF=@AUTOCONF@
+
+# End configuration section
+
+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 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 routines.c routines2.c serv_chat.c \
+ serv_info.c serv_test.c serv_upgrade.c setup.c snprintf.c stats.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
+
+DEP_FILES=$(SOURCES:.c=.d)
client: $(CLIENT_TARGETS)
#
#
-citadel: ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o messages.o \
- commands.o client_chat.o serv_info.o
- $(CC) $(CFLAGS) ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o \
- messages.o commands.o client_chat.o serv_info.o $(LFLAGS) -o citadel
-
-netpoll: netpoll.o config.o ipc_c_tcp.o
- $(CC) $(CFLAGS) netpoll.o config.o ipc_c_tcp.o $(LFLAGS) -o netpoll
-
-netpoll.o: netpoll.c
- $(CC) $(CFLAGS) -c netpoll.c
-
-ipc_c_tcp.o: ipc_c_tcp.c
- $(CC) $(CFLAGS) -c ipc_c_tcp.c
-
-citadel.o: citadel.c
- $(CC) $(CFLAGS) -c citadel.c
-
-rooms.o: rooms.c
- $(CC) $(CFLAGS) -c rooms.c
+citadel$(SUFFIX): ipc_c_tcp.o citadel.o rooms.o routines.o routines2.o messages.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 \
+ commands.o client_chat.o serv_info.o tools.o $(LIBOBJS) $(LDFLAGS) \
+ -o citadel
-messages.o: messages.c
- $(CC) $(CFLAGS) -c messages.c
-
-commands.o: commands.c
- $(CC) $(CFLAGS) -c commands.c
-
-routines.o: routines.c
- $(CC) $(CFLAGS) -c routines.c
-
-routines2.o: routines2.c
- $(CC) $(CFLAGS) -c routines2.c
-
-client_chat.o: client_chat.c
- $(CC) $(CFLAGS) -c client_chat.c
-
-serv_info.o: serv_info.c
- $(CC) $(CFLAGS) -c serv_info.c
+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
+.c.o:
+ $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $<
#
#
-citserver: citserver.o user_ops.o support.o room_ops.o file_ops.o \
- msgbase.o config.o sysdep.o locate_host.o \
- housekeeping.o database.o control.o logging.o \
- dynloader.o
- $(CC) $(CFLAGS) -rdynamic \
- citserver.o user_ops.o room_ops.o file_ops.o support.o \
- msgbase.o config.o sysdep.o locate_host.o \
- housekeeping.o database.o control.o logging.o \
- dynloader.o \
- $(LFLAGS) $(SERVER_LFLAGS) -o citserver
-
-citserver.o: citserver.c
- $(CC) $(CFLAGS) -D_REENTRANT -c citserver.c
-
-user_ops.o: user_ops.c
- $(CC) $(CFLAGS) -D_REENTRANT -c user_ops.c
-
-room_ops.o: room_ops.c
- $(CC) $(CFLAGS) -D_REENTRANT -c room_ops.c
-
-dynloader.o: dynloader.c
- $(CC) $(CFLAGS) -D_REENTRANT -c dynloader.c
-
-file_ops.o: file_ops.c
- $(CC) $(CFLAGS) -D_REENTRANT -c file_ops.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 tools.ro mime_parser.ro $(AUTH) $(LIBOBJS:.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 tools.ro mime_parser.ro \
+ $(AUTH) $(LIBOBJS:.o=.ro)\
+ $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) -o citserver
-support.o: support.c
- $(CC) $(CFLAGS) -D_REENTRANT -c support.c
+.c.ro:
+ $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) -c $< -o $@
-msgbase.o: msgbase.c
- $(CC) $(CFLAGS) -D_REENTRANT -c msgbase.c
+modules/serv_chat.so: serv_chat.mo
+ $(CC) -shared -o modules/serv_chat.so serv_chat.mo
-locate_host.o: locate_host.c
- $(CC) $(CFLAGS) -D_REENTRANT -c locate_host.c
+modules/serv_chat.mo: serv_chat.mo
+ ln -f serv_chat.mo modules
-modules/serv_chat.so: serv_chat.o
- $(CC) -shared -o modules/serv_chat.so serv_chat.o
+.c.mo:
+ $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) $(PTHREAD_DEFS) $(PICFLAGS) -DPIC -c $< -o $@
-serv_chat.o: serv_chat.c
- $(CC) $(CFLAGS) -D_REENTRANT -fPIC -c serv_chat.c
+modules/serv_test.so: serv_test.mo
+ $(CC) -shared -o modules/serv_test.so serv_test.mo
-modules/serv_test.so: serv_test.o
- $(CC) -shared -o modules/serv_test.so serv_test.o
+modules/serv_test.mo: serv_test.mo
+ ln -f serv_test.mo modules
-serv_test.o: serv_test.c
- $(CC) $(CFLAGS) -D_REENTRANT -fPIC -c serv_test.c
+modules/serv_upgrade.so: serv_upgrade.mo
+ $(CC) -shared -o modules/serv_upgrade.so serv_upgrade.mo
-housekeeping.o: housekeeping.c
- $(CC) $(CFLAGS) -D_REENTRANT -c housekeeping.c
+modules/serv_upgrade.mo: serv_upgrade.mo
+ ln -f serv_upgrade.mo modules
-database.o: database.c
- $(CC) $(CFLAGS) -D_REENTRANT -c database.c
+modules/serv_expire.so: serv_expire.mo
+ $(CC) -shared -o modules/serv_expire.so serv_expire.mo
-control.o: control.c
- $(CC) $(CFLAGS) -D_REENTRANT -c control.c
+modules/serv_expire.mo: serv_expire.mo
+ ln -f serv_expire.mo modules
-logging.o: logging.c
- $(CC) $(CFLAGS) -D_REENTRANT -c logging.c
-
-config.o: config.c
- $(CC) $(CFLAGS) -D_REENTRANT -c config.c
-
-sysdep.o: sysdep.c
- $(CC) $(CFLAGS) -D_REENTRANT -c sysdep.c
-
-aidepost: aidepost.o config.o
- $(CC) $(CFLAGS) aidepost.o config.o $(LFLAGS) -o aidepost
-
-aidepost.o: aidepost.c
- $(CC) $(CFLAGS) -c aidepost.c
+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
# from your BBSUID rather than the actual sending user.
#
netmailer: netmailer.o internetmail.o config.o
- $(CC) $(CFLAGS) netmailer.o config.o internetmail.o $(LFLAGS) -o netmailer
- chmod 4755 netmailer
-
-netmailer.o: netmailer.c
- $(CC) $(CFLAGS) -c netmailer.c
+ $(CC) netmailer.o config.o internetmail.o $(LDFLAGS) -o netmailer
-internetmail.o: internetmail.c
- $(CC) $(CFLAGS) -c internetmail.c
+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
-netproc: netproc.o config.o ipc_c_tcp.o
- $(CC) $(CFLAGS) netproc.o config.o ipc_c_tcp.o \
- $(LFLAGS) -o netproc
-
-netproc.o: netproc.c
- $(CC) $(CFLAGS) -c netproc.c
-
-citmail: citmail.o config.o internetmail.o
- #
- # ###### IMPORTANT ######
- # To allow Citadel users to receive Internet mail, you must
- # set this program to be your local mail delivery agent.
- #
- $(CC) $(CFLAGS) citmail.o config.o internetmail.o $(LFLAGS) -o citmail
- chmod 4755 citmail
-
-citmail.o: citmail.c
- $(CC) $(CFLAGS) -c citmail.c
+citmail: citmail.o config.o internetmail.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 $(LIBOBJS) $(LDFLAGS) -o citmail
mailinglist: mailinglist.o config.o internetmail.o
- $(CC) $(CFLAGS) mailinglist.o config.o internetmail.o \
- $(LFLAGS) -o mailinglist
+ $(CC) mailinglist.o config.o internetmail.o $(LDFLAGS) -o mailinglist
-mailinglist.o: mailinglist.c
- $(CC) $(CFLAGS) -c mailinglist.c
+setup: setup.o tools.o
+ $(CC) setup.o tools.o $(CURSES) $(LDFLAGS) -o setup
-setup: setup.o
- $(CC) $(CFLAGS) setup.o $(CURSES) $(LFLAGS) -o setup
-
-setup.o: setup.c
- $(CC) $(CFLAGS) -c setup.c
+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) $(CFLAGS) netsetup.o config.o $(LFLAGS) -o netsetup
-
-netsetup.o: netsetup.c
- $(CC) $(CFLAGS) -c netsetup.c
+ $(CC) netsetup.o config.o $(LDFLAGS) -o netsetup
proxy: proxy.o ipc_c_tcp.o
- $(CC) $(CFLAGS) proxy.o ipc_c_tcp.o $(LFLAGS) -o proxy
+ $(CC) proxy.o ipc_c_tcp.o $(LDFLAGS) -o proxy
-proxy.o: proxy.c
- $(CC) $(CFLAGS) -c proxy.c
+whobbs$(SUFFIX): whobbs.o ipc_c_tcp.o tools.o $(LIBOBJS)
+ $(CC) whobbs.o ipc_c_tcp.o tools.o $(LIBOBJS) $(LDFLAGS) -o whobbs
-whobbs: whobbs.o ipc_c_tcp.o
- $(CC) $(CFLAGS) whobbs.o ipc_c_tcp.o $(LFLAGS) -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
-whobbs.o: whobbs.c
- $(CC) $(CFLAGS) -c whobbs.c
+qpdecode: qpdecode.o
+ $(CC) qpdecode.o $(LDFLAGS) -o qpdecode
-userlist: userlist.o ipc_c_tcp.o
- $(CC) $(CFLAGS) userlist.o ipc_c_tcp.o $(LFLAGS) -o userlist
+base64: base64.o
+ $(CC) base64.o $(LDFLAGS) -o base64
-userlist.o: userlist.c
- $(CC) $(CFLAGS) -c userlist.c
+userlist: userlist.o ipc_c_tcp.o tools.o $(LIBOBJS)
+ $(CC) userlist.o ipc_c_tcp.o tools.o \
+ $(LIBOBJS) $(LDFLAGS) -o userlist
msgform: msgform.o
- $(CC) $(CFLAGS) msgform.o $(LFLAGS) -o msgform
-
-msgform.o: msgform.c
- $(CC) $(CFLAGS) -c msgform.c
+ $(CC) msgform.o $(LDFLAGS) -o msgform
readlog: readlog.o config.o
- $(CC) $(CFLAGS) readlog.o config.o $(LFLAGS) -o readlog
-
-readlog.o: readlog.c
- $(CC) $(CFLAGS) -c readlog.c
+ $(CC) readlog.o config.o $(LDFLAGS) -o readlog
rcit: rcit.o config.o
- $(CC) $(CFLAGS) rcit.o config.o $(LFLAGS) -o rcit
- #
- # NOTE: TO RECEIVE CITADEL TRAFFIC VIA THE RCIT PROGRAM (ESPECIALLY
- # IF YOU ARE GATEWAYING TO USENET) YOU MUST LINK RNEWS TO RCIT:
- #ln -s rcit /usr/bin/rnews
- #
-
-rcit.o: rcit.c
- $(CC) $(CFLAGS) -c rcit.c
-
-stats: stats.o config.o
- $(CC) $(CFLAGS) stats.o config.o $(LFLAGS) -o stats
-
-stats.o: stats.c
- $(CC) $(CFLAGS) -c stats.c
+ $(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 ipc_c_tcp.o tools.o config.o $(LIBOBJS)
+ $(CC) stats.o ipc_c_tcp.o tools.o config.o $(LIBOBJS) $(LDFLAGS) -o stats
+
+.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 \
+ ./mkinstalldirs $(root)$(prefix)/$$i; \
+ done
+ @for i in citadel.rc public_clients \
+ `find help messages network -type f | grep -v CVS`; do \
+ $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+ echo $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+ done
+ @if test -d $(root)/etc/pam.d; then \
+ $(INSTALL_DATA) citadel.pam $(root)/etc/pam.d/citadel; \
+ echo $(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 \
+ $(INSTALL_DATA) $$i $(root)$(prefix)/$$i; \
+ echo $(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 \
+ if test -f $$i; then \
+ $(INSTALL) $$i $(root)$(prefix)/$$i; \
+ echo $(INSTALL) $$i $(root)$(prefix)/$$i; \
+ fi \
+ done
+ @if test -f $(root)$(prefix)/chkpwd; then \
+ chmod u+s $(root)$(prefix)/chkpwd; \
+ echo chmod +s $(root)$(prefix)/chkpwd; \
+ fi
clean:
- find . -name \*.[o] -print -exec rm -f {} \;
+ rm -f *.o *.ro *.mo
cleaner: clean
rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
- $(SERV_MODULES) $(PROXY_TARGETS)
+ $(SERV_MODULES) $(PROXY_TARGETS) so_locations
+
+distclean: cleaner
+ rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
+
+.c.d:
+ @echo Checking dependencies for $<
+ @$(CC) -M $(CPPFLAGS) $< | 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.in $(srcdir)/aclocal.m4
+ cd $(srcdir) && $(AUTOCONF)
-realclean: cleaner
- rm -f Makefile sysdep.h config.cache config.log config.status
+weekly: $(srcdir)/weekly.in config.status
+ CONFIG_FILES=weekly CONFIG_HEADERS= $(SHELL) ./config.status
-.depend: $(wildcard *.c) $(wildcard *.h)
- $(CC) -MM *.c > .depend
+-include $(DEP_FILES)