M4=m4
M4FLAGS=
LEX=flex
+MD5SUM=@MD5SUM_SIMPLE@
CWD=$(shell pwd)
INSTALL_GROUP=root
-INSTALL_FLAGS=-u root -g $(INSTALL_GROUP)
+INSTALL_FLAGS=-o root -g $(INSTALL_GROUP)
INSTALL=@INSTALL@
INSTALL_PROGRAM=@INSTALL_PROGRAM@ $(INSTALL_FLAGS)
prefix=@prefix@
exec_prefix=$(prefix)
bindir=$(exec_prefix)/bin
+mandir=$(prefix)/man
+man1dir=$(mandir)/man1
sbindir=$(exec_prefix)/sbin
etcdir=/etc
etcsubdir=$(etcdir)/userv
TARGETS= daemon client
TARGETS_DOC_PS= spec.ps overview.ps
-TARGETS_DOC= spec.html $(TARGETS_DOC_PS)
+TARGETS_DOC_RM= $(TARGETS_DOC_PS) spec.html
+TARGETS_DOC= $(TARGETS_DOC_PS) spec.html/index.html
+MAN1PAGES= userv.1
SOURCES= Makefile.in configure.in acconfig.h \
client.c common.h \
daemon.h debug.c parser.c lib.c lib.h \
language.i4 lexer.l.m4 tokens.h.m4
-ALSOSHIP= README INSTALL Changelog COPYING \
- system.default system.override \
- spec.sgml.in overview.fig overview.ps \
- buildship install-sh .cvsignore
+CONFIG_RESULTS= config.status config.log config.h config.cache \
+ Makefile pcsum.h
-GENSHIP_CLEAN= pcsum.h lexer.l lexer.c tokens.h config.h.in spec.sgml $(TARGETS_DOC)
+GENSHIP_CLEAN= lexer.l lexer.c tokens.h config.h.in spec.sgml $(TARGETS_DOC)
GENSHIP= $(GENSHIP_CLEAN) configure
-SHIPTARGETS= $(SOURCES) $(ALSOSHIP) $(GENSHIP)
-
all: $(TARGETS)
docs: $(TARGETS_DOC)
$(INSTALL_PROGRAM) -m 4755 client $(bindir)/userv
$(INSTALL) -d -m 2755 $(etcsubdir) \
$(etcsubdir)/default.d $(etcsubdir)/services.d $(etcsubdir)/override.d
- if test ! -f $(etcsubdir)/system.default; then
+ if test ! -f $(etcsubdir)/system.default; then \
$(INSTALL_DATA) system.default $(etcsubdir); fi
if test ! -f $(etcsubdir)/system.override; then \
$(INSTALL_DATA) system.override $(etcsubdir); fi
install-doc: $(TARGETS_DOC)
$(INSTALL) -d -m 2755 $(docdir) $(docdir)/spec.html
+ $(INSTALL) -d -m 2755 $(mandir) $(man1dir)
$(INSTALL_DATA) -m 644 $(TARGETS_DOC_PS) $(docdir)/.
$(INSTALL_DATA) -m 644 spec.html/*.html $(docdir)/spec.html/.
+ $(INSTALL_DATA) -m 644 $(MAN1PAGES) $(man1dir)
uninstall:
rm -f $(bindir)/userv $(sbindir)/uservd
uninstall-doc:
- cd $docdir && rm -rf $(TARGETS_DOC)
+ cd $docdir && rm -rf $(TARGETS_DOC_RM)
daemon: overlord.o process.o servexec.o parserlexer.o debug.o lib.o both.o
$(CC) $(LDFLAGS) -o $@ $^ $(LDLIBS)
$(CC) -c $(CPPFLAGS) $(CFLAGS) lexer.c -o $@
pcsum.h: common.h config.h config.status Makefile
- cat $^ | md5sum | sed -e 's/ -$$//; s/../0x&,/g; s/,$$//;' >pcsum.h.new
+ cat $^ | $(MD5SUM) \
+ | sed -e 's/ -$$//; s/../0x&,/g; s/,$$//;' \
+ >pcsum.h.new
cmp pcsum.h.new pcsum.h || mv -f pcsum.h.new pcsum.h
@rm -f pcsum.h.new
tokens.h: language.i4
-pcsum.h
- rm -f overview.eps
- rm -f spec.lout* spec.text* spec.sgml spec.sgml.new spec.ps?*
- rm -rf spec.html?*
- rm -f lout.li *.lix *.ldx config.cache
- rm -f *.o *~ core ./#*#
-
autoconf configure:
autoheader
autoconf
clean:
- rm -rf $(TARGETS) *.o
+ find -name '*.orig' -o -name '*~' -o -name '.*~' \
+ -o -name '*#' -o -name '.#*' -o -name '*.bak' \
+ | xargs -r rm
+ rm -rf $(TARGETS) *.o core version.h
+ rm -f overview.eps
+ rm -f spec.lout* spec.text* spec.ps?* spec.sgml.new
+ rm -f lout.li *.ld *.lix *.ldx
+ rm -f userv-*.tar.gz vd/*
distclean mostlyclean: clean
- rm -f config.status config.log Makefile config.h
+ rm -f $(CONFIG_RESULTS)
maintainer-clean: distclean
- rm -rf $(GENSHIP_CLEAN)
-
-dist-prep: $(SHIPTARGETS)
-
-dist: $(SHIPTARGETS)
- rm -rf shipcheck
- mkdir -p shipcheck/userv-$(VERSION)
- cp -a $^ shipcheck/userv-$(VERSION)
- cd shipcheck && \
- GZIP=-9v tar zvvcf userv-$(VERSION).tar.gz userv-$(VERSION)
- rm -rf shipcheck/userv-$(VERSION)
+ rm -rf $(GENSHIP_CLEAN) spec.html/*.html
+
+dist-prep: $(GENSHIP)
+
+pre-checkin:
+ ./configure
+ $(MAKE) dist-prep
+
+dist_tmp=dist_tmp/userv-$(VERSION)
+dist_prune=\( -name CVS -o -name 'dist_tmp*' -o -name slash-etc -o -name vd \)
+dist: dist-prep distclean
+ rm -rf dist_tmp*
+ mkdir dist_tmp $(dist_tmp)
+ find $(dist_prune) -prune -o -type d -print | \
+ sed -e 's#.*#mkdir -p $(dist_tmp)/&#' | sh
+ find $(dist_prune) -prune -o -type f -print | \
+ sed -e 's#.*#ln & $(dist_tmp)/&#' | sh
+ cd dist_tmp && tar cf ../$(dist_tmp).tar `basename $(dist_tmp)`
+ gzip -9 $(dist_tmp).tar
+ mv $(dist_tmp).tar.gz .
linecount: $(SOURCES)
wc -l $^
-%.html: %.sgml
- rm -rf $@; debiandoc2html $<
+%.html/index.html: %.sgml
+ debiandoc2html $<
%.ps: %.sgml
debiandoc2ps -1 -O $< >$@.new && mv $@.new $@