]> git.donarmstrong.com Git - lilypond.git/blobdiff - GNUmakefile.in
*** empty log message ***
[lilypond.git] / GNUmakefile.in
index 862b9e52e84c5d0891c6c15ae6dadc776e775e82..c84bf3fa4cebe5a83c66438e224bee4bce2360eb 100644 (file)
@@ -1,30 +1,25 @@
 # -*-Makefile-*-
-# title           specific top level makefile for LilyPond  
 
-# subdir level:
-#
 depth = .
-#
 
-# descent order into subdirectories
-# 
 SUBDIRS = buildscripts python scripts \
-       elisp \
-       flower kpath-guile ttftool lily \
-       mf ly tex ps scm \
+       flower lily \
+       mf ly \
+       tex ps scm \
        po make \
-       cygwin debian stepmake \
-       Documentation input \
-       vim 
-#
+       elisp vim \
+       input \
+       cygwin stepmake $(documentation-dir)
 
-include VERSION
-package=`echo $PACKAGE_NAME | tr '[A-Z]' '[a-z]'`
+
+## this convoluted construction is necessary, since we don't know the
+## value of DOCUMENTATION here.
+documentation-dir=$(if $(findstring no,$(DOCUMENTATION)),,Documentation)
 
 SCRIPTS = configure aclocal.m4 autogen.sh lexer-gcc-3.1.sh Doxyfile
-README_FILES = ChangeLog  COPYING DEDICATION ROADMAP THANKS HACKING
+README_FILES = ChangeLog COPYING DEDICATION ROADMAP THANKS HACKING
 README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt NEWS.txt
-IN_FILES := $(wildcard *.in)
+IN_FILES := $(call src-wildcard,*.in)
 PATCH_FILES = emacsclient.patch server.el.patch darwin.patch
 EXTRA_DIST_FILES = VERSION .cvsignore SConstruct \
   $(README_FILES) $(SCRIPTS) $(IN_FILES) $(PATCH_FILES)
@@ -41,9 +36,9 @@ doc:
        $(MAKE) -C Documentation
 
 install-WWW:
-       -$(INSTALL) -m 755 -d $(DESTDIR)$(webdir) 
-       tar -C $(webdir)/ -xzf $(outdir)/web.tar.gz
-# install-WWW does not recurse; fake it visiting Documentation/user manually
+       -$(INSTALL) -m 755 -d $(DESTDIR)$(webdir)
+       cp -a $(outdir)/web-root/ $(DESTDIR)$(webdir)/
+
        $(MAKE) -C Documentation/user local-install-WWW
        $(MAKE) -C Documentation/user install-info
 
@@ -59,6 +54,9 @@ web-uninstall:
 local-install:
        $(INSTALL) -d $(DESTDIR)$(local_lilypond_datadir)
 
+final-install:
+       @true
+
 web-ext = html midi pdf png txt ly
 
 footify = $(PYTHON) $(step-bindir)/add-html-footer.py  --name $(PACKAGE_NAME) --version $(TOPLEVEL_VERSION)
@@ -66,93 +64,123 @@ footifymail = MAILADDRESS=bug-lilypond@gnu.org
 
 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' > $(builddir)/.htaccess
-       $(PYTHON) $(buildscript-dir)/mutopia-index.py -o $(builddir)/examples.html ./
-       cd $(builddir) && $(FIND) . -name '*.html' -print | $(footifymail) xargs $(footify)
-       cd $(builddir) && find . -name \*.html~ -print | xargs rm -f
-       cd $(builddir) && find Documentation input \
+       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/
+       echo '<META HTTP-EQUIV="refresh" content="0;URL=Documentation/index.html">' > $(outdir)/index.html
+       echo '<html><body>Redirecting to the documentation index...</body></html>' >> $(outdir)/index.html
+
+       cd $(top-build-dir) && $(FIND) . -name '*.html' -print | $(footifymail) xargs $(footify)
+       cd $(top-build-dir) && find . -name \*.html~ -print | xargs rm -f
+       cd $(top-build-dir) && find Documentation input \
                $(web-ext:%=-path '*/out-www/*.%' -or) -type l \
                > $(outdir)/weblist
-       echo '<META HTTP-EQUIV="refresh" content="0;URL=Documentation/out-www/index.html">' > $(builddir)/index.html
-       echo '<html><body>Redirecting to the documentation index...</body></html>' >> $(builddir)/index.html
-       cd $(builddir) && ls *.html >> $(outdir)/weblist
-       cat $(outdir)/weblist | (cd $(builddir); GZIP=-9v tar -czf $(outdir)/web.tar.gz  -T -)
-
-share-prefix = $(builddir)/share
-tree-prefix = $(builddir)/share/lilypond/$(TOPLEVEL_VERSION)
+       ls $(outdir)/*.html >> $(outdir)/weblist
+
+## rewrite file names so we lose out-www
+       rm -rf $(outdir)/web-root/
+       mkdir $(outdir)/web-root/
+       cat $(outdir)/weblist | (cd $(top-build-dir); tar -cf-  -T- ) | \
+               tar -C $(outdir)/web-root/ -xf -  
+       cd $(outdir)/web-root/ &&  \
+               for a in `find . -name out-www`; do \
+                       mv $$a/* $$a/.. ; \
+                       rmdir $$a ; \
+               done
+
+tree-prefix = $(outdir)
+tree-bin = $(tree-prefix)/bin
+tree-lib = $(tree-prefix)/lib
+tree-share = $(tree-prefix)/share
+tree-share-prefix = $(tree-share)/lilypond/$(TOPLEVEL_VERSION)
+tree-lib-prefix = $(tree-lib)/lilypond/$(TOPLEVEL_VERSION)
+
+C_DIRS = flower lily
+c-clean:
+       $(foreach i, $(C_DIRS), $(MAKE) -C $(i) clean &&) true
 
 src-ext = c cc yy ll hh icc py scm tex ps texi itexi tely itely sh
 
 web-clean:
        $(MAKE) out=www clean
-       $(MAKE) $(tree-prefix)/lilypond-force
+       $(MAKE) $(tree-share-prefix)/lilypond-force
 
-default: $(config_h) builddir-setup 
+default: $(config_h) build-dir-setup 
 
-builddir-setup: $(tree-prefix)/lilypond-force
+build-dir-setup: $(tree-share-prefix)/lilypond-force
 
-PO_FILES = $(wildcard $(srcdir)/po/*.po)
-HELP_CATALOGS = $(PO_FILES:$(srcdir)/po/%.po=%)
+PO_FILES = $(call src-wildcard,$(src-depth)/po/*.po)
+HELP_CATALOGS = $(PO_FILES:$(src-depth)/po/%.po=%)
 CATALOGS = $(HELP_CATALOGS:lilypond=) 
 
-$(tree-prefix)/lilypond-force link-tree: GNUmakefile
-# Preparing LilyPond tree for builddir exec
-       cd $(builddir) && rm -rf lib share
-       mkdir -p $(builddir)/lib/$(package)
-       mkdir -p $(tree-prefix)
-       mkdir -p $(tree-prefix)/dvips
-       mkdir -p $(tree-prefix)/elisp
-       mkdir -p $(tree-prefix)/fonts
-       mkdir -p $(tree-prefix)/fonts/otf
-       mkdir -p $(tree-prefix)/fonts/tfm
-       mkdir -p $(tree-prefix)/fonts/type1
-       mkdir -p $(tree-prefix)/fonts/svg
-       mkdir -p $(tree-prefix)/fonts/map
-       mkdir -p $(tree-prefix)/fonts/enc
-       mkdir -p $(tree-prefix)/tex
-       cd $(builddir)/lib && \
-               ln -s  ../../../python/$(outconfbase) python
-       cd $(tree-prefix) && \
-               ln -s $(abs-srcdir)/ly ly && \
-               ln -s $(abs-srcdir)/ps && \
-               ln -s ../../../python/$(outconfbase) python && \
-               ln -s $(abs-srcdir)/scm && \
-               ln -s $(abs-srcdir)/scripts scripts
-       cd $(tree-prefix)/dvips && \
-               ln -s ./../../mf/$(outconfbase) mf-out && \
-               ln -s $(abs-srcdir)/ps
-       cd $(tree-prefix)/tex && \
-               ln -s $(abs-srcdir)/tex source && \
-               ln -s ../../../../tex/$(outconfbase) tex-out && \
-               ln -s ../../../../mf/$(outconfbase) mf-out
-       cd $(tree-prefix)/fonts/type1 && \
-               ln -s ../../../../../mf/$(outconfbase)/*.pfa .
-       cd $(tree-prefix)/fonts/otf && \
-               ln -s ../../../../../mf/$(outconfbase)/*.otf .
-       cd $(tree-prefix)/fonts/svg && \
-               ln -s ../../../../../mf/$(outconfbase)/*.svg .
-       cd $(tree-prefix)/fonts/tfm && \
-               ln -s ../../../../../mf/$(outconfbase)/*.tfm .
-       cd $(tree-prefix)/fonts/enc && \
-               ln -s ../../../../../mf/$(outconfbase)/*.enc .
-       cd $(tree-prefix)/fonts && \
-               ln -s $(abs-srcdir)/mf source && \
+$(tree-share-prefix)/lilypond-force link-tree: GNUmakefile
+# 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)
+       (cd $(tree-lib)/lilypond/ && ln -sf $(TOPLEVEL_VERSION) current)
+       (cd $(tree-share)/lilypond/ && ln -sf $(TOPLEVEL_VERSION) current)
+       mkdir -p $(tree-share-prefix)/dvips
+       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 . && \
+               ln -sf ../../scripts/$(outconfbase)/convert-ly . && \
+               ln -sf ../../scripts/$(outconfbase)/lilypond-book . && \
+               ln -sf ../../scripts/$(outconfbase)/*.ly .
+       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)/dvips && \
+               ln -s ./../../../mf/$(outconfbase) mf-out && \
+               ln -s $(top-src-dir)/ps
+       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-prefix)/elisp && \
-               ln -sf ../../../../../elisp/$(outconfbase)/lilypond-words.el . && \
-               ln -s $(abs-srcdir)/elisp/*.el .
+       -cd $(tree-share-prefix)/elisp && \
+               ln -sf ../../../../../../elisp/$(outconfbase)/lilypond-words.el . && \
+               ln -s $(top-src-dir)/elisp/*.el .
        $(foreach i,$(CATALOGS), \
-               mkdir -p $(share-prefix)/locale/$i/LC_MESSAGES && \
-               cd $(share-prefix)/locale/$i/LC_MESSAGES && \
-               ln -sf ../../../../po/$(outconfbase)/$i.mo lilypond.mo &&) true
-#      touch $@
-       touch $(tree-prefix)/lilypond-force
-
-local-clean: builddir-setup-clean
-builddir-setup-clean:
-       cd $(builddir) && rm -rf share
-
-$(config_h): config.hh.in 
+               (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,svg,tfm,type1}/* &&  \
+               cd $(tree-share-prefix)/fonts/otf && \
+               ln -s ../../../../../../mf/$(outconfbase)/*.{otf,ttf} .
+       -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 .
+
+
+local-clean: build-dir-setup-clean
+build-dir-setup-clean:
+       cd $(top-build-dir) && rm -rf share
+
+$(config_h): config.hh.in
 #
 # this is to prevent people from getting
 # undefined symbols  when we add them to config.h.in,
@@ -164,5 +192,3 @@ $(config_h): config.hh.in
        @echo '         rm $(config_h); ./autogen.sh'
        @echo
        @false
-
-