X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=GNUmakefile.in;h=09830cffe143869e96592837fb17991204894bb2;hb=79a1d3e220b3d1238fe9f483c9960d4b82c28249;hp=41d87c4315fdc4e4fa6b20f77ce47240a0af4bf5;hpb=a6157e173876ce2a638649ba8c240f02ed905888;p=lilypond.git diff --git a/GNUmakefile.in b/GNUmakefile.in index 41d87c4315..09830cffe1 100644 --- a/GNUmakefile.in +++ b/GNUmakefile.in @@ -6,79 +6,131 @@ depth = . # -# descent order into subdirectories: -# -SUBDIRS = buildscripts scripts flower lily mf midi2ly po debian \ - Documentation ly input tex make mutopia intl $(builddir)/stepmake\ - ps scm +# descent order into subdirectories +# +SUBDIRS = buildscripts python scripts \ + flower lily \ + mf ly tex ps scm \ + po make \ + cygwin debian $(builddir)/stepmake \ + Documentation input # -SCRIPTS = configure aclocal.m4 -README_FILES = DEDICATION COPYING NEWS CHANGES ROADMAP -README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt FAQ.txt +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 = lilypond-font-lock.el lilypond-mode.el vimrc VERSION $(README_FILES) $(SCRIPTS) $(IN_FILES) +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) -INSTALLATION_DIR=$(datadir) -INSTALLATION_FILES=$(builddir)/config.make VERSION +INSTALLATION_DIR=$(local_lilypond_datadir) +INSTALLATION_FILES=$(configuration) VERSION # bootstrap stepmake: # -STEPMAKE_TEMPLATES=toplevel yolily-toplevel po install +STEPMAKE_TEMPLATES=toplevel po install include $(depth)/make/stepmake.make -# -website: fonts htmldoc examples footify +doc: + $(MAKE) -C Documentation -footify: - $(footify) --index=./ `$(FIND) . -maxdepth 1 -name '*.html' -print` - $(footify-all-command) +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.* ) -fonts: - $(MAKE) -C $(depth)/mf +html-doc: web +install-html-doc: + $(INSTALL) -m 755 -d $(local_package_docdir) + tar -C $(local_package_docdir)/ -xzf $(outdir)/web.tar.gz -doc: - $(MAKE) -C Documentation +local-install: + $(INSTALL) -d $(local_lilypond_datadir) -htmldoc: - $(MAKE) out='www' local-WWW - $(MAKE) out='www' -C Documentation WWW - rm -f `find . -name \*.html~ -print` - $(footify) --index=./ `$(FIND) . -maxdepth 1 -name '*.html' -print` - $(footify-all-command) - find `find Documentation -type d -name 'out-www'` -not -name '*dvi' -not -name '*ly' -not -name '*tex' -not -name '*.ps' -not -name 'out-www' > wwwlist - tar cfz $(outdir)/htmldoc.tar.gz `cat wwwlist` `ls *.png $(ERRORLOG)` index.html - -examples: - $(MAKE) out='www' -C input WWW - $(MAKE) out='www' -C mutopia WWW -# arg, should not break concept of recursive make; -# this breaks links (and dependencies, see above) - -# don't understand this comment --hwn - -# See below. The footify-all you had before caused dead links on the -# webpage, because the footify command assumes it can calculate the location -# of index.html from the current depth. That doesn't work, if you don't -# use recursive make like we do everywhere else; leads to bugs that you -# make a specific fix for. - - $(PYTHON) $(buildscript-dir)/mutopia-index.py -o short-examples.html input/ - $(PYTHON) $(buildscript-dir)/mutopia-index.py -o long-examples.html mutopia/ -#$(footify-all-command) - $(footify) --index=./ `$(FIND) . -name '*.html' -print` - tar --exclude='*.dvi' --exclude='*.tex' --exclude='*.ps' --exclude='*.ppm' -czf $(outdir)/examples.tar.gz *-examples.html `find input mutopia -type d -name 'out-www' -print` - -# Kpathsea is overkill, and a horror/impossible to compile without compiling -# and using a matching TeX (well, I gave up trying for now). -my_tfm_path=$(TFM_PATH) /tmp /tmp /tmp /tmp /tmp /tmp - -localinstall: - 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 - -local-WWW-clean: - $(SHELL) $(buildscript-dir)/clean-fonts.sh +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 + +web-ext = gz html midi pdf png txt ly + +footify=$(PYTHON) $(step-bindir)/add-html-footer.py --name $(PACKAGE_NAME) --version $(TOPLEVEL_VERSION) +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 '' > $(builddir)/index.html + cd $(builddir) && ls *.html >> $(outdir)/weblist + cat $(outdir)/weblist | (cd $(builddir); GZIP=-9v tar -czf $(outdir)/web.tar.gz -T -) + +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') + +web-clean: + $(SHELL) $(buildscript-dir)/clean-fonts.sh + $(MAKE) out=www clean + + + +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/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 $@ + +local-clean: builddir-setup-clean +builddir-setup-clean: + cd $(builddir) && rm -rf share + +$(config_h): configure.in aclocal.m4 +# +# 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