X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=GNUmakefile.in;h=d4e8ae5ebe62b639d6bdf303e5be9b3fa9b6500d;hb=aad9d4e5907d37f9d05ee870aa59976430a5ae6c;hp=5ecb4bbfcfa8f57763c0a5f7a5871263256f9260;hpb=2050c94d7f75471ef8d1ef466453b2d266dfc8c5;p=lilypond.git diff --git a/GNUmakefile.in b/GNUmakefile.in index 5ecb4bbfcf..d4e8ae5ebe 100644 --- a/GNUmakefile.in +++ b/GNUmakefile.in @@ -8,145 +8,142 @@ depth = . # 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 \ + po make \ + cygwin debian stepmake \ Documentation input \ - mutopia + vim # -SCRIPTS = configure aclocal.m4 autogen.sh -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 = $(wildcard *.el) vimrc VERSION $(README_FILES) $(SCRIPTS) $(IN_FILES) emacsclient.patch lexer-gcc-3.0.patch darwin.patch .cvsignore +PATCH_FILES = emacsclient.patch server.el.patch darwin.patch +EXTRA_DIST_FILES = VERSION .cvsignore SConstruct \ + $(README_FILES) $(SCRIPTS) $(IN_FILES) $(PATCH_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 -run-reqs: builddir-setup fonts lily -web-reqs: run-reqs pfa-fonts - -doc: run-reqs +doc: $(MAKE) -C Documentation -web-doc: web-reqs - $(MAKE) out=www -C Documentation WWW - $(MAKE) footify - -pfa-fonts: - $(MAKE) MAKE_PFA_FILES=1 -C mf +install-WWW: + -$(INSTALL) -m 755 -d $(webdir) + tar -C $(webdir)/ -xzf $(outdir)/web.tar.gz +# install-WWW does not recurse; fake it visiting Documentation/user manually + $(MAKE) -C Documentation/user local-install-WWW -docdir = $(prefix)/share/doc/lilypond-$(TOPLEVEL_VERSION) -install-html-doc: html-doc - $(INSTALL) -d $(docdir)/html - tar -C $(docdir)/html -zxf $(outdir)/web.tar.gz +web-install: + $(MAKE) out=www install-WWW -# KPATHSEA=0: Hack for compiling without kpathsea -- not recommended -my_tfm_path = $(TFM_PATH) /tmp /tmp /tmp /tmp /tmp /tmp +uninstall-WWW: + #TODO +web-uninstall: + $(MAKE) out=www uninstall-WWW= local-install: - $(INSTALL) -d $(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 - + $(INSTALL) -d $(local_lilypond_datadir) -TOP_HTMLS = index.html short-examples.html long-examples.html +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 -short-examples: web-reqs - $(MAKE) out=www -C input WWW - $(PYTHON) $(buildscript-dir)/mutopia-index.py -o $(builddir)/$@.html input/ +web-ext = gz html midi pdf png txt ly -long-examples: web-reqs - $(MAKE) out=www -C mutopia WWW - $(PYTHON) $(buildscript-dir)/mutopia-index.py -o $(builddir)/$@.html mutopia/ +footify = MAILADDRESS=bug-lilypond@gnu.org $(PYTHON) $(step-bindir)/add-html-footer.py --name $(PACKAGE_NAME) --version $(TOPLEVEL_VERSION) -lily: lily/$(outdir)/lilypond - -lily/$(outdir)/lilypond: - $(MAKE) -C lily - -local-web: web-doc $(TOP_HTMLS:%.html=%) footify do-top-doc top-web - -web-ext = gz html midi pdf png txt -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 mutopia \ + cd $(builddir) && find Documentation input \ $(web-ext:%=-path '*/out-www/*.%' -or) -false \ > $(outdir)/weblist - cd $(builddir) && ls *.png *.html >> $(outdir)/weblist + echo '' > $(builddir)/index.html + echo 'Redirecting to the documentation index...' >> $(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') - -local-WWW: - -web: local-web -html-doc: web -index: web -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: - cd $(depth)/$(builddir) && rm -f $(TOP_HTMLS) lily-[0-9]*.png - $(SHELL) $(buildscript-dir)/clean-fonts.sh - -WWW: - -default: builddir-setup - -builddir-setup: $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION)-force +src-ext = c cc yy ll hh icc py scm tex ps texi itexi tely itely sh -$(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION)-force: - # Preparing LilyPond tree for builddir exec - @echo Making $(depth)/$(builddir)/share - @cd $(depth)/$(builddir) && rm -rf share - @cd $(depth)/$(builddir) && mkdir -p share/lilypond - @cd $(depth)/$(builddir)/share/lilypond && mkdir -p $(TOPLEVEL_VERSION) - @cd $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION) && \ - ln -s ../../../$(srcdir)/ly ly && \ - ln -s ../../../mf/$(outconfbase) dvips && \ +web-clean: + $(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 ../../../$(srcdir)/mf && \ - ln -s ../../../$(srcdir)/ps && \ - ln -s ../../../$(srcdir)/scm - @cd $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION) && \ - mkdir tex - @cd $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION)/tex && \ - ln -s ../../../../$(srcdir)/tex source && \ - ln -s ../../../../mf/$(outconfbase) generate - @cd $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION) && \ - mkdir fonts - @cd $(depth)/$(builddir)/share/lilypond/$(TOPLEVEL_VERSION)/fonts && \ - ln -s ../../../../$(srcdir)/mf source && \ - ln -s ../../../../mf/$(outconfbase) afm && \ - ln -s ../../../../mf/$(outconfbase) tfm && \ - ln -s ../../../../mf/$(outconfbase) type1 + 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 $(depth)/$(builddir) && rm -rf share + 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 + +