X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=debian%2Frules;h=96565f0ffc6c8f85b7531dea4bb9e415d530b2ac;hb=249be3f8515dec54a8a58f5b431eb7db4f66fde5;hp=38d4587e96283ee533d7137d5824d73cc23e3440;hpb=5576bef4713c38b8911a5458801aa4e4426c44d0;p=debian%2Fdebian-policy.git diff --git a/debian/rules b/debian/rules index 38d4587..96565f0 100755 --- a/debian/rules +++ b/debian/rules @@ -1,69 +1,107 @@ #!/usr/bin/make -f -############################ -*- Mode: Makefile -*- ########################### -## rules --- -## Author : Manoj Srivastava ( srivasta@tiamat.datasync.com ) -## Created On : Thu Oct 29 15:35:55 1998 -## Created On Node : tiamat.datasync.com -## Last Modified By : Manoj Srivastava -## Last Modified On : Tue Apr 27 10:38:06 1999 -## Last Machine Used: glaurung.green-gryphon.com -## Update Count : 34 -## Status : Unknown, Use with caution! -## HISTORY : -## Description : -## -############################################################################### -# The name of the package (for example, `emacs'). + +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) + +arch := $(shell dpkg --print-architecture) + +# 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: *//') +version := $(shell awk -F '[()]' '/^$(package)/{ print $$2; exit }' debian/changelog) -FILES_TO_CLEAN = debian/files debian/buildinfo debian/substvars \ - version.ent policy.lout policy.lout.ld lout.li \ - upgrading-checklist.text policy.text.gz -STAMPS_TO_CLEAN = stamp-binary stamp-build stamp-configure -DIRS_TO_CLEAN = debian/tmp policy.html +# Currently, emacs23 is required (xemacs is not sufficient). +EMACS := emacs23 # Location of the source dir -SRCTOP := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi;) +SRCTOP := $(CURDIR) TMPTOP := $(SRCTOP)/debian/tmp -DOCDIR := $(TMPTOP)/usr/doc/$(package) +DOCDIR := $(TMPTOP)/usr/share/doc/$(package) LIBDIR := $(TMPTOP)/usr/share/doc-base -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 -BYHAND_FILES =policy.text.gz libc6-migration.text\ - virtual-package-names-list.text +sanitycheck := debian/rules policy.sgml + +SGML_FILES := policy menu-policy mime-policy perl-policy upgrading-checklist +DESC_FILES := copyright-format debian-policy debian-menu-policy debian-perl-policy \ + debian-mime-policy 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 := $(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 \ + libc6-migration.txt version.ent \ + copyright-format/copyright-format.html \ + copyright-format/copyright-format.txt.gz \ + debconf_spec/debconf_specification.html \ + debconf_spec/debconf_specification.txt.gz \ + policy.ps.gz policy.pdf.gz README.txt README.html \ + Process.txt Process.html + +FILES_FROM_ORG := Process.html Process.txt README.txt README.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 +# policy.{pdf,ps,tpt,txt} are generated files +FILES_TO_CLEAN = copyright-format.xml.tar.gz \ + debian/files debian/buildinfo debian/substvars \ + debian/postinst debian/prerm \ + version.ent \ + $(SGML_FILES:=.txt.gz) $(SGML_FILES:=.html.tar.gz) \ + $(SGML_FILES:=-1.html) \ + policy.pdf.gz policy.ps.gz \ + debconf_specification.xml.tar.gz \ + policy.pdf policy.ps policy.txt policy. \ + body.tmp head.tmp policy.tpt \ + $(FILES_FROM_ORG) + +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 - nsgmls -gues policy.sgml # check SGML syntax - debiandoc2html policy.sgml - debiandoc2text policy.sgml - lynx -dump upgrading-checklist.html > upgrading-checklist.text - gzip -9f policy.text +stamp-build: version.ent $(sanitycheck) + $(MAKE) $(SGML_FILES:=.sgml.validate) \ + $(SGML_FILES:=.html.tar.gz) \ + $(SGML_FILES:=-1.html) \ + $(SGML_FILES:=.txt.gz) \ + policy.ps.gz policy.pdf.gz + $(MAKE) $(FILES_FROM_ORG) + $(MAKE) -C copyright-format all + $(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 copyright-format clean + $(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 \ @@ -73,20 +111,20 @@ 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-binary -stamp-binary: build - @test root = "`whoami`" || (echo need root priviledges; exit 1) - $(checkdir) - test -f stamp-build || $(MAKE) -f debian/rules build - -rm -rf $(TMPTOP) +binary-indep: stamp-policy +stamp-policy: build $(sanitycheck) + @test $$(id | sed -e 's/(.*$$//' -e 's/^uid=//') || \ + (echo need root priviledges; exit 1) +# 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 # we don't hardcode the policy compliance of the policy @@ -95,35 +133,45 @@ stamp-binary: build # itself... echo "debian-policy:Version=$(version)" > debian/substvars $(install_file) $(POLICY_FILES) $(DOCDIR)/ - $(install_file) $(FSSTND_FILES) $(DOCDIR)/fsstnd/ $(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 -) - $(install_program) debian/{postinst,prerm} debian/tmp/DEBIAN/ - dpkg-gencontrol -isp - chown -R root.root debian/tmp + GZIP=-9 cd copyright-format && \ + tar -zcf ../copyright-format.xml.tar.gz * + $(install_file) copyright-format.xml.tar.gz $(DOCDIR)/ + @set -ex; \ + 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 + for file in $(SGML_FILES); do \ + $(install_file) $${file}-1.html $(DOCDIR); \ + done + $(install_file) $(FHS_HTML) $(DOCDIR)/fhs + @set -ex; \ + cd debian/tmp; \ + find . -path "./DEBIAN" -prune -o -type f -printf '%P\0' \ + | xargs -r0 md5sum > DEBIAN/md5sums + dpkg-gencontrol -p$(package) -Pdebian/tmp -isp + chown -R root:root debian/tmp chmod -R go=rX debian/tmp dpkg --build debian/tmp .. - debiandoc2ps -pa4 -1 -O policy.sgml | gzip -9v > ../policy.ps.gz - GZIP=-9v tar zcf ../policy.html.tar.gz policy.html - dpkg-distaddfile -fdebian/files policy.ps.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-binary - -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