X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=debian%2Frules;h=0139b9d0183f6f901a1198e230ca50fc06b42c7f;hb=0faa083fa169ed1134802a26c00d5ce6443d6cfd;hp=bc5c534b43fad8afb53299980680a28632d7d127;hpb=699e6f1eaae51f9a86fcba4ca604264cb3d0a9fa;p=lilypond.git diff --git a/debian/rules b/debian/rules index bc5c534b43..0139b9d018 100755 --- a/debian/rules +++ b/debian/rules @@ -5,35 +5,195 @@ # version 2 or later for copying conditions. There is NO warranty. # -export MAILADDRESS = lilypond@packages.debian.org +include VERSION -# fontconfig blows chunks if it can't write to $HOME; and some -# buildds set it to a bogus value. -export HOME = /tmp +export MAILADDRESS = lilypond@packages.debian.org DEB_HOST_ARCH ?= $(shell dpkg-architecture -qDEB_HOST_ARCH) +DEB_HOST_MULTIARCH ?= $(shell dpkg-architecture -qDEB_HOST_MULTIARCH) 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)))) + guile_make_args := -j$(firstword $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))) +endif + +######################################################################## +# START: Definitions from the old guile-1.8 (1.8.8+1-10) package +######################################################################## + +# These are used for cross-compiling and for saving the configure script +# from having to guess our platform (since we know it already) +DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE) +DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE) + +ifeq (alpha,$(shell dpkg-architecture -qDEB_HOST_ARCH)) + # The -O2 option breaks make check on alpha right now. + guile_deb_cflags := -Os -g +else ifeq (sh4,$(shell dpkg-architecture -qDEB_HOST_ARCH)) + # Renesas SH(sh4) needs -mieee. Without it, test-conversion fails. + # (Bug: 531378) + guile_deb_cflags := -O2 -g -mieee +else + guile_deb_cflags := -O2 -g +endif + +ifneq (,$(findstring debug,$(DEB_BUILD_OPTIONS))) + CFLAGS += -g +endif +ifeq (,$(findstring nostrip,$(DEB_BUILD_OPTIONS))) + INSTALL_PROGRAM += -s +endif + +guile_configure_args = \ + --host=$(DEB_HOST_GNU_TYPE) \ + --build=$(DEB_BUILD_GNU_TYPE) \ + --with-threads=no \ + --disable-error-on-warning \ + --prefix=/usr + +ifeq (hurd-i386,$(shell dpkg-architecture -qDEB_HOST_ARCH)) + guile_configure_args += LIBS=-lpthread +endif + +######################################################################## +# END: Definitions from the old guile-1.8 (1.8.8+1-10) package +######################################################################## + +export PATH := $(CURDIR)/out/guile/usr/bin:$(PATH) +export LD_LIBRARY_PATH := $(CURDIR)/out/guile/usr/lib:$(LD_LIBRARY_PATH) +export GUILE_LOAD_PATH := $(CURDIR)/out/guile/usr/share/guile/1.8 +export LILYPOND_VERSION := $(MAJOR_VERSION).$(MINOR_VERSION).$(PATCH_LEVEL) + +%.reloc: %.reloc.in + sed < $< > $@ \ + -e 's!@LILYPOND_VERSION@!$(LILYPOND_VERSION)!g' + +%.sh: %.sh.in + sed < $< > $@ \ + -e 's!@DEB_HOST_MULTIARCH@!$(DEB_HOST_MULTIARCH)!g' \ + -e 's!@LILYPOND_VERSION@!$(LILYPOND_VERSION)!g' +# Do not use debhelper's autoreconf, the build currently +# fails with this option and we take care of that +# ourselves anyway. %: - dh --parallel $@ + dh $@ --without autoreconf --with python2 --with quilt + +## we need to nuke the parser files, because if there is a mismatch +## between upstreams bison and our bison, the build will fail epically +override_dh_auto_configure: + $(eval unexport GUILE_LOAD_PATH) + cd guile18 && ./autogen.sh + cd guile18 && CFLAGS="$(guile_deb_cflags)" ./configure ${guile_configure_args} + cd guile18 && $(MAKE) ${guile_make_args} + $(MAKE) -C guile18 install DESTDIR=$(CURDIR)/out/guile + rm -f lily/out/parser.* + ./autogen.sh --noconfigure + GUILE_LOAD_PATH="$(GUILE_LOAD_PATH)" \ + dh_auto_configure -- --disable-checking --enable-debugging $(config_opt) + +override_dh_auto_build-indep: + dh_auto_build -i + $(MAKE) doc $(DOC_OPTIONS) + +## 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: debian/lilypond.sh debian/lilypond-invoke-editor.sh + 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 + sed -i -e '1s!$(CURDIR)/out/guile/usr/bin/guile!/usr/bin/guile!' \ + debian/tmp/usr/bin/lilypond-invoke-editor + +## We need the non-Documentation arch-independent files installed by +## the arch-dependent "$(MAKE) install" too, hence the dependency +## on override_dh_auto_install-arch +override_dh_auto_install-indep: override_dh_auto_install-arch debian/guile.reloc + $(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 + perl debian/move_info_images_from_html_doc $(CURDIR)/debian/tmp/usr/share/info/ $(CURDIR)/debian/tmp/usr/share/doc/lilypond/html/Documentation/ + perl debian/symlink_html_images_to_info_images $(CURDIR)/debian/tmp/usr/share/info/lilypond + perl debian/remove_w3c_callback $(CURDIR)/debian/tmp/usr/share/doc/lilypond/ $(CURDIR)/debian/tmp/usr/share/info/ +## we need to nuke the parser files, because if there is a mismatch +## between upstreams bison and our bison, the build will fail epically +override_dh_auto_clean: + [ ! -f guile18/Makefile ] || $(MAKE) -C guile18 maintainer-clean + rm -f lily/out/parser.* + dh_auto_clean --no-parallel -override_dh_auto_configure: - dh_auto_configure -- --disable-checking --enable-debugging $(config_opt) +override_dh_install-arch: + dh_install -a --list-missing -build-indep: - $(MAKE) -j1 doc WEB_TARGETS="offline" +## 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-indep: + /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 -i --list-missing -build-arch: - dh_auto_build -a +override_dh_python2: + dh_python2 --verbose + dh_python2 --verbose usr/share/lilypond/$(MAJOR_VERSION).$(MINOR_VERSION).$(PATCH_LEVEL)/python/ + +override_dh_compress: + dh_compress -X.ly -X.pdf + +override_dh_installdocs: + dh_installdocs + 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 + +override_dh_shlibdeps-arch: + $(eval unexport LD_LIBRARY_PATH) + dh_shlibdeps -a -lusr/lib/$(DEB_HOST_MULTIARCH)/lilypond/$(LILYPOND_VERSION)/guile + +# Skip tests for architecture-dependent-only build because +# the test would fail without built documentation. +override_dh_auto_test-arch: + +override_dh_auto_test-indep: +ifeq (,$(filter $(DEB_BUILD_OPTIONS),nocheck)) + $(MAKE) test-baseline + $(MAKE) test +endif ## this rule will update debian/control and the per-language install ## files; all of the files it generates/modifies should be included in @@ -41,68 +201,3 @@ build-arch: ## modified. update-doc-packages: perl debian/update_doc_packages - - -## # 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* -## -## dh_installinfo -## dh_installdocs -## # remove the useless offline-root directory -## mv $(CURDIR)/debian/lilypond-doc/usr/share/doc/lilypond/html/offline-root/* \ -## $(CURDIR)/debian/lilypond-doc/usr/share/doc/lilypond/html/.; -## rmdir $(CURDIR)/debian/lilypond-doc/usr/share/doc/lilypond/html/offline-root; -## find $(CURDIR)/debian/lilypond-doc/usr/share/doc/lilypond/html \ -## -type d -empty -delete -## dh_installemacsen -## -## install -m 644 debian/xiao-haizi-guai-guai.ly debian/sakura-sakura.ly \ -## $(r_data)/$(d)/examples -## dh_installchangelogs -## -## 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/type1 \ -## usr/share/texmf/fonts/type1/public/lilypond \ -## -## 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_pysupport /usr/share/lilypond/${VERSION}/python -## 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