# descent order into subdirectories
#
-SUBDIRS = buildscripts scripts flower lily \
+SUBDIRS = buildscripts python scripts \
+ elisp \
+ flower lily \
mf ly tex ps scm \
- python po make intl \
- debian $(builddir)/stepmake \
- Documentation input \
- mutopia ports
+ po make \
+ cygwin debian stepmake \
+ Documentation input
#
-SCRIPTS = configure aclocal.m4
-README_FILES = ChangeLog CHANGES COPYING DEDICATION NEWS README.mandrake ROADMAP
-README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt FAQ.txt
+SCRIPTS = configure aclocal.m4 autogen.sh lexer-gcc-3.1.sh
+README_FILES = ChangeLog COPYING DEDICATION ROADMAP THANKS
+README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt NEWS.txt
IN_FILES := $(wildcard *.in)
-EXTRA_DIST_FILES = lilypond-font-lock.el lilypond-mode.el lilypond-init.el vimrc VERSION $(README_FILES) $(SCRIPTS) $(IN_FILES) emacsclient.patch lexer-gcc-3.0.patch .cvsignore
+PATCH_FILES = emacsclient.patch server.el.patch darwin.patch
+VIM_FILES = vimrc lilypond.vim
+EXTRA_DIST_FILES = VERSION .cvsignore $(README_FILES) $(SCRIPTS) $(IN_FILES) \
+ $(PATCH_FILES) $(VIM_FILES)
NON_ESSENTIAL_DIST_FILES = $(README_TXT_FILES)
-INSTALLATION_DIR=$(datadir)
-INSTALLATION_FILES=$(configuration) VERSION
+INSTALLATION_DIR=$(local_lilypond_datadir)
+INSTALLATION_FILES=$(config_make) VERSION
# bootstrap stepmake:
#
STEPMAKE_TEMPLATES=toplevel po install
include $(depth)/make/stepmake.make
-#
-
-footify:
- $(footify) --index=./ `$(FIND) . -maxdepth 1 -name '*.html' -print`
- $(footify-all-command)
-fonts:
- $(MAKE) -C $(depth)/mf
-
-doc: lily fonts
+doc:
$(MAKE) -C Documentation
-web-doc:
- $(MAKE) out=www -C Documentation WWW
- $(MAKE) footify
-
-# KPATHSEA=0: Hack for compiling without kpathsea -- not recommended
-my_tfm_path = $(TFM_PATH) /tmp /tmp /tmp /tmp /tmp /tmp
+install-WWW:
+ -$(INSTALL) -m 755 -d $(webdir)
+ tar -C $(webdir)/ -xzf $(outdir)/web.tar.gz
+web-install:
+ $(MAKE) out=www install-WWW
local-install:
- mkdir -p $(datadir)
-ifeq ($(KPATHSEA),0)
- $(foreach i, 1 2 3 4 5, rm -f $(datadir)/tfm.$(i); $(LN_S) $(word $(i), $(my_tfm_path)) $(datadir)/tfm.$(i) ; )
-endif
-
-
-TOP_HTMLS = index.html short-examples.html long-examples.html
-
-index: web-doc
-
-short-examples:
- $(MAKE) out=www -C input WWW
- $(PYTHON) $(buildscript-dir)/mutopia-index.py -o short-examples.html input/
+ $(INSTALL) -d $(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
-long-examples:
- $(MAKE) out=www -C mutopia WWW
- $(PYTHON) $(buildscript-dir)/mutopia-index.py -o long-examples.html mutopia/
+web-ext = gz html midi pdf png txt ly
-lily: lily/$(outdir)/lilypond
+footify = MAILADDRESS=bug-lilypond@gnu.org $(PYTHON) $(step-bindir)/add-html-footer.py --name $(PACKAGE_NAME) --version $(TOPLEVEL_VERSION)
-lily/$(outdir)/lilypond:
- $(MAKE) -C lily
+bla:
+ cd $(builddir) && $(footify) `$(FIND) . -name '*.html' -print`
-local-web: fonts lily $(TOP_HTMLS:%.html=%) footify do-top-doc top-web
+local-WWW-post:
+ $(PYTHON) $(buildscript-dir)/mutopia-index.py -o $(builddir)/examples.html ./
+ cd $(builddir) && $(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="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 -)
-top-web:
- rm -f `find . -name \*.html~ -print`
- find `find Documentation input mutopia *.png index.html -type d -name 'out-www'` \
- -not -name '*.dvi' -not -name '*ly' -not -name '*.tex' \
- -not -name '*.ps' -not -name '*.eps' -not -name '*pk' \
- -not -name '*.aux' -not -name '*.cp' -not -name '*.fn' \
- -not -name '*.vr' -not -name '*.yp' -not -name '*.ky' \
- -not -name '*.pg' -not -name '*.tmp' -not -name '*.toc' \
- -not -name '*.fns' -not -name '*.cps' -not -name '*.nexi' \
- -not -name '*.texi' -not -name '*.texidoc' -not -name '*.tp' \
- -not -name '*.log' -not -name 'out-www' -not -name '*.dep' \
- > $(outdir)/weblist
- ls *.png *.html >> $(outdir)/weblist
- cat $(outdir)/weblist | GZIP=-9v tar -czf $(outdir)/web.tar.gz -T -
-#WWW: local-WWW
+src-ext = c cc yy ll hh icc py scm tex ps texi itexi tely itely sh
-web: local-web
+ALL-TAGS:
+ etags $(shell find . $(src-ext:%=-name '*.%' -or) -false | grep -v '/out')
-local-WWW-clean: top-WWW-clean
-
-WWW-clean:
- $(MAKE) -C Documentation WWW-clean
- $(MAKE) -C input WWW-clean
- $(MAKE) -C mutopia WWW-clean
-
-top-WWW-clean:
- rm -f $(TOP_HTMLS) lily-[0-9]*.png
+web-clean:
$(SHELL) $(buildscript-dir)/clean-fonts.sh
-
-
-
-WWW:
+ $(MAKE) out=www clean
+ $(MAKE) $(builddir)/share/lilypond-force
+
+
+default: $(config_h) builddir-setup
+
+builddir-setup: $(builddir)/share/lilypond-force
+
+PO_FILES = $(wildcard $(srcdir)/po/*.po)
+HELP_CATALOGS = $(PO_FILES:$(srcdir)/po/%.po=%)
+CATALOGS = $(HELP_CATALOGS:lilypond=)
+
+$(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/elisp
+ 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
+ cd $(builddir)/share/lilypond/elisp && \
+ ln -sf ../../../elisp/$(outconfbase)/lilypond.words.el . && \
+ ln -s $(abs-srcdir)/elisp/*.el .
+ $(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 $@
+
+local-clean: builddir-setup-clean
+builddir-setup-clean:
+ cd $(builddir) && 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,
+# and they blindly run "cvs update; make".
+#
+ @echo
+ @echo ' *** $(config_h) is out of date'
+ @echo ' *** Remove it and rerun autogen:'
+ @echo ' rm $(config_h); ./autogen.sh'
+ @echo
+ @false
+
+
+# maybe move into private script?
+rsync-web:
+ cd out-www && mkdir web && tar -xzf web.tar.gz -C web
+ cd out-www/web && \
+ chgrp -R lilypond . && \
+ chmod -R g+w . && \
+ chmod 2775 `find -type d` . && \
+ rsync --delete --stats --progress -gorltvu -e ssh . x:/var/www/lilypond/doc/v$(MAJOR_VERSION).$(MINOR_VERSION)/
+ cd out-www && rm -rf web/