X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=debian%2Frules;h=028c067823bf86ef62ab14d6bb853663b34d3418;hb=d2522d495e1f29517ad04d4413650355859b883a;hp=57d5a6247ce3c054287aa15029e2d87616d9b78e;hpb=51398e2a334ffb31a7f7ac1fd46dcafda9ca8f61;p=debian%2Fdebian-policy.git diff --git a/debian/rules b/debian/rules index 57d5a62..028c067 100755 --- a/debian/rules +++ b/debian/rules @@ -5,72 +5,117 @@ ## Created On : Thu Oct 29 15:35:55 1998 ## Created On Node : tiamat.datasync.com ## Last Modified By : Manoj Srivastava -## Last Modified On : Wed Jun 30 23:05:51 1999 +## Last Modified On : Wed Sep 6 09:37:43 2000 ## Last Machine Used: glaurung.green-gryphon.com -## Update Count : 51 +## Update Count : 56 ## Status : Unknown, Use with caution! ## HISTORY : ## Description : ## $Id$ ############################################################################### + +# ifdef ARCH +# ha:=-a$(ARCH) +# endif + +# set the dpkg-architecture vars; but we don't use them, so we'll comment out +# export DEB_BUILD_ARCH := $(shell dpkg-architecture $(ha) -qDEB_BUILD_ARCH) +# export DEB_BUILD_GNU_CPU := $(shell dpkg-architecture $(ha) -qDEB_BUILD_GNU_CPU) +# export DEB_BUILD_GNU_SYSTEM:= $(shell dpkg-architecture $(ha) -qDEB_BUILD_GNU_SYSTEM) +# export DEB_BUILD_GNU_TYPE := $(shell dpkg-architecture $(ha) -qDEB_BUILD_GNU_TYPE) +# export DEB_HOST_ARCH := $(shell dpkg-architecture $(ha) -qDEB_HOST_ARCH) +# export DEB_HOST_GNU_CPU := $(shell dpkg-architecture $(ha) -qDEB_HOST_GNU_CPU) +# export DEB_HOST_GNU_SYSTEM := $(shell dpkg-architecture $(ha) -qDEB_HOST_GNU_SYSTEM) +# export DEB_HOST_GNU_TYPE := $(shell dpkg-architecture $(ha) -qDEB_HOST_GNU_TYPE) + + # The name of the package (for example, `emacs'). package := $(shell grep Source debian/control | sed 's/^Source: //') -arch := $(shell dpkg --print-installation-architecture) +# arch := $(shell dpkg --print-installation-architecture) date := $(shell date +"%Y-%m-%d") version := $(shell LC_ALL=C dpkg-parsechangelog | \ grep ^Version: | sed 's/^Version: *//') -ppackage:= packaging-manual - -FILES_TO_CLEAN = debian/files debian/buildinfo debian/substvars \ - version.ent policy.lout policy.lout.ld lout.li \ - upgrading-checklist.text policy.text.gz \ - packaging.lout packaging.text.gz packaging.ps \ - packaging.pdf.gz menu-policy.text.gz \ - proposal.text.gz menu-policy.pdf.gz proposal.pdf.gz -STAMPS_TO_CLEAN = stamp-policy stamp-packaging stamp-build stamp-configure -DIRS_TO_CLEAN = debian/tmp policy.html fhs debian/tmp-packaging \ - packaging.html menu-policy.html proposal.html -SGML_FILES = policy packaging menu-policy proposal # Location of the source dir SRCTOP := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi;) TMPTOP := $(SRCTOP)/debian/tmp -DOCDIR := $(TMPTOP)/usr/doc/$(package) +DOCDIR := $(TMPTOP)/usr/share/doc/$(package) LIBDIR := $(TMPTOP)/usr/share/doc-base -PTMPTOP := $(SRCTOP)/debian/tmp-packaging -PDOCDIR := $(PTMPTOP)/usr/doc/$(ppackage) -PLIBDIR := $(PTMPTOP)/usr/share/doc-base - -FHS_ARCHIVE =$(shell ls -1 fhs*.tar.gz) -FHS_FILES =fhs/fhs.dvi fhs/fhs.ps fhs/fhs.txt -FSSTND_FILES =FSSTND-FAQ fsstnd-1.2.dvi.gz fsstnd-1.2.ps.gz fsstnd-1.2.txt.gz -POLICY_FILES =policy.text.gz policy.sgml virtual-package-names-list.text \ - upgrading-checklist.text libc6-migration.text \ - version.ent proposal.sgml proposal.text.gz \ - menu-policy.sgml menu-policy.text.gz -BYHAND_FILES =policy.text.gz libc6-migration.text \ - virtual-package-names-list.text menu-policy.text.gz -PBYHAND_FILES=packaging.text.gz + +SGML_FILES = policy menu-policy mime-policy policy-process perl-policy +DESC_FILES = debian-policy debian-menu-policy debian-perl-policy \ + debian-mime-policy debian-policy-process debconf-spec + +# While we have two versions of the FHS installed in the source package, +# we need to modify this to handle it. This is the easiest way to do it. +# FHS_ARCHIVE =$(shell ls -1 fhs*.tar.gz) +# And with version 2.1, we have to build the text and dvi versions +# ourselves :-( +FHS_ARCHIVE =fhs-2.1-source.tar.gz +FHS_HTML =fhs-2.1.html.tar.gz +FHS_FILES =fhs/fhs.ps fhs/fhs.txt fhs/fhs.pdf +FHS_BYHAND =fhs-2.1.html.tar.gz fhs/fhs.txt +# FSSTND_FILES =FSSTND-FAQ fsstnd-1.2.dvi.gz fsstnd-1.2.ps.gz fsstnd-1.2.txt.gz +POLICY_FILES = $(SGML_FILES:=.sgml) $(SGML_FILES:=.txt.gz) \ + virtual-package-names-list.txt \ + upgrading-checklist.txt libc6-migration.txt version.ent \ + debconf_spec/debconf_specification.html \ + debconf_spec/debconf_specification.txt.gz +BYHAND_FILES = $(SGML_FILES:=.txt.gz) $(SGML_FILES:=.html.tar.gz) \ + debconf_spec/debconf_specification.txt.gz \ + debconf_spec/debconf_specification.html \ + libc6-migration.txt virtual-package-names-list.txt \ + policy.ps.gz policy.pdf.gz \ + $(FHS_BYHAND) + +FILES_TO_CLEAN = debian/files debian/buildinfo debian/substvars \ + debian/postinst debian/prerm \ + version.ent upgrading-checklist.txt \ + $(SGML_FILES:=.txt.gz) $(SGML_FILES:=.html.tar.gz) \ + policy.pdf.gz policy.ps.gz \ + debconf_specification.xml.tar.gz + +STAMPS_TO_CLEAN = stamp-policy stamp-build stamp-configure +DIRS_TO_CLEAN = debian/tmp fhs $(SGML_FILES:=.html) + install_file = /usr/bin/install -p -o root -g root -m 644 install_program= /usr/bin/install -p -o root -g root -m 755 make_directory = /usr/bin/install -p -d -o root -g root -m 755 +GROFF_VERSION := $(shell dpkg -s groff | sed -n -e 's/Version: //p') + all build: stamp-build stamp-build: $(checkdir) -test -f stamp-configure || $(MAKE) -f debian/rules configure + set -e; \ for file in $(SGML_FILES); do \ nsgmls -gues $$file.sgml; \ debiandoc2html $$file.sgml; \ debiandoc2text $$file.sgml; \ - if [ -f $$file.txt ]; then mv $$file.txt $$file.text; fi; \ - gzip -9f $$file.text; \ + if [ -f $$file.text ]; then mv $$file.text $$file.txt; fi; \ + gzip -9 $$file.txt; \ + tar -cf $$file.html.tar $$file.html; \ + gzip -9 $$file.html.tar; \ done - tar zfx $(FHS_ARCHIVE) - lynx -dump upgrading-checklist.html > upgrading-checklist.text + tar -zxf $(FHS_ARCHIVE) + # Need to use a patched tmac.m macro file if we're using a pre-1.16 + # groff; version 1.16 is apparently fixed + if dpkg --compare-versions $(GROFF_VERSION) lt 1.16; then \ + cp /usr/share/groff/tmac/tmac.m fhs && \ + cd fhs && patch -p1 < ../mm1.32-patch; \ + fi + # The extra '.' in the tmac path doesn't matter if + GROFF_TMAC_PATH=. cd fhs && $(MAKE) fhs.ps fhs.pdf fhs.txt + links -dump fhs-changes-2.1.html | perl -pe 's/[\r\0]//g' > \ + fhs/fhs-changes-2.1.txt + links -dump upgrading-checklist.html | perl -pe 's/[\r\0]//g' > \ + upgrading-checklist.txt + $(MAKE) -C debconf_spec all + gzip -9f debconf_spec/debconf_specification.txt touch stamp-build configure: stamp-configure @@ -83,6 +128,7 @@ stamp-configure: clean: # Undoes the effect of `make -f debian/rules build'. $(checkdir) + $(MAKE) -C debconf_spec clean rm -f $(FILES_TO_CLEAN) $(STAMPS_TO_CLEAN) rm -rf $(DIRS_TO_CLEAN) rm -f core `find . \( -name '*.orig' -o -name '*.rej' -o \ @@ -98,14 +144,16 @@ binary-arch: build # generated by this package. If there were any they would be # made here. -binary-indep: stamp-policy stamp-packaging +binary-indep: stamp-policy stamp-policy: build - @test root = "`whoami`" || (echo need root priviledges; exit 1) + @test $$(id | sed -e 's/(.*$$//' -e 's/^uid=//') || \ + (echo need root priviledges; exit 1) $(checkdir) - test -f stamp-build || $(MAKE) -f debian/rules build +# This is unnecessary; commenting out +# test -f stamp-build || $(MAKE) -f debian/rules build -rm -rf $(TMPTOP) $(make_directory) $(TMPTOP)/DEBIAN - $(make_directory) $(DOCDIR)/fsstnd +# $(make_directory) $(DOCDIR)/fsstnd $(make_directory) $(DOCDIR)/fhs $(make_directory) $(LIBDIR) # create a substvar to reference from debian/control so that @@ -114,69 +162,43 @@ stamp-policy: build # a given that the debian-policy pkg must always comply with # itself... echo "debian-policy:Version=$(version)" > debian/substvars - echo "packaging-manual:Version=$(version)" >> debian/substvars $(install_file) $(POLICY_FILES) $(DOCDIR)/ - $(install_file) $(FSSTND_FILES) $(DOCDIR)/fsstnd/ +# $(install_file) $(FSSTND_FILES) $(DOCDIR)/fsstnd/ $(install_file) $(FHS_FILES) $(DOCDIR)/fhs/ $(install_file) debian/changelog $(DOCDIR)/ - -gzip -fqr9 $(DOCDIR) + # Be more specific with file compression + -gzip -9 $(DOCDIR)/*.txt $(DOCDIR)/*.sgml \ + $(DOCDIR)/fhs/* $(DOCDIR)/changelog $(install_file) debian/copyright $(DOCDIR)/ - $(install_file) debian-policy.desc $(LIBDIR)/debian-policy - (tar cf - policy.html) | (cd $(DOCDIR); tar xf -) - (tar cf - menu-policy.html) | (cd $(DOCDIR); tar xf -) - (tar cf - proposal.html) | (cd $(DOCDIR); tar xf -) - $(install_program) debian/{postinst,prerm} debian/tmp/DEBIAN/ + GZIP=-9 tar -C debconf_spec -zcf debconf_specification.xml.tar.gz * + $(install_file) debconf_specification.xml.tar.gz $(DOCDIR)/ + set -e; \ + for file in $(DESC_FILES); do \ + $(install_file) $$file.desc $(LIBDIR)/$$file; \ + done + set -e; \ + for file in $(SGML_FILES); do \ + tar -C $(DOCDIR) -zxf $$file.html.tar.gz; \ + done + tar -C $(DOCDIR)/fhs -zxf $(FHS_HTML) + sed -e 's/#PACKAGE#/$(package)/g' debian/postinst.in > debian/postinst + sed -e 's/#PACKAGE#/$(package)/g' debian/prerm.in > debian/prerm + $(install_program) debian/postinst debian/tmp/DEBIAN/ + $(install_program) debian/prerm debian/tmp/DEBIAN/ dpkg-gencontrol -pdebian-policy -Pdebian/tmp -isp - chown -R root.root debian/tmp + chown -R root:root debian/tmp chmod -R go=rX debian/tmp dpkg --build debian/tmp .. - debiandoc2latexps -O policy.sgml | gzip -9v > ../policy.ps.gz - debiandoc2latexpdf -O policy.sgml | gzip -9v > ../policy.pdf.gz - GZIP=-9v tar zcf ../policy.html.tar.gz policy.html - dpkg-distaddfile -fdebian/files policy.ps.gz byhand - - dpkg-distaddfile -fdebian/files policy.pdf.gz byhand - - dpkg-distaddfile -fdebian/files policy.html.tar.gz byhand - - for i in $(BYHAND_FILES); do \ - $(install_file) $$i .. ; \ - dpkg-distaddfile -fdebian/files $$i byhand - ; \ - done - touch stamp-policy - -stamp-packaging: build - @test root = "`whoami`" || (echo need root priviledges; exit 1) - $(checkdir) - test -f stamp-build || $(MAKE) -f debian/rules build - -rm -rf $(PTMPTOP) - $(make_directory) $(PTMPTOP)/DEBIAN - $(make_directory) $(PDOCDIR) - $(make_directory) $(PLIBDIR) - echo "debian-policy:Version=$(version)" > debian/substvars - echo "packaging-manual:Version=$(version)" >> debian/substvars - - $(install_file) packaging.sgml $(PDOCDIR)/ - $(install_file) version.ent $(PDOCDIR)/ - $(install_file) debian/changelog $(PDOCDIR)/ - -gzip -fqr9 $(PDOCDIR) - $(install_file) packaging.text.gz $(PDOCDIR)/ - $(install_file) debian/copyright $(PDOCDIR)/ - $(install_file) packaging-manual.desc $(PLIBDIR)/packaging-manual - (tar cf - packaging.html) | (cd $(PDOCDIR); tar xf -) - $(install_program) debian/{postinst,prerm} debian/tmp-packaging/DEBIAN/ - dpkg-gencontrol -ppackaging-manual -Pdebian/tmp-packaging -isp - chown -R root.root debian/tmp-packaging - chmod -R go=rX debian/tmp-packaging - dpkg --build debian/tmp-packaging .. - debiandoc2latexps -O packaging.sgml | gzip -9f > ../packaging.ps.gz - debiandoc2latexpdf -O packaging.sgml | gzip -9f > ../packaging.pdf.gz - GZIP=-9v tar zcf ../packaging.html.tar.gz packaging.html - dpkg-distaddfile -fdebian/files packaging.ps.gz byhand - - dpkg-distaddfile -fdebian/files packaging.pdf.gz byhand - - dpkg-distaddfile -fdebian/files packaging.html.tar.gz byhand - - for i in $(PBYHAND_FILES); do \ - $(install_file) $$i .. ; \ - dpkg-distaddfile -fdebian/files $$i byhand - ; \ + debiandoc2latexps policy.sgml + gzip -9f policy.ps + debiandoc2latexpdf policy.sgml + gzip -9f policy.pdf + set -e; \ + for i in $(BYHAND_FILES); do \ + $(install_file) $$i .. ; \ + dpkg-distaddfile -fdebian/files `basename $$i` byhand - ; \ done - touch stamp- + touch stamp-policy define checkdir @@ -186,7 +208,7 @@ endef source diff: @echo >&2 'source and diff are obsolete - use dpkg-source -b'; false -.PHONY: binary binary-arch binary-indep clean checkroot +.PHONY: configure build binary binary-arch binary-indep clean checkroot #Local variables: #mode: makefile