# 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$
all: $(TARGETS)
-.SUFFIXES: .ro .mo .d
+.SUFFIXES: .ro .mo .d .c
EXEEXT=@EXEEXT@
SO=@SO@
CX=@CX@
-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_pop3$(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_expire$(SO) $(SERV_ICQ)
+ modules/serv_moderate$(SO) \
+ modules/serv_bio$(SO) \
+ modules/serv_expire$(SO) \
+ modules/serv_vandelay$(SO)
UTIL_TARGETS=aidepost netmailer netproc netsetup msgform readlog rcit \
stats citmail netpoll mailinglist userlist sendcommand \
base64 qpdecode
-PROXY_TARGETS=proxy
prefix=@prefix@
srcdir=@srcdir@
INSTALL_DATA=@INSTALL_DATA@
SHELL=/bin/sh
AUTOCONF=@AUTOCONF@
+YACC=@YACC@
+DATABASE=@DATABASE@
# End configuration section
VPATH=$(srcdir)
SOURCES=aidepost.c citadel.c citmail.c citserver.c client_chat.c commands.c \
- config.c control.c database.c dynloader.c file_ops.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 proxy.c rcit.c readlog.c \
- room_ops.c rooms.c routines.c routines2.c serv_chat.c serv_icq.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 client_icq.c html.c vcard.c serv_upgrade.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
+ domain.c clientsocket.c serv_inetcfg.c serv_rwho.c serv_bio.c \
+ serv_moderate.c client_passwords.c \
+ serv_imap.c imap_tools.c imap_fetch.c imap_search.c \
+ serv_network.c serv_pas2.c md5.c
DEP_FILES=$(SOURCES:.c=.d)
#
citadel$(EXEEXT): ipc_c_tcp$(CX) citadel$(CX) rooms$(CX) routines$(CX) \
- routines2$(CX) messages$(CX) client_icq$(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) client_icq$(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)
.c.o:
$(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $<
+.y.c:
+ $(YACC) $(YFLAGS) $<
+ mv -f y.tab.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.ro control.ro logging.ro policy.ro dynloader.ro tools.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:
+ @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_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
$(LINK_SHARED) -o modules/serv_test.so serv_test.mo
modules/serv_test.mo: serv_test.mo
ln -f serv_test.mo modules
-modules/serv_pop3.so: serv_pop3.mo
- $(LINK_SHARED) -o modules/serv_pop3.so serv_pop3.mo
+modules/serv_pop3.so: serv_pop3.mo md5.mo
+ $(LINK_SHARED) -o modules/serv_pop3.so serv_pop3.mo md5.mo
modules/serv_pop3.mo: serv_pop3.mo
ln -f serv_pop3.mo modules
modules/serv_rwho.mo: serv_rwho.mo
ln -f serv_rwho.mo modules
+modules/serv_moderate.so: serv_moderate.mo
+ $(LINK_SHARED) -o modules/serv_moderate.so serv_moderate.mo
+
+modules/serv_moderate.mo: serv_moderate.mo
+ ln -f serv_moderate.mo modules
+
+modules/serv_bio.so: serv_bio.mo
+ $(LINK_SHARED) -o modules/serv_bio.so serv_bio.mo
+
+modules/serv_bio.mo: serv_bio.mo
+ ln -f serv_bio.mo modules
+
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_vandelay.so: serv_vandelay.mo
+ $(LINK_SHARED) -o modules/serv_vandelay.so serv_vandelay.mo
+
+modules/serv_vandelay.mo: serv_vandelay.mo
+ ln -f serv_vandelay.mo modules
+
+modules/serv_network.so: serv_network.mo
+ $(LINK_SHARED) -o modules/serv_network.so serv_network.mo
-modules/serv_icq.mo: serv_icq.mo
- ln -f serv_icq.mo modules
+modules/serv_network.mo: serv_network.mo
+ ln -f serv_network.mo modules
modules/serv_upgrade.so: serv_upgrade.mo
$(LINK_SHARED) -o modules/serv_upgrade.so serv_upgrade.mo
modules/domain.mo: domain.mo
ln -f domain.mo modules
+modules/serv_imap.so: serv_imap.mo imap_tools.mo imap_fetch.mo imap_search.mo
+ $(LINK_SHARED) -o modules/serv_imap.so imap_tools.mo serv_imap.mo \
+ imap_fetch.mo imap_search.mo
+
+modules/serv_imap.mo: serv_imap.mo
+ ln -f serv_imap.mo modules
+
+modules/imap_tools.mo: imap_tools.mo
+ ln -f imap_tools.mo modules
+
+modules/imap_fetch.mo: imap_fetch.mo
+ ln -f imap_fetch.mo modules
+
+modules/imap_search.mo: imap_search.mo
+ ln -f imap_search.mo modules
+
aidepost: aidepost.o config.o $(LIBOBJS)
$(CC) aidepost.o config.o $(LIBOBJS) $(LDFLAGS) -o aidepost
+modules/serv_pas2.so: serv_pas2.mo md5.mo
+ $(LINK_SHARED) -o modules/serv_pas2.so serv_pas2.mo md5.mo
+
+modules/serv_pas2.mo: serv_pas2.mo
+ ln -f serv_pas2.mo modules
+
+modules/md5.mo: md5.mo
+ ln -f md5.mo modules
+
+
+
#
# '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
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)
+ $(LIBOBJS) $(LDFLAGS) -o netproc $(NETLIBS)
citmail: citmail.o config.o
- $(CC) citmail.o config.o $(LDFLAGS) -o citmail
+ $(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
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 $(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)
install-data:
@for i in help messages network/spoolin network/spoolout \
network/systems; do \
- ./mkinstalldirs $(root)$(prefix)/$$i; \
+ $(srcdir)/mkinstalldirs $(root)$(prefix)/$$i; \
done
@for i in citadel.rc public_clients \
- `find help messages network -type f | grep -v CVS`; do \
+ `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) citadel.pam $(root)/etc/pam.d/citadel; \
- $(INSTALL_DATA) citadel.pam $(root)/etc/pam.d/citadel; \
+ echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(root)/etc/pam.d/citadel; \
+ $(INSTALL_DATA) $(srcdir)/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 \
+ @$(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 \
- ./mkinstalldirs $(root)$(prefix)/$$i; \
+ $(srcdir)/mkinstalldirs $(root)$(prefix)/$$i; \
done
@for i in $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
- $(PROXY_TARGETS) $(SERV_MODULES) utilsmenu weekly \
- dnetsetup; do \
+ $(SERV_MODULES) ; do \
if test -f $$i; then \
echo $(INSTALL) $$i $(root)$(prefix)/$$i; \
$(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; \
cleaner: clean
rm -f $(CLIENT_TARGETS) $(SERVER_TARGETS) $(UTIL_TARGETS) \
- modules/*.[ms]o $(PROXY_TARGETS) so_locations
+ modules/*.[ms]o so_locations
distclean: cleaner
- find . -name '*~' -or -name '.#*' | xargs rm -f
+ find . -name '*~' -o -name '.#*' | xargs rm -f
rm -f Makefile sysdep.h config.cache config.log config.status *.d weekly
.c.d: