# -*-Makefile-*-
-# title specific top level makefile for LilyPond
-# subdir level:
-#
depth = .
-#
-# descent order into subdirectories
-#
SUBDIRS = buildscripts python scripts \
flower lily \
- mf ly tex ps scm \
+ mf ly \
+ tex ps scm \
po make \
- cygwin debian $(builddir)/stepmake \
- Documentation input
-#
+ elisp vim \
+ input \
+ stepmake $(documentation-dir)
+
-SCRIPTS = configure aclocal.m4 autogen.sh
-README_FILES = ChangeLog COPYING DEDICATION NEWS README.mandrake ROADMAP THANKS
-README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt
-IN_FILES := $(wildcard *.in)
-EXTRA_DIST_FILES = $(wildcard *.el) vimrc VERSION $(README_FILES) $(SCRIPTS) $(IN_FILES) emacsclient.patch lexer-gcc-3.0.patch server.el.patch darwin.patch .cvsignore lexer-gcc-3.1.sh lilypond.words
-NON_ESSENTIAL_DIST_FILES = $(README_TXT_FILES)
+## this convoluted construction is necessary, since we don't know the
+## value of DOCUMENTATION here.
+documentation-dir=$(if $(findstring no,$(DOCUMENTATION)),,Documentation)
+
+SCRIPTS = configure autogen.sh
+README_FILES = COPYING DEDICATION ROADMAP THANKS HACKING
+TOPDOC_FILES = AUTHORS README INSTALL NEWS
+TOPDOC_TXT_FILES = $(addprefix $(top-build-dir)/Documentation/topdocs/$(outdir)/,$(addsuffix .txt,$(TOPDOC_FILES)))
+IN_FILES := $(call src-wildcard,*.in)
+
+EXTRA_DIST_FILES = VERSION .cvsignore .gitignore SConstruct \
+ $(README_FILES) $(SCRIPTS) $(IN_FILES)
INSTALLATION_DIR=$(local_lilypond_datadir)
INSTALLATION_FILES=$(config_make) VERSION
# bootstrap stepmake:
#
STEPMAKE_TEMPLATES=toplevel po install
-include $(depth)/make/stepmake.make
+include $(depth)/make/stepmake.make
+
+#
+# suggested settings
+#
+# LILYPOND_JOBS= -djob-count=X ## for SMP/Multicore machine
+#
+include local.make
+
+local-dist: dist-toplevel-txt-files dist-changelog
+
+dist-changelog:
+ if test -d $(top-src-dir)/.git ; then \
+ cd $(top-src-dir) && git-whatchanged gub-2.9.29-2.. > $(distdir)/ChangeLog ; \
+ else \
+ cp $(top-src-dir)/ChangeLog $(distdir) ; \
+ fi
+
+all: $(outdir)/VERSION
+
+$(outdir)/VERSION: $(config_make) VERSION
+ -mkdir -p $(outdir)
+ echo $(TOPLEVEL_VERSION) > $@
+
+dist-toplevel-txt-files:
+ -mkdir -p $(distdir)
+ ln $(TOPDOC_TXT_FILES) $(distdir)/
+ ln $(top-src-dir)/stepmake/aclocal.m4 $(distdir)/
doc:
$(MAKE) -C Documentation
-pfa-fonts:
- $(MAKE) MAKE_PFA_FILES=1 -C mf
- (cd $(builddir)/share/lilypond/fonts && \
- tar czvf ../../../$(outbase)/type1.tar.gz type1/*.pfa type1/fonts.* type1/lilypond.* )
+install-WWW:
+ -$(INSTALL) -m 755 -d $(DESTDIR)$(webdir)
+ rsync -rl $(outdir)/offline-root/ $(DESTDIR)$(webdir)
+ $(MAKE) -C Documentation/user local-install-WWW
+ $(MAKE) -C Documentation/user install-info
+
+install-help2man:
+ $(MAKE) -C scripts man install-help2man
+ $(MAKE) -C lily man install-help2man
+
+web-install:
+ $(MAKE) out=www install-WWW
-web-install:
- $(INSTALL) -m 755 -d $(webdir)
- tar -C $(webdir)/ -xzf $(outdir)/web.tar.gz
+uninstall-WWW:
+ echo TODO
+
+web-uninstall:
+ $(MAKE) out=www uninstall-WWW
local-install:
- $(INSTALL) -d $(local_lilypond_datadir)
+ $(INSTALL) -d $(DESTDIR)$(local_lilypond_datadir)
final-install:
- @echo
- @echo " *** Before running, buildscripts/out/lilypond-{profile,login}"
- @echo " *** must be run. You're advised to source these scripts from your "
- @echo " *** login scripts. For more information, see Invoking LilyPond in the manual."
- @echo
+ @true
-web-ext = gz html midi pdf png txt ly
-footify=$(PYTHON) $(step-bindir)/add-html-footer.py --name $(PACKAGE_NAME) --version $(TOPLEVEL_VERSION)
+# For online docs with content negotiation, issue `make web WEB_TARGETS=online'
+# For both online and offline docs, issue `make web WEB_TARGETS="offline online"'
+WEB_TARGETS = offline
-local-web-post:
- $(footify) `$(FIND) . -name '*.html' -print`
- cd $(builddir) && rm -f `find . -name \*.html~ -print`
- cd $(builddir) && find Documentation input \
- $(web-ext:%=-path '*/out-www/*.%' -or) -false \
- > $(outdir)/weblist
- echo '<META HTTP-EQUIV="refresh" content="2;URL=Documentation/out-www/index.html">' > $(builddir)/index.html
- cd $(builddir) && ls *.html >> $(outdir)/weblist
- cat $(outdir)/weblist | (cd $(builddir); GZIP=-9v tar -czf $(outdir)/web.tar.gz -T -)
+local-WWW-post:
+# need UTF8 setting in case this is hosted on a website.
+ echo -e 'AddDefaultCharset utf-8\nAddCharset utf-8 .html\nAddCharset utf-8 .en\nAddCharset utf-8 .nl\nAddCharset utf-8 .txt\n' > $(top-build-dir)/.htaccess
+ $(PYTHON) $(buildscript-dir)/mutopia-index.py -o $(outdir)/examples.html input/
+ rm -rf $(outdir)/online-root
+ rm -rf $(outdir)/offline-root
+ $(PYTHON) $(buildscript-dir)/www_post.py $(PACKAGE_NAME) $(TOPLEVEL_VERSION) $(buildscript-dir) $(outdir) "$(WEB_TARGETS)"
-src-ext = c cc yy ll hh icc py scm tex ps texi itexi tely itely sh
-ALL-TAGS:
- etags $(shell find . $(src-ext:%=-name '*.%' -or) -false | grep -v '/out')
+tree-prefix = $(outdir)
+tree-bin = $(tree-prefix)/bin
+tree-lib = $(tree-prefix)/lib
+tree-share = $(tree-prefix)/share
-web-clean:
- $(SHELL) $(buildscript-dir)/clean-fonts.sh
- $(MAKE) out=www clean
+# Don't put version numbers here. During development
+# they make no sense, and cause EPS files to become invalid.
+tree-share-prefix = $(tree-share)/lilypond/current
+tree-lib-prefix = $(tree-lib)/lilypond/current
+C_DIRS = flower lily
+c-clean:
+ $(foreach i, $(C_DIRS), $(MAKE) -C $(i) clean &&) true
-default: $(config_h) builddir-setup
+src-ext = c cc yy ll hh icc py scm tex ps texi itexi tely itely sh
-builddir-setup: $(builddir)/share/lilypond-force
+web-clean:
+ $(MAKE) out=www clean
+ $(MAKE) $(tree-share-prefix)/lilypond-force
-PO_FILES = $(wildcard $(srcdir)/po/*.po)
-HELP_CATALOGS = $(PO_FILES:$(srcdir)/po/%.po=%)
-CATALOGS = $(HELP_CATALOGS:lilypond=)
+default: $(config_h) build-dir-setup
-$(builddir)/share/lilypond-force:
-# Preparing LilyPond tree for builddir exec
- cd $(builddir) && rm -rf lib share
- mkdir -p $(builddir)/lib/lilypond
- mkdir -p $(builddir)/share/lilypond
- mkdir -p $(builddir)/share/lilypond/fonts
- mkdir -p $(builddir)/share/lilypond/tex
- cd $(builddir)/lib/lilypond && \
- ln -s ../../python/$(outconfbase) python
- cd $(builddir)/share/lilypond && \
- ln -s $(abs-srcdir)/ly ly && \
- ln -s ../../mf/$(outconfbase) dvips && \
- ln -s ../../mf/$(outconfbase) afm && \
- ln -s ../../mf/$(outconfbase) tfm && \
- ln -s $(abs-srcdir)/mf && \
- ln -s $(abs-srcdir)/ps && \
- ln -s ../../python/$(outconfbase) python && \
- ln -s $(abs-srcdir)/scm
- cd $(builddir)/share/lilypond/tex && \
- ln -s $(abs-srcdir)/tex source && \
- ln -s ../../../mf/$(outconfbase) generate
- cd $(builddir)/share/lilypond/fonts && \
- ln -s $(abs-srcdir)/mf source && \
- ln -s ../../../mf/$(outconfbase) afm && \
- ln -s ../../../mf/$(outconfbase) tfm && \
- ln -s ../../../mf/$(outconfbase) type1
- $(foreach i,$(CATALOGS), \
- mkdir -p $(builddir)/share/locale/$i/LC_MESSAGES && \
- cd $(builddir)/share/locale/$i/LC_MESSAGES && \
- ln -fs ../../../../po/$(outconfbase)/$i.mo lilypond.mo &&) true
- touch $@
+build-dir-setup: $(tree-share-prefix)/lilypond-force
-local-clean: builddir-setup-clean
-builddir-setup-clean:
- cd $(builddir) && rm -rf share
+PO_FILES = $(call src-wildcard,$(src-depth)/po/*.po)
+HELP_CATALOGS = $(PO_FILES:po/%.po=%)
+CATALOGS = $(HELP_CATALOGS:lilypond=)
-$(config_h): configure.in aclocal.m4
+$(tree-share-prefix)/lilypond-force link-tree: GNUmakefile $(outdir)/VERSION
+# Preparing LilyPond tree for build-dir exec
+ cd $(top-build-dir)/$(outbase) && rm -rf bin lib share
+ mkdir -p $(tree-bin)
+ mkdir -p $(tree-share-prefix)
+ mkdir -p $(tree-lib-prefix)
+ mkdir -p $(tree-share-prefix)/elisp
+ mkdir -p $(tree-share-prefix)/fonts
+ mkdir -p $(tree-share-prefix)/fonts/otf
+ mkdir -p $(tree-share-prefix)/fonts/tfm
+ mkdir -p $(tree-share-prefix)/fonts/type1
+ mkdir -p $(tree-share-prefix)/fonts/svg
+ mkdir -p $(tree-share-prefix)/fonts/map
+ mkdir -p $(tree-share-prefix)/fonts/enc
+ mkdir -p $(tree-share-prefix)/tex
+ cd $(tree-bin) && \
+ ln -sf ../../lily/$(outconfbase)/lilypond . && \
+ for i in abc2ly convert-ly etf2ly lilypond-book lilypond-invoke-editor midi2ly musicxml2ly; \
+ do ln -sf ../../scripts/$(outconfbase)/$$i . ; done
+ cd $(tree-lib-prefix) && \
+ ln -s ../../../../python/$(outconfbase) python
+ cd $(tree-share-prefix) && \
+ ln -s $(top-src-dir)/ly ly && \
+ ln -s ../../../../mf mf && \
+ ln -s $(top-src-dir)/ps && \
+ ln -s ../../../../python/$(outconfbase) python && \
+ ln -s $(top-src-dir)/scm && \
+ ln -s $(top-src-dir)/scripts scripts
+ cd $(tree-share-prefix)/tex && \
+ ln -s $(top-src-dir)/tex source && \
+ ln -s ../../../../../tex/$(outconfbase) tex-out && \
+ ln -s ../../../../../mf/$(outconfbase) mf-out
+
+ cd $(tree-share-prefix)/fonts && \
+ ln -s $(top-src-dir)/mf source && \
+ true
+ -cd $(tree-share-prefix)/elisp && \
+ ln -sf ../../../../../../elisp/$(outconfbase)/lilypond-words.el . && \
+ ln -s $(top-src-dir)/elisp/*.el .
+ $(foreach i,$(CATALOGS), \
+ (mkdir -p $(tree-share)/locale/$i/LC_MESSAGES && \
+ cd $(tree-share)/locale/$i/LC_MESSAGES && \
+ ln -sf ../../../../../po/$(outconfbase)/$i.mo lilypond.mo) &&) true
+ touch $(tree-share-prefix)/lilypond-force
+
+$(tree-share-prefix)/mf-link-tree link-mf-tree: $(tree-share-prefix)/lilypond-force
+ -rm -f $(tree-share-prefix)/fonts/otf/* && \
+ rm -f $(tree-share-prefix)/fonts/svg/* && \
+ rm -f $(tree-share-prefix)/fonts/tfm/* && \
+ rm -f $(tree-share-prefix)/fonts/type1/* && \
+ cd $(tree-share-prefix)/fonts/otf && \
+ ln -s ../../../../../../mf/$(outconfbase)/*.otf .
+ -cd $(tree-share-prefix)/fonts/svg && \
+ ln -s ../../../../../../mf/$(outconfbase)/*.svg .
+ -cd $(tree-share-prefix)/fonts/tfm && \
+ ln -s ../../../../../../mf/$(outconfbase)/*.tfm .
+ -cd $(tree-share-prefix)/fonts/type1 && \
+ ln -s ../../../../../../mf/$(outconfbase)/*.pfa .
+
+TAGS.make: dummy
+ etags -o $@ $(find $(top-src-dir) -name 'GNUmakefile*' -o -name '*.make')
+
+$(config_h): config.hh.in
#
# this is to prevent people from getting
# undefined symbols when we add them to config.h.in,
@echo ' rm $(config_h); ./autogen.sh'
@echo
@false
+
+
+################################################################
+# testing
+
+RESULT_DIR=$(top-build-dir)/out/test-results
+OUT_TEST=test
+
+
+test:
+ rm -f input/regression/out-$(OUT_TEST)/collated-files.html
+ @echo -en 'For tracking crashes: use\n\n\t'
+ @echo 'grep sourcefilename `grep -L systems.texi input/regression/out-test/*log|sed s/log/ly/g`'
+ @echo
+ if test -d .git ; then \
+ echo -e 'HEAD is:\n\n\t' ; \
+ git log --max-count=1 --pretty=oneline ;\
+ echo -e '\n\n\n' ; \
+ git diff ; \
+ fi > input/regression/out-test/tree.gittxt
+ $(MAKE) -C input/regression/ out=$(OUT_TEST) LILYPOND_BOOK_LILYPOND_FLAGS="--backend=eps --formats=ps $(LILYPOND_JOBS) -dseparate-log-files -dinclude-eps-fonts -dgs-load-fonts --header=texidoc -I $(top-src-dir)/input/manual -ddump-profile -dcheck-internal-types -ddump-signatures -danti-alias-factor=1" LILYPOND_BOOK_VERBOSE= out-$(OUT_TEST)/collated-files.html
+ @find input ly -name '*.ly' -print |grep -v 'out.*/' | xargs grep '\\version' -L | grep -v "standard input" |sed 's/^/**** Missing version: /g'
+
+
+test-baseline: test
+ @if test -d .git ; then \
+ $(if $(shell git diff), echo "commit before base lining" && false,true) ; \
+ fi
+ rm -rf input/regression/out-test-baseline
+ mv input/regression/out-test input/regression/out-test-baseline
+
+local-check: test
+ rm -rf $(RESULT_DIR)
+ mkdir -p $(RESULT_DIR)
+ $(PYTHON) $(buildscript-dir)/output-distance.py --create-images --output-dir $(RESULT_DIR) input/regression/out-test-baseline input/regression/out-test/
+
+
+test-redo:
+ for a in `cat $(RESULT_DIR)/changed.txt` ; do \
+ echo removing $$a* ; \
+ rm -f $$a* ;\
+ done
+ $(MAKE) check
+
+test-clean:
+ $(MAKE) -C input/regression/ out=$(OUT_TEST) clean