X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=debian%2Frules;h=bf8c1b240e3fefe0ee3571d0937bebfd3942304f;hb=7274b0d832d8087898384eed6be5150012e092aa;hp=a2378cd331b500ee3d5e4f8d27039fe527de011a;hpb=a8bf97b6b7f724102ecef1d220c71f090bc45657;p=lilypond.git diff --git a/debian/rules b/debian/rules index a2378cd331..bf8c1b240e 100755 --- a/debian/rules +++ b/debian/rules @@ -4,175 +4,109 @@ # This is free software; see the GNU General Public Licence # version 2 or later for copying conditions. There is NO warranty. # -# Currently maintained by Anthony Fok -# for Debian GNU/Linux. -package = lilypond - -SHELL = /bin/sh -r = debian/$(package) -r_data = debian/$(package)-data -r_doc = debian/$(package)-doc -d = usr/share/doc/$(package) - -# since I'm building this a few times on my 8-way machine, try to -# build it faster -ifneq (,$(filter parallel=%,$(DEB_BUILD_OPTIONS))) - NUMJOBS = $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS))) - MAKEFLAGS += -j$(NUMJOBS) CPU_COUNT=$(NUMJOBS) -endif - - -include VERSION -VERSION = $(MAJOR_VERSION).$(MINOR_VERSION).$(PATCH_LEVEL) - -# "main_memory = 263000" in /etc/texmf/texmf.cnf isn't large enough -# for latex to process standchen.dvi.latex, so adding extra_mem_* ... -# export extra_mem_top = 100000 -# export extra_mem_bot = 100000 -# But now, building lilypond.dvi requires increased pool_size (2002-02-18) -# export pool_size = 500000 -# But now, it seems that none of the above is needed in 1.4.11 (2002-02-24) -export MODE = ljfour -export BDPI = 600 -export USER_CFLAGS = -DDEBIAN -export DEB_BUILD = yes export MAILADDRESS = lilypond@packages.debian.org -# fontconfig blows chunks if it can't write $HOME; and some buildd's -# set it to a bogus value. +# fontconfig blows chunks if it can't write to $HOME; and some +# buildds set it to a bogus value. export HOME = /tmp -# Uncomment this to turn on verbose mode. -#export DH_VERBOSE=1 - -# This has to be exported to make some magic below work. -export DH_OPTIONS - -build: build-stamp -build-stamp: - dh_testdir - - cp -f /usr/share/misc/config.guess /usr/share/misc/config.sub ./stepmake/bin/ - ./configure --disable-checking --enable-debugging \ - --prefix=/usr --enable-optimising \ - --infodir='$${prefix}/share/info' \ - --mandir='$${prefix}/share/man' - $(MAKE) - $(MAKE) test - - touch build-stamp - -build-doc: build build-doc-stamp -build-doc-stamp: - dh_testdir - - # make html - # unfortunatly, this does not work well with multiple processors - $(MAKE) -j1 doc WEB_TARGETS="offline" - # make info - $(MAKE) info - - touch build-doc-stamp - -clean: - dh_testdir - dh_testroot - rm -f build-stamp build-doc-stamp - [ ! -f Makefile ] || $(MAKE) web-clean - [ ! -f Makefile ] || $(MAKE) distclean - rm -f lib/python - rm -f ./stepmake/bin/config.guess ./stepmake/bin/config.guess.sub - - # Still not clean enough? Let's use... BRUTE STRENGTH! :-) - find . -type d -name 'out' -o -name 'out-www' | xargs rm -rf - rm -f buildscripts/*.pyc - rm -f lib/lilypond/python examples.html - rm -f debian/emacsen-startup - rm -f debian/lilypond1.7*.dirs debian/lilypond.dirs - rm -f debian/postinst debian/prerm debian/postrm - rm -f debian/lilypond-data.doc-base debian/lilypond.doc-base - rm -f GNUmakefile config.log config.make config.status config.hh - - dh_clean - -install: DH_OPTIONS= -install: build - dh_testdir - dh_testroot - dh_clean -k - dh_installdirs - - # Add here commands to install the package into debian/tmp. - $(MAKE) install prefix=$(CURDIR)/debian/tmp/usr - - dh_install --sourcedir=debian/tmp --list-missing - -# Build architecture-independent files here. -binary-indep: DH_OPTIONS=-i -binary-indep: build-doc install - dh_testdir - dh_testroot - # Install LilyPond web documentation... - $(MAKE) install-doc prefix=$(CURDIR)/debian/lilypond-doc/usr/ - # it installs a random dir-dep file for no reason - rm -f $(CURDIR)/debian/lilypond-doc/usr/share/info/*-dir-dep* +DEB_HOST_ARCH ?= $(shell dpkg-architecture -qDEB_HOST_ARCH) +CFLAGS := $(shell dpkg-buildflags --get CFLAGS) +CXXFLAGS := $(shell dpkg-buildflags --get CXXFLAGS) +ifneq (,$(filter $(DEB_HOST_ARCH), i386 kfreebsd-i386)) + config_opt = --disable-optimising + CFLAGS := $(filter-out -O%, $(CFLAGS)) + CXXFLAGS := $(filter-out -O%, $(CXXFLAGS)) +else +ifneq (,$(filter $(DEB_BUILD_OPTIONS),noopt)) + config_opt = --disable-optimising +else + config_opt = --enable-optimising +endif +endif + +DOC_OPTIONS := WEB_TARGETS="offline" +ifneq (,$(filter parallel=%,$(DEB_BUILD_OPTIONS))) + DOC_OPTIONS := $(DOC_OPTIONS) CPU_COUNT=$(firstword $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))) +endif +%: + dh $@ --parallel --with autotools-dev --with python2 --with quilt + + +## we need to nuke the parser files, because if there is a mistmatch +## between upstreams bison and our bison, the build will fail epically +override_dh_auto_configure: + rm -f lily/out/parser.* + dh_auto_configure -- --disable-checking --enable-debugging $(config_opt) + +override_dh_auto_build-indep: + dh_auto_build + $(MAKE) doc $(DOC_OPTIONS) + +override_dh_auto_install-indep: + $(MAKE) install-doc $(DOC_OPTIONS) prefix=$(CURDIR)/debian/tmp/usr/ + $(MAKE) install-info $(DOC_OPTIONS) prefix=$(CURDIR)/debian/tmp/usr + rm -rf $(CURDIR)/debian/tmp/usr/share/omf + rm -rf $(CURDIR)/debian/tmp/usr/share/doc/lilypond/html/input + +## Unfortunately, lilypond is kind of broken, and installs the wrong +## info documentation (missing images) if we call their makefile +## directly. They also don't provide an install rule which doesn't +## install the documentation, which we don't care about for the +## architecture dependent build +override_dh_auto_install-arch: + for dir in `echo */*makefile|xargs -n 1 dirname|grep -v Documentation`; do \ + $(MAKE) --no-builtin-rules PACKAGE=LILYPOND package=lilypond -C $$dir install $(DOC_OPTIONS) prefix=$(CURDIR)/debian/tmp/usr/; \ + done; + +## we need to nuke the parser files, because if there is a mistmatch +## between upstreams bison and our bison, the build will fail epically +override_dh_auto_clean: + rm -f lily/out/parser.* + dh_auto_clean + +## we need to install only the png, jpg, css, ly and english html +## files into the doc-html package, and only the english pdfs into the +## doc-pdf package. Because dh_install doesn't support regexes, we'll +## use find to replace the contents of the .install file before we +## call dh_install +override_dh_install: + /bin/echo -e 'usr/share/doc/lilypond/html/*/*/*.ly\nusr/share/doc/lilypond/html/*/*/*.png' \ + > $(CURDIR)/debian/lilypond-doc-html.install + /bin/echo -e 'usr/share/doc/lilypond/html/*/*/*.jpg\nusr/share/doc/lilypond/html/*/*/*.css' \ + >> $(CURDIR)/debian/lilypond-doc-html.install + find $(CURDIR)/debian/tmp/ -type f \ + -regex '.*usr/share/doc/lilypond/.*/[^\.]+.html' \ + -printf '%P\n' >> $(CURDIR)/debian/lilypond-doc-html.install + /bin/echo -e ''> $(CURDIR)/debian/lilypond-doc-pdf.install + find $(CURDIR)/debian/tmp/ -type f \ + -regex '.*usr/share/doc/lilypond/.*/[^\.]+.pdf' \ + -printf '%P\n' >> $(CURDIR)/debian/lilypond-doc-pdf.install + find $(CURDIR)/debian/tmp/ -type f \ + -regex '.*usr/share/doc/lilypond/.*/[^\.]+.preview.pdf' \ + -printf '%P\n' >> $(CURDIR)/debian/lilypond-doc-pdf.install + dh_install --list-missing + +override_dh_python2: + dh_python2 + dh_python2 usr/share/lilypond/*/python/ + +override_dh_compress: + dh_compress -X.ly + +override_dh_installdocs: dh_installdocs - find $(CURDIR)/debian/lilypond-doc/usr/share/doc/lilypond/html \ - -type d -empty -delete - dh_installemacsen - - #find input \( -name '*.*ly' -o -name '*.abc' -o -name '*.tex' -o -name 'TODO' \) ! -regex '.*/out-www/.*' \ - # -exec cp -a --parents '{}' $(r_data)/$(d)/examples ';' - install -m 644 debian/xiao-haizi-guai-guai.ly debian/sakura-sakura.ly \ - $(r_data)/$(d)/examples - dh_installchangelogs - -# mv $(r_data)/usr/share/lilypond/$(VERSION)/fonts/map/lilypond.map \ -# $(r_data)/etc/texmf/dvips/lilypond.map - - dh_link usr/share/lilypond/$(VERSION)/tex \ - usr/share/texmf/tex/lilypond \ - usr/share/lilypond/$(VERSION)/fonts/source \ - usr/share/texmf/fonts/source/public/lilypond \ - usr/share/lilypond/$(VERSION)/fonts/afm \ - usr/share/texmf/fonts/afm/public/lilypond \ - usr/share/lilypond/$(VERSION)/fonts/tfm \ - usr/share/texmf/fonts/tfm/public/lilypond \ - usr/share/lilypond/$(VERSION)/fonts/type1 \ - usr/share/texmf/fonts/type1/public/lilypond \ - etc/texmf/dvips/lilypond.map \ - usr/share/lilypond/$(VERSION)/dvips/lilypond.map - - dh_pysupport /usr/share/lilypond/${VERSION}/python - - dh_compress -X$(d)/html/ - dh_fixperms - dh_installdeb - dh_gencontrol - dh_md5sums - dh_builddeb - -binary-arch: DH_OPTIONS=-s -binary-arch: build install - dh_testdir - dh_testroot - dh_installdocs AUTHORS.txt NEWS.txt README.txt \ - DEDICATION THANKS - - - dh_installemacsen - dh_installchangelogs Documentation/misc/CHANGES* Documentation/misc/ChangeLog* - - dh_strip - dh_compress - dh_fixperms - dh_installdeb - dh_shlibdeps - dh_gencontrol - dh_md5sums - dh_builddeb - -binary: binary-indep binary-arch -.PHONY: build clean install binary-indep binary-arch binary + for a in $(wildcard $(CURDIR)/debian/*.doc-base-special); do \ + package=`basename $$a .doc-base-special`; \ + install -d debian/$$package/usr/share/doc-base; \ + install -m0644 $$a debian/$$package/usr/share/doc-base/$$package; \ + done; + +## this rule will update debian/control and the per-language install +## files; all of the files it generates/modifies should be included in +## the Debian package and should not need to be regenerated or +## modified. +update-doc-packages: + perl debian/update_doc_packages