X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=userv.git;a=blobdiff_plain;f=Makefile.in;h=d36c6c6eae8f77a0d8bf1267a8eb245cc121ccad;hp=1d21aa63c614502434ec17cc3ece25bcd3d6176c;hb=b691594e2f401ebf70d79824c0eb9e99c36d6dca;hpb=e719d95f34240a6fc3ed0c028ffa89323e8d8fb3 diff --git a/Makefile.in b/Makefile.in index 1d21aa6..d36c6c6 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,6 +1,6 @@ # userv - Makefile.in # -# Copyright (C)1996-1997 Ian Jackson +# Copyright (C)1996-1997,1999 Ian Jackson # # This is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by @@ -16,71 +16,129 @@ # along with userv; if not, write to the Free Software # Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +VERSION=@VERSION@ +VEREXT=std + CC=@CC@ -CFLAGS=@CFLAGS@ $(XCFLAGS) +CFLAGS=@CFLAGS@ $(XCFLAGS) -DVERSION='"$(VERSION)"' -DVEREXT='"$(VEREXT)"' $(WERROR) $(XCFLAGS) OPTIMISE=@OPTIMISE@ CPPFLAGS=@DEBUGDEFS@ $(XCPPFLAGS) -LDLIBS=@DEBUGLIBS@ $(XLDLIBS) +LDLIBS=@DEBUGLIBS@ @LIBS@ $(XLDLIBS) M4=m4 M4FLAGS= LEX=flex +MD5SUM=@MD5SUM_SIMPLE@ CWD=$(shell pwd) +INSTALL_GROUP=0 # root or wheel +INSTALL_FLAGS=-o root -g $(INSTALL_GROUP) + INSTALL=@INSTALL@ -INSTALL_PROGRAM=@INSTALL_PROGRAM@ -INSTALL_DATA=@INSTALL_DATA@ +INSTALL_PROGRAM=@INSTALL_PROGRAM@ $(INSTALL_FLAGS) +INSTALL_DATA=@INSTALL_DATA@ $(INSTALL_FLAGS) prefix=@prefix@ exec_prefix=$(prefix) bindir=$(exec_prefix)/bin +mandir=$(prefix)/man +man1dir=$(mandir)/man1 +man8dir=$(mandir)/man8 sbindir=$(exec_prefix)/sbin etcdir=/etc etcsubdir=$(etcdir)/userv +docdir=$(prefix)/userv + +TARGETS= daemon client +TARGETS_DOC_PS= spec.ps overview.ps +TARGETS_DOC_RM= $(TARGETS_DOC_PS) spec.html +TARGETS_DOC= $(TARGETS_DOC_PS) spec.html/index.html +MAN1PAGES= userv.1 +MAN8PAGES= uservd.8 SOURCES= Makefile.in configure.in acconfig.h \ client.c common.h \ - daemon.c daemon.h ddebug.c parser.c lib.c lib.h \ + overlord.c process.c servexec.c \ + daemon.h debug.c parser.c lib.c lib.h \ language.i4 lexer.l.m4 tokens.h.m4 -ALSOSHIP= system.default system.override \ - spec.sgml overview.fig overview.ps \ - COPYING buildship install-sh .cvsignore -GENSHIP= lexer.l lexer.c tokens.h configure config.h.in \ - spec.html spec.ps overview.ps -SHIPTARGETS= $(SOURCES) $(ALSOSHIP) $(GENSHIP) +CONFIG_RESULTS= config.status config.log config.h config.cache \ + Makefile pcsum.h + +GENSHIP_CLEAN= lexer.l lexer.c tokens.h config.h.in spec.sgml $(TARGETS_DOC) +GENSHIP= $(GENSHIP_CLEAN) configure + +all: $(TARGETS) -all: daemon client +docs: $(TARGETS_DOC) install: all - $(INSTALL_PROGRAM) -s -o root -g root -m 755 daemon $(sbindir)/uservd - $(INSTALL_PROGRAM) -s -o root -g root -m 4755 client $(bindir)/userv - $(INSTALL) -d -o root -g root -m 2755 $(etcsubdir) - if ! test -f $(etcsubdir)/system.default; then \ - $(INSTALL_DATA) -o root -g root system.default $(etcsubdir); fi - if ! test -f $(etcsubdir)/system.override; then \ - $(INSTALL_DATA) -o root -g root system.override $(etcsubdir); fi + $(INSTALL_PROGRAM) -m 755 daemon $(sbindir)/uservd + $(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 \ + $(INSTALL_DATA) system.default $(etcsubdir); fi + if test ! -f $(etcsubdir)/system.override; then \ + $(INSTALL_DATA) system.override $(etcsubdir); fi + +install-strip: + $(MAKE) INSTALL_PROGRAM='$(INSTALL_PROGRAM) -s' install + +install-doc: $(TARGETS_DOC) + $(INSTALL) -d -m 2755 $(docdir) $(docdir)/spec.html + $(INSTALL) -d -m 2755 $(mandir) $(man1dir) $(man8dir) + $(INSTALL_DATA) -m 644 $(TARGETS_DOC_PS) $(docdir)/. + $(INSTALL_DATA) -m 644 spec.html/*.html $(docdir)/spec.html/. + $(INSTALL_DATA) -m 644 $(MAN1PAGES) $(man1dir) + $(INSTALL_DATA) -m 644 $(MAN8PAGES) $(man8dir) + +uninstall: + rm -f $(bindir)/userv $(sbindir)/uservd + +uninstall-doc: + cd $docdir && rm -rf $(TARGETS_DOC_RM) + +check: + @echo There is no validation suite for this package. -daemon: daemon.o parserlexer.o ddebug.o lib.o +daemon: overlord.o process.o servexec.o parserlexer.o debug.o lib.o both.o + $(CC) $(LDFLAGS) -o $@ $^ $(LDLIBS) + +client: client.o both.o + $(CC) $(LDFLAGS) -o $@ $^ $(LDLIBS) lexer.l: language.i4 -client.o: config.h common.h pcsum.h version.h +spec.sgml: spec.sgml.in Makefile + sed -e '/<\/version>/ s/>/&$(VERSION)/' \ + spec.sgml.in >$@.new && mv -f $@.new $@ + +client.o: config.h common.h pcsum.h both.h version.h + +process.o: config.h common.h pcsum.h both.h daemon.h lib.h tokens.h -daemon.o: config.h common.h pcsum.h daemon.h lib.h tokens.h +overlord.o: config.h common.h pcsum.h daemon.h -lib.o: config.h lib.h +servexec.o: config.h common.h pcsum.h daemon.h lib.h version.h -ddebug.o: config.h common.h pcsum.h daemon.h lib.h tokens.h +lib.o: config.h common.h lib.h + +debug.o: config.h common.h pcsum.h daemon.h lib.h tokens.h parserlexer.o: lexer.c parser.c config.h common.h pcsum.h daemon.h lib.h tokens.h # lexer.c #include's parser.c at the end. Blame flex. $(CC) -c $(CPPFLAGS) $(CFLAGS) lexer.c -o $@ -pcsum.h: common.h version.h config.h config.status Makefile - cat $^ | md5sum | sed -e 's/../0x&,/g; s/,$$//;' >pcsum.h.new +pcsum.h: common.h config.h config.status Makefile + 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 +version.h: Makefile + echo '#define VERSION "$(VERSION)"' >$@.new && mv -f $@.new $@ + tokens.h: language.i4 autoconf configure: @@ -88,36 +146,48 @@ autoconf configure: autoconf clean: - rm -f daemon client lexer.l lexer.c tokens.h pcsum.h - rm -f overview.eps overview.ps - rm -f spec.lout* spec.ps spec.text* lout.li - rm -rf spec.html* - rm -f *.o *~ core ./#*# - -distclean: clean - rm -f config.status config.log Makefile config.h - -realclean: distclean - rm -f configure config.h.in - -shipprep: $(SHIPTARGETS) - -ship: $(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) + 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 spec.tex + rm -f lout.li *.ld *.lix *.ldx + rm -f userv-*.tar.gz vd/* + +distclean mostlyclean: clean + rm -f $(CONFIG_RESULTS) + +maintainer-clean: distclean + 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 -k -O $< >$@.new && mv $@.new $@ + debiandoc2ps -1 -O $< >$@.new && mv $@.new $@ %.ps: %.fig fig2dev -L ps -c -l dummy -P -z A4 $< >$@.new && mv $@.new $@