## LDADD is included in the program-specific LDADD since we want to add
## to this list of libraries, not replace it.
##
-LDADD = sbr/libmh.a
+LDADD = sbr/libmh.a sbr/libdtimep.a
##
## These are used to create the default mhn.defaults config file
auxexecdir = @libdir@
##
+## nmh _does_ have a test suite!
+##
+TESTS_ENVIRONMENT = MH_OBJ_DIR=@abs_builddir@ \
+ MH_TEST_DIR=@abs_builddir@/test/testdir \
+ auxexecdir=$(auxexecdir) bindir=$(bindir) \
+ mandir=$(mandir) sysconfdir=$(sysconfdir)
+##
+## Important note: the "cleanup" test should always be last
+##
+TESTS = test/bad-input/test-header test/comp/test-comp-format \
+ test/folder/test-create \
+ test/folder/test-total test/format/test-localmbox \
+ test/format/test-myname test/format/test-myhost \
+ test/format/test-mymbox \
+ test/inc/test-deb359167 test/inc/test-eom-align \
+ test/manpages/test-manpages test/mhbuild/test-forw \
+ test/mhpath/test-mhpath \
+ test/mhshow/test-cte-binary test/mhshow/test-qp \
+ test/mhshow/test-subpart test/new/test-basic \
+ test/pick/test-pick test/pick/test-stderr \
+ test/repl/test-if-str test/scan/test-scan \
+ test/sequences/test-flist test/sequences/test-mark \
+ test/whatnow/test-attach-detach test/whatnow/test-cd \
+ test/whatnow/test-ls \
+ test/cleanup ## The "cleanup" test should always be last.
+
+check_SCRIPTS = test/common.sh
+check_PROGRAMS = test/getfullname
+
+##
## Stuff that should be cleaned via "make clean"
##
CLEANFILES = config/version.c sbr/sigmsg.h etc/mts.conf etc/sendfiles \
etc/mhn.defaults man/man.sed $(man_MANS)
+clean-local:
+ @rm -rf RPM a.out.DSYM uip/a.out.DSYM
+ @rm -rf test/testdir
+
+##
+## Stuff that should be cleaned via "make maintainer-clean"
+##
+MAINTAINERCLEANFILES = cscope.files cscope.out
+
+##
+## And our own superclean, to get everything left by maintainer-clean.
+##
+SUPERCLEANFILES = ChangeLog Makefile.in aclocal.m4 compile config.guess \
+ config.h.in config.h.in~ config.sub configure depcomp \
+ install-sh missing ylwrap nmh-*.tar.gz
+superclean: maintainer-clean
+ @rm -f $(SUPERCLEANFILES)
+.PHONY: superclean
##
## Files that need to be built before everything else
uip/spost uip/viamail uip/mhtest
##
-## Internal libraries that we don't create as part of the build process
+## Internal libraries that we create as part of the build process
## but do not install
##
-noinst_LIBRARIES = sbr/libmh.a mts/libmts.a
+noinst_LIBRARIES = sbr/libmh.a sbr/libdtimep.a mts/libmts.a
##
## These are all of our header files. Right now we don't install any of
##
sysconf_DATA = etc/mhn.defaults etc/mts.conf
+##
+## Documentation that gets installed in docdir
+##
dist_doc_DATA = COPYRIGHT VERSION docs/COMPLETION-BASH docs/COMPLETION-TCSH \
docs/COMPLETION-ZSH docs/DIFFERENCES docs/FAQ \
docs/MAIL.FILTERING docs/MAILING-LISTS docs/README-ATTACHMENTS \
##
## Our man pages
##
-
man_MANS = man/ali.1 man/anno.1 man/ap.8 man/burst.1 man/comp.1 \
man/conflict.8 man/dist.1 man/dp.8 man/flist.1 man/flists.1 \
man/fmtdump.8 man/fnext.1 man/folder.1 man/folders.1 \
## Files we need to include in the distribution which aren't found by
## Automake using the automatic rules
##
-
EXTRA_DIST = config/version.sh sbr/sigmsg.awk etc/mts.conf.in etc/sendfiles.in \
etc/mhn.defaults.sh $(MHNSEARCHPROG) nmh.spec DATE \
docs/ChangeLog_MH-3_to_MH-6.6 \
man/rcvpack.man man/rcvstore.man man/rcvtty.man man/refile.man \
man/repl.man man/rmf.man man/rmm.man man/scan.man man/send.man \
man/sendfiles.man man/show.man man/slocal.man man/sortm.man \
- man/unseen.man man/whatnow.man man/whom.man
+ man/unseen.man man/whatnow.man man/whom.man test/README $(TESTS) \
+ test/inc/deb359167.mbox test/inc/fromline.txt \
+ test/inc/msgheader.txt test/inc/filler.txt test/inc/md5sums
##
## These are all of the definitions for each of the programs listed above.
## overrides that are used to select different library options from the
## default.
##
-## Note that a few programs link in extra files (specifically, popsbr.c)
-## if POP3 support is compiled in. An Automake conditional is used for
-## this purpose.
-##
-
uip_ali_SOURCES = uip/ali.c uip/aliasbr.c
uip_anno_SOURCES = uip/anno.c uip/annosbr.c
uip_comp_SOURCES = uip/comp.c uip/whatnowproc.c uip/whatnowsbr.c uip/sendsbr.c \
uip/annosbr.c uip/distsbr.c
+uip_comp_LDADD = $(LDADD) $(ICONVLIB)
uip_dist_SOURCES = uip/dist.c uip/whatnowproc.c uip/whatnowsbr.c uip/sendsbr.c \
uip/annosbr.c uip/distsbr.c
uip_folder_SOURCES = uip/folder.c
uip_forw_SOURCES = uip/forw.c uip/whatnowproc.c uip/whatnowsbr.c uip/sendsbr.c \
- uip/annosbr.c uip/distsbr.c
+ uip/annosbr.c uip/distsbr.c uip/forwsbr.c
uip_forw_LDADD = $(LDADD) $(ICONVLIB)
-uip_inc_SOURCES = uip/inc.c uip/scansbr.c uip/dropsbr.c uip/termsbr.c
-if POP_SUPPORT
-uip_inc_SOURCES += uip/popsbr.c
-endif
+uip_inc_SOURCES = uip/inc.c uip/scansbr.c uip/dropsbr.c uip/termsbr.c \
+ uip/popsbr.c
uip_inc_LDADD = $(LDADD) $(TERMLIB) $(ICONVLIB) $(SASLLIB)
uip_install_mh_SOURCES = uip/install-mh.c
uip/mhmisc.c uip/mhfree.c uip/termsbr.c uip/md5.c
uip_mhstore_LDADD = $(LDADD) $(TERMLIB)
-uip_msgchk_SOURCES = uip/msgchk.c
-if POP_SUPPORT
-uip_msgchk_SOURCES += uip/popsbr.c
-endif
+uip_msgchk_SOURCES = uip/msgchk.c uip/popsbr.c
uip_msgchk_LDADD = $(LDADD) $(SASLLIB)
uip_msh_SOURCES = uip/msh.c uip/mshcmds.c uip/vmhsbr.c uip/picksbr.c \
uip_viamail_SOURCES = uip/viamail.c uip/mhmisc.c uip/mhoutsbr.c uip/sendsbr.c \
uip/annosbr.c uip/distsbr.c
+test_getfullname_SOURCES = test/getfullname.c
+test_getfullname_LDADD =
+
##
## Our rebuild rules for files that aren't built via the normal mechanisms
##
config/version.c: Makefile
sh $(srcdir)/config/version.sh $(VERSION) > $@
-sbr/sigmsg.h: Makefile $(srcdir)/sbr/sigmsg.awk $(SIGNAL_H)
+sbr/sigmsg.h: $(srcdir)/sbr/sigmsg.awk $(SIGNAL_H)
$(AWK) -f $(srcdir)/sbr/sigmsg.awk $(SIGNAL_H) > $@
etc/mts.conf: $(srcdir)/etc/mts.conf.in Makefile
## between different programs.
##
install-exec-hook:
- rm -f $(DESTDIR)/$(bindir)/flists$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/folders$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/fnext$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/fprev$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/unseen$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/prev$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/next$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/flist$(EXEEXT) $(DESTDIR)/$(bindir)/flists$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/folder$(EXEEXT) $(DESTDIR)/$(bindir)/folders$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/new$(EXEEXT) $(DESTDIR)/$(bindir)/fnext$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/new$(EXEEXT) $(DESTDIR)/$(bindir)/fprev$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/new$(EXEEXT) $(DESTDIR)/$(bindir)/unseen$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/show$(EXEEXT) $(DESTDIR)/$(bindir)/prev$(EXEEXT)
- ln $(DESTDIR)/$(bindir)/show$(EXEEXT) $(DESTDIR)/$(bindir)/next$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/flists$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/folders$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/fnext$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/fprev$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/unseen$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/prev$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/next$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/flist$(EXEEXT) $(DESTDIR)$(bindir)/flists$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/folder$(EXEEXT) $(DESTDIR)$(bindir)/folders$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/new$(EXEEXT) $(DESTDIR)$(bindir)/fnext$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/new$(EXEEXT) $(DESTDIR)$(bindir)/fprev$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/new$(EXEEXT) $(DESTDIR)$(bindir)/unseen$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/show$(EXEEXT) $(DESTDIR)$(bindir)/prev$(EXEEXT)
+ ln $(DESTDIR)$(bindir)/show$(EXEEXT) $(DESTDIR)$(bindir)/next$(EXEEXT)
+ if test x$(SETGID_MAIL) != x; then \
+ chgrp $(MAIL_SPOOL_GRP) $(DESTDIR)$(bindir)/inc$(EXEEXT); \
+ chmod 2755 $(DESTDIR)$(bindir)/inc$(EXEEXT); \
+ fi
install-data-hook:
- ln $(DESTDIR)/$(man5dir)/mh-profile.5 $(DESTDIR)/$(man5dir)/mh_profile.5
+ rm -f $(DESTDIR)$(man5dir)/mh_profile.5
+ ln $(DESTDIR)$(man5dir)/mh-profile.5 $(DESTDIR)$(man5dir)/mh_profile.5
##
## Make sure we remove those links at uninstall time
##
uninstall-hook:
- rm -f $(DESTDIR)/$(bindir)/flists$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/folders$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/fnext$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/fprev$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/unseen$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/prev$(EXEEXT)
- rm -f $(DESTDIR)/$(bindir)/next$(EXEEXT)
- rm -f $(DESTDIR)/$(man5dir)/mh_profile.5
+ rm -f $(DESTDIR)$(bindir)/flists$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/folders$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/fnext$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/fprev$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/unseen$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/prev$(EXEEXT)
+ rm -f $(DESTDIR)$(bindir)/next$(EXEEXT)
+ rm -f $(DESTDIR)$(man5dir)/mh_profile.5
##
## Our rules to build our internal libraries (libmh.a, libmts.a)
sbr/context_replace.c sbr/context_save.c \
sbr/copy.c sbr/copyip.c sbr/cpydata.c \
sbr/cpydgst.c sbr/crawl_folders.c sbr/discard.c \
- sbr/done.c sbr/dtime.c sbr/dtimep.l \
+ sbr/done.c sbr/dtime.c \
sbr/error.c sbr/ext_hook.c sbr/fdcompare.c \
sbr/folder_addmsg.c sbr/folder_delmsgs.c \
sbr/folder_free.c sbr/folder_pack.c \
-DMAILSPOOL='"$(mailspool)"' \
-DSENDMAILPATH='"$(sendmailpath)"' -DNMHBINDIR='"$(bindir)"' \
-DNMHLIBDIR='"$(libdir)"' \
- -DDEFAULT_EDITOR='"$(default_editor)"' \
- -DDEFAULT_PAGER='"$(default_pager)"'
+ -DDEFAULT_EDITOR='"$(editorpath)"' \
+ -DDEFAULT_PAGER='"$(pagerpath)"'
+
+sbr_libdtimep_a_SOURCES = sbr/dtimep.l
+sbr_libdtimep_a_CFLAGS = $(sbr_libmh_a_CPPFLAGS) $(DISABLE_UNUSED_MACROS_WARNING)
mts_libmts_a_SOURCES = mts/smtp/hosts.c mts/smtp/smtp.c
## Our rules for generating man pages (both the rule for man.sed and
## the implicit rules for man page generation).
##
-
manext1 = 1
manext5 = 5
manext8 = 8
$(man_MANS): man/man.sed
man/man.sed: Makefile
- echo 's,%nmhwarning%,THIS FILE HAS BEEN AUTOMATICALLY GENERATED. DO NOT EDIT.,g' > $@
- echo 's,%nmhversion%,nmh-$(VERSION),g' >> $@
- echo 's,%nmhdate%,$(DATE),g' >> $@
- echo 's,%bindir%,$(bindir),g' >> $@
- echo 's,%etcdir%,$(sysconfdir),g' >> $@
- echo 's,%libdir%,$(libdir),g' >> $@
- echo 's,%mandir%,$(mandir),g' >> $@
- echo 's,%mailspool%,$(mailspool),g' >> $@
- echo 's,%sendmailpath%,$(sendmailpath),g' >> $@
- echo 's,%default_editor%,$(default_editor),g' >> $@
- echo 's,%default_pager%,$(default_pager),g' >> $@
- echo 's,%manext1%,$(manext1),g' >> $@
- echo 's,%manext5%,$(manext5),g' >> $@
- echo 's,%manext8%,$(manext8),g' >> $@
-if POP_SUPPORT
- echo '/^%nmhbeginpop%/d;/^%nmhendpop%/d' >> $@
-else
- echo '/^%nmhbeginpop%/,/^%nmhendpop%/d' >> $@
-endif
- echo '/%components%/r $(top_srcdir)/etc/components' >> $@
- echo ' s,%components%,,g' >> $@
- echo '/%distcomps%/r $(top_srcdir)/etc/distcomps' >> $@
- echo ' s,%distcomps%,,g' >> $@
- echo '/%forwcomps%/r $(top_srcdir)/etc/forwcomps' >> $@
- echo ' s,%forwcomps%,,g' >> $@
- echo '/%mhl_forward%/r $(top_srcdir)/etc/mhl.forward' >> $@
- echo ' s,%mhl_forward%,,g' >> $@
- echo '/%mhl_format%/r $(top_srcdir)/etc/mhl.format' >> $@
- echo ' s,%mhl_format%,,g' >> $@
- echo '/%mhl_reply%/r $(top_srcdir)/etc/mhl.reply' >> $@
- echo ' s,%mhl_reply%,,g' >> $@
+ @echo 's,%nmhwarning%,THIS FILE HAS BEEN AUTOMATICALLY GENERATED. DO NOT EDIT.,g' > $@
+ @echo 's,%nmhversion%,nmh-$(VERSION),g' >> $@
+ @echo 's,%nmhdate%,$(DATE),g' >> $@
+ @echo 's,%bindir%,$(bindir),g' >> $@
+ @echo 's,%etcdir%,$(sysconfdir),g' >> $@
+ @echo 's,%libdir%,$(libdir),g' >> $@
+ @echo 's,%mandir%,$(mandir),g' >> $@
+ @echo 's,%mailspool%,$(mailspool),g' >> $@
+ @echo 's,%sendmailpath%,$(sendmailpath),g' >> $@
+ @echo 's,%default_editor%,$(editorpath),g' >> $@
+ @echo 's,%default_pager%,$(pagerpath),g' >> $@
+ @echo 's,%manext1%,$(manext1),g' >> $@
+ @echo 's,%manext5%,$(manext5),g' >> $@
+ @echo 's,%manext8%,$(manext8),g' >> $@
+ @echo '/%components%/r $(top_srcdir)/etc/components' >> $@
+ @echo ' s,%components%,,g' >> $@
+ @echo '/%distcomps%/r $(top_srcdir)/etc/distcomps' >> $@
+ @echo ' s,%distcomps%,,g' >> $@
+ @echo '/%forwcomps%/r $(top_srcdir)/etc/forwcomps' >> $@
+ @echo ' s,%forwcomps%,,g' >> $@
+ @echo '/%mhl_forward%/r $(top_srcdir)/etc/mhl.forward' >> $@
+ @echo ' s,%mhl_forward%,,g' >> $@
+ @echo '/%mhl_format%/r $(top_srcdir)/etc/mhl.format' >> $@
+ @echo ' s,%mhl_format%,,g' >> $@
+ @echo '/%mhl_reply%/r $(top_srcdir)/etc/mhl.reply' >> $@
+ @echo ' s,%mhl_reply%,,g' >> $@
.man.$(manext1):
- $(SED) -f man/man.sed $< > $@
+ @$(SED) -f man/man.sed $< > $@
.man.$(manext5):
- $(SED) -f man/man.sed $< > $@
+ @$(SED) -f man/man.sed $< > $@
.man.$(manext8):
- $(SED) -f man/man.sed $< > $@
+ @$(SED) -f man/man.sed $< > $@
+
+## Don't include commit hashes in ChangeLog.
+ChangeLog:
+ @[ -d .git ] && git --no-pager log --abbrev-commit | \
+ egrep -v '^commit [0-9a-f]+$$' > $@ || true
+## Make ChangeLog phony so it will always get regenerated. But don't
+## fail if we don't have a git repository in order to allow
+## regeneration of distribution archive or RPM.
+.PHONY: ChangeLog
##
## Our RPM build target
##
-
-rpm: $(DIST_ARCHIVES)
+rpm: dist
@test -d $(rpmdir)/SOURCES || $(MKDIR_P) $(rpmdir)/SOURCES
@test -d $(rpmdir)/SPECS || $(MKDIR_P) $(rpmdir)/SPECS
@mv -f $(DIST_ARCHIVES) $(rpmdir)/SOURCES
@cp -p nmh.spec $(rpmdir)/SPECS
@rpmbuild --define '_topdir $(rpmdir)' \
--define '_tmppath %{_topdir}/TMP' \
+ --define "_sysconfdir $(DESTDIR)$(sysconfdir)" \
-ba $(rpmdir)/SPECS/nmh.spec
+.PHONY: rpm
+
+##
+## A target to build information needed by cscope
+##
+cscope:
+ echo "-I $(srcdir)/h -I $(srcdir)/sbr -I $(srcdir)/uip -I $(srcdir)/mts/smtp" > cscope.files
+ find $(srcdir) \( -name \*.c -o -name \*.l \) -print | grep -v dtimep.c >> cscope.files
+.PHONY: cscope
+
+
+##
+## Use GNU gcov to find the coverage of the test suite.
+## gcov and gcov-clean are not integrated into the other automake
+## targets because gcov will be used so infrequently, if at all.
+##
+gcov:
+ @echo rebuilding with AM_CLFAGS=--coverage . . .
+ @(make clean && make AM_CFLAGS=--coverage) > /dev/null && make check
+ @for i in `find . -name '*.gcda'`; do \
+ gcov -o `echo $$i | $(SED) 's%\\(.*\\)/%\\1 %'`; \
+ done
+ @for i in `find . -name '*.gcno'`; do \
+ if ! test -f `echo $$i | sed 's%\.gcno%.gcda%'`; then \
+ echo untested: $$i; \
+ fi; \
+ done
+gcov-clean:
+ @find . -name '*.gcno' -o -name '*.gcda' -o -name '*.gcov' | xargs rm
+.PHONY: gcov gcov-clean
+
+
+##
+## Rules to upload the distribution to savannah
+##
+upload: dist
+ @if test -z "$(SAVANNAH_USERNAME)"; then \
+ echo "You need to set SAVANNAH_USERNAME to the your username on savannah.gnu.org." ;\
+ echo "You can set it either in your environment or on the make command line."; \
+ false; \
+ fi
+ @echo "Did you run 'make distcheck' already?"
+ @if test -z "$(SKIP_GPG_SIG)"; then \
+ echo "Creating GPG signature (set SKIP_GPG_SIG to bypass this step)"; \
+ gpg --output $(DIST_ARCHIVES).sig --detatch-sig $(DIST_ARCHIVES); \
+ fi
+ @echo "Setting permissions for savannah.gnu.org"
+ chmod 664 $(DIST_ARCHIVES)
+ if test -f $(DIST_ARCHIVES).sig; then \
+ chmod 664 $(DIST_ARCHIVES).sig; \
+ fi
+ @echo "Uploading to savannah"
+ scp -p $(DIST_ARCHIVES)* $(SAVANNAH_USERNAME)@savannah.gnu.org:/releases/nmh
+.PHONY: upload