X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=developers-reference.git;a=blobdiff_plain;f=debian%2Frules;h=240e3b4900ee85c02723d53e7497056f254dfa0c;hp=6f0317dde67dff4bd316c802757e7c7c0fdeac86;hb=9f37a435dd6e6702f2c819ffa7f2415d7d11dfd0;hpb=115f25c409f6197c268198b4b749035589e5dede diff --git a/debian/rules b/debian/rules index 6f0317d..240e3b4 100755 --- a/debian/rules +++ b/debian/rules @@ -1,121 +1,91 @@ #!/usr/bin/make -f # rules file for developers-reference -# -# I do not use debstd, debhelper, or any of that stuff. -# I believe in stripped down rules files; nothing that is not required -# I believe in readability through abstraction package := developers-reference # directory abstraction -prefix := debian/tmp +prefix := debian/$(package) docdir := $(prefix)/usr/share/doc/$(package) -docbasedir := $(prefix)/usr/share/doc-base +docbaserel := /usr/share/doc-base +docbasedir := $(prefix)$(docbaserel) + +# list of language packages, in the form pkg-LANG; must jibe +# with debian/control +langs := fr # tool abstraction install_file := install -o root -g root -m 644 -p install_script := install -o root -g root -m 755 -p make_directory := install -d -o root -g root -m 755 -compress := gzip -9f # version abstraction -DEB_VERSION := $(shell LC_ALL=C dpkg-parsechangelog | grep '^Version: ' | sed 's/^Version: *//') -DEB_DATE := $(shell dpkg-parsechangelog | sed -n 's/^Date: *//p') +DEB_VERSION := $(shell awk -F '[()]' '/^$(package)/{ print $$2; exit }' debian/changelog) +DEB_DATE := $(shell dpkg-parsechangelog 2>/dev/null | sed -n 's/^Date: *//p') # pretty-print the date; I wish this was dynamic like the top-level makefile but oh well -DATE_EN := $(shell LC_ALL=C date --date="$(DEB_DATE)" '+%d %B, %Y') -DATE_FR := $(shell LC_ALL=fr_FR date --date="$(DEB_DATE)" '+%d %B %Y') -DATE_JA := $(shell LC_ALL=ja_JP date --date="$(DEB_DATE)" '+%x') +PUBDATE := $(shell LC_ALL=C date --date="$(DEB_DATE)" -I) -version.ent: debian/changelog - :> version.ent - echo "" >> version.ent - echo "" >> version.ent - echo "" >> version.ent - echo "" >> version.ent +# debhelper verbose mode +#export DH_VERBOSE=1 build: $(checkdir) - $(MAKE) + rm -f version.ent + $(MAKE) VERSION=$(DEB_VERSION) PUBDATE=$(PUBDATE) LANGS="$(langs)" touch build +.PHONY: clean clean: $(checkdir) $(MAKE) clean rm -f build - rm -rf $(prefix) - rm -f debian/files* core debian/substvars + dh_clean +.PHONY: test test: -# make sure control files are good - sh -n debian/postinst - sh -n debian/prerm +# nothing to test ATM -binary-indep: build test +.PHONY: install +install: build $(checkdir) $(checkroot) - rm -rf $(prefix) - $(make_directory) $(prefix)/DEBIAN - $(make_directory) $(docdir) $(docbasedir) - - for dir in $(wildcard developers-reference*.html); do \ - $(make_directory) $(docdir)/$$dir ;\ - $(install_file) $$dir/*.html $(docdir)/$$dir/ ;\ + dh_clean -k + + dh_installdocs -p$(package) README-contrib \ + *.html \ + developers-reference.txt \ + developers-reference.pdf + + set -e; for lang in $(langs); do \ + dh_installdocs -p$(package)-$$lang README-contrib \ + $$lang/*.html \ + $$lang/developers-reference.txt \ + $$lang/developers-reference.pdf; \ done - $(install_file) developers-reference*.txt $(docdir)/ - $(install_file) developers-reference*.pdf $(docdir)/ -# $(install_file) developers-reference*.sgml version.ent common.ent $(docdir)/ - - $(install_file) README-contrib debian/copyright debian/TODO $(docdir)/ - $(install_file) ChangeLog $(docdir)/changelog - $(install_file) debian/changelog $(docdir)/changelog.Debian - $(install_file) $(package).desc $(docbasedir)/$(package) - $(install_file) $(package).fr.desc $(docbasedir)/$(package).fr - $(install_file) $(package).ja.desc $(docbasedir)/$(package).ja - - $(install_script) debian/postinst debian/prerm $(prefix)/DEBIAN/ - -# compress docdir (policy) - find $(docdir) -type f \( -size +4k -or -iname "change*" \) \ - ! -name "*.html" ! -name "*.gif" ! -name "*.pdf" \ - ! -name "copyright" | xargs $(compress) - - dpkg-gencontrol -isp -# be tricky about putting the TOC sections into the description of the package - perl -ne '/^\d+\.\s/ && print " $$_";' < developers-reference.txt \ - >> $(prefix)/DEBIAN/control - - cd $(prefix) && \ - find . -type f ! -regex '.*/DEBIAN/.*' -printf '%P\0' | \ - xargs -r0 md5sum > DEBIAN/md5sums.tmp - $(install_file) $(prefix)/DEBIAN/md5sums.tmp $(prefix)/DEBIAN/md5sums - rm -f $(prefix)/DEBIAN/md5sums.tmp - - dpkg --build $(prefix) .. - -# some extra-package files -# $(install_file) developers-reference.pdf \ -# ../developers-reference.pdf.$(DEB_VERSION) -# dpkg-distaddfile -fdebian/files developers-reference.pdf.$(DEB_VERSION) byhand - -# GZIP=-9 tar czf ../developers-reference.html.tar.gz.$(DEB_VERSION)\ -# developers-reference.html -# dpkg-distaddfile -fdebian/files developers-reference.html.tar.gz.$(DEB_VERSION)\ -# byhand - -# $(install_file) developers-reference.txt \ -# ../developers-reference.txt -# $(compress) ../developers-reference.txt -# mv ../developers-reference.txt.gz \ -# ../developers-reference.txt.gz.$(DEB_VERSION) -# dpkg-distaddfile -fdebian/files \ -# developers-reference.txt.gz.$(DEB_VERSION) byhand - - -binary-arch: build -# There are no architecture-dependent files to be uploaded -# generated by this package. If there were any they would be -# made here. + + +.PHONY: binary-indep +binary-indep: test install + $(checkdir) + $(checkroot) + dh_installdirs -i + dh_installchangelogs -i + dh_compress -i -X.pdf + dh_fixperms -i + debian/tocsubstvars -i + dh_installdeb -i + dh_gencontrol -i + dh_md5sums -i + dh_builddeb -i + + +.PHONY: binary-arch +binary-arch: build install +# There are no architecture-dependent files to be uploaded +# generated by this package. define checkdir test -f debian/rules - test -f developers-reference.sgml + test -f index.dbk endef # Below here is fairly generic really @@ -124,10 +94,5 @@ define checkroot test `id -u` = 0 endef +.PHONY: binary binary: binary-indep binary-arch - -.PHONY: binary binary-arch binary-indep clean - -#Local variables: -#mode: makefile -#End: