X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=debian%2Frules;h=1e31ad42664f77226b76326e76606098a9eabab2;hb=6e1b2d9c86e05355da2081276decbf3ae3fce4c2;hp=ce6cb50c027e749952de1ea0ee1f457d025d7dc7;hpb=efac5ae0f24ae1331d9afe0b9bbba8e2484a4189;p=debian%2Fdebian-policy.git diff --git a/debian/rules b/debian/rules index ce6cb50..1e31ad4 100755 --- a/debian/rules +++ b/debian/rules @@ -5,9 +5,9 @@ ## Created On : Thu Oct 29 15:35:55 1998 ## Created On Node : tiamat.datasync.com ## Last Modified By : Manoj Srivastava -## Last Modified On : Wed Sep 6 09:37:43 2000 -## Last Machine Used: glaurung.green-gryphon.com -## Update Count : 56 +## Last Modified On : Tue Oct 26 15:20:25 2004 +## Last Machine Used: glaurung.internal.golden-gryphon.com +## Update Count : 62 ## Status : Unknown, Use with caution! ## HISTORY : ## Description : @@ -18,116 +18,90 @@ ifdef ARCH ha:=-a$(ARCH) endif -# set the dpkg-architecture vars -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) - +# 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) +arch := $(shell dpkg --print-installation-architecture) -# The name of the package (for example, `emacs'). +# Basic information package := $(shell grep Source debian/control | sed 's/^Source: //') -arch := $(shell dpkg --print-installation-architecture) date := $(shell date +"%Y-%m-%d") -version := $(shell LC_ALL=C dpkg-parsechangelog | \ - grep ^Version: | sed 's/^Version: *//') - -FILES_TO_CLEAN = debian/files debian/buildinfo debian/substvars \ - debian/postinst debian/prerm \ - version.ent policy.lout policy.lout.ld lout.li \ - upgrading-checklist.text policy.text.gz \ - menu-policy.text.gz \ - policy-process.text.gz policy-process.pdf.gz \ - proposal.text.gz menu-policy.pdf.gz proposal.pdf.gz \ - mime-policy.text.gz mime-policy.pdf.gz \ - debconf_spec/debconf_specification.html \ - debconf_spec/debconf_specification.txt.gz \ - -STAMPS_TO_CLEAN = stamp-policy stamp-build stamp-configure -DIRS_TO_CLEAN = debian/tmp policy.html fhs \ - menu-policy.html mime-policy.html \ - proposal.html policy-process.html -SGML_FILES = policy menu-policy mime-policy proposal \ - policy-process +version := $(shell awk -F '[()]' '/^$(package)/{ print $$2; exit }' debian/changelog) # Location of the source dir -SRCTOP := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi;) +SRCTOP := $(CURDIR) TMPTOP := $(SRCTOP)/debian/tmp DOCDIR := $(TMPTOP)/usr/share/doc/$(package) LIBDIR := $(TMPTOP)/usr/share/doc-base +sanitycheck := debian/rules policy.sgml + +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 fhs # 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_FILES = fhs/fhs.ps fhs/fhs.txt fhs/fhs.pdf -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 \ - mime-policy.sgml mime-policy.text.gz \ - policy-process.text.gz policy-process.sgml \ - debconf_spec/debconf_specification.html \ - debconf_spec/debconf_specification.txt.gz -BYHAND_FILES =policy.text.gz libc6-migration.text \ - virtual-package-names-list.text menu-policy.text.gz \ - mime-policy.text.gz policy.ps.gz policy.pdf.gz \ - policy.html.tar.gz \ - debconf_spec/debconf_specification.txt.gz - - -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') +# FHS_ARCHIVE := $(wildcard fhs*.tar.gz) +FHS_ARCHIVE := fhs-2.3-source.tar.gz +FHS_HTML := fhs-2.3.html +FHS_FILES := fhs-2.3.ps.gz fhs-2.3.txt.gz fhs-2.3.pdf.gz +FHS_NEW_ARCHIVE := +FHS_NEW_HTML := +FHS_NEW_FILES := + +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 \ + policy.ps.gz policy.pdf.gz + +# policy.{pdf,ps,tpt,txt} are generated files +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 \ + policy.pdf policy.ps policy.txt policy. + +STAMPS_TO_CLEAN := stamp-policy stamp-build +DIRS_TO_CLEAN := debian/tmp fhs $(SGML_FILES:=.html) + + +install_file := install -p -o root -g root -m 644 +install_program := install -p -o root -g root -m 755 +make_directory := install -p -d -o root -g root -m 755 all build: stamp-build -stamp-build: - $(checkdir) - -test -f stamp-configure || $(MAKE) -f debian/rules configure - 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; \ - done - tar zfx $(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 - lynx -dump fhs-changes-2.1.html > fhs/fhs-changes-2.1.text - lynx -dump upgrading-checklist.html > upgrading-checklist.text - $(MAKE) -c debconf_spec all - gzip -9f debconf_spec/debconf_specification.txt +stamp-build: version.ent $(sanitycheck) + $(MAKE) $(SGML_FILES:=.sgml.validate) \ + $(SGML_FILES:=.html.tar.gz) \ + $(SGML_FILES:=.txt.gz) \ + policy.ps.gz policy.pdf.gz + links -dump upgrading-checklist.html | perl -pe 's/[\r\0]//g' > \ + upgrading-checklist.txt + $(MAKE) -C debconf_spec all touch stamp-build -configure: stamp-configure -stamp-configure: - rm -f version.ent - echo "" >> version.ent - echo "" >> version.ent - touch stamp-configure +configure: version.ent +version.ent: debian/changelog + rm -f $@ + echo "" >> $@ + echo "" >> $@ -clean: +clean: $(sanitycheck) # 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 \ @@ -137,21 +111,19 @@ clean: binary: binary-indep binary-arch -binary-arch: build - $(checkdir) +binary-arch: build $(sanitycheck) # There are no architecture-dependent files to be uploaded # generated by this package. If there were any they would be # made here. binary-indep: stamp-policy -stamp-policy: build +stamp-policy: build $(sanitycheck) @test $$(id | sed -e 's/(.*$$//' -e 's/^uid=//') || \ (echo need root priviledges; exit 1) - $(checkdir) - test -f stamp-build || $(MAKE) -f debian/rules build - -rm -rf $(TMPTOP) +# 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)/fhs $(make_directory) $(LIBDIR) # create a substvar to reference from debian/control so that @@ -161,45 +133,41 @@ stamp-policy: build # itself... echo "debian-policy:Version=$(version)" > debian/substvars $(install_file) $(POLICY_FILES) $(DOCDIR)/ - $(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 -f9 $(DOCDIR)/*.txt $(DOCDIR)/*.sgml \ + $(DOCDIR)/changelog +# These are allready compressed + #$(install_file) $(FHS_NEW_FILES) $(DOCDIR)/fhs/ + $(install_file) $(FHS_FILES) $(DOCDIR)/fhs/ $(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 - mime-policy.html) | (cd $(DOCDIR); tar xf -) - (tar cf - proposal.html) | (cd $(DOCDIR); tar xf -) - (tar cf - policy-process.html) | (cd $(DOCDIR); tar xf -) + GZIP=-9 cd debconf_spec && \ + tar -zcf ../debconf_specification.xml.tar.gz * + $(install_file) debconf_specification.xml.tar.gz $(DOCDIR)/ + @set -ex; \ + for file in $(DESC_FILES); do \ + $(install_file) $$file.desc $(LIBDIR)/$$file; \ + done + @set -ex; \ + for file in $(SGML_FILES); do \ + tar -C $(DOCDIR) -zxf $$file.html.tar.gz; \ + done + $(install_file) $(FHS_HTML) $(DOCDIR)/fhs + @set -ex; \ + cd debian/tmp; \ + find . -type f -printf '%P\0' | xargs -r0 md5sum > DEBIAN/md5sums 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,prerm} debian/tmp/DEBIAN/ - dpkg-gencontrol -pdebian-policy -Pdebian/tmp -isp - chown -R root.root debian/tmp + $(install_program) debian/postinst debian/tmp/DEBIAN/ + $(install_program) debian/prerm debian/tmp/DEBIAN/ + dpkg-gencontrol -p$(package) -Pdebian/tmp -isp + chown -R root:root debian/tmp chmod -R go=rX debian/tmp dpkg --build debian/tmp .. - debiandoc2latexps policy.sgml - gzip -9qvf policy.ps - debiandoc2latexpdf policy.sgml - gzip -9qfv policy.pdf - GZIP=-9v tar zcf policy.html.tar.gz policy.html - $(install_file) version.ent $(DOCDIR)/ - for i in $(BYHAND_FILES); do \ - $(install_file) $$i .. ; \ - dpkg-distaddfile -fdebian/files `filename $$i` byhand - ; \ - done - touch stamp-policy - - -define checkdir - test -f debian/rules -a -f policy.sgml -endef + touch stamp-policy -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