X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=GNUmakefile.in;h=2f768d56b19fcdb09f9ee7bb3d7c08b3de486718;hb=c879d18f08f2000f2fdae1efe108e1bd818eb911;hp=17208a76cabfc2013b5109c8a3efdfe0dba34e5a;hpb=a96faf44452c408fb5cce3a9ac5b6f5b3f509d48;p=lilypond.git diff --git a/GNUmakefile.in b/GNUmakefile.in index 17208a76ca..2f768d56b1 100644 --- a/GNUmakefile.in +++ b/GNUmakefile.in @@ -8,104 +8,162 @@ depth = . # descent order into subdirectories # -SUBDIRS = buildscripts scripts flower lily \ +SUBDIRS = buildscripts python scripts \ + elisp \ + flower kpath-guile lily \ mf ly tex ps scm \ - midi2ly po make intl \ - debian $(builddir)/stepmake \ + po make \ + cygwin debian stepmake \ Documentation input \ - mutopia ports + vim # -SCRIPTS = configure aclocal.m4 -README_FILES = DEDICATION COPYING NEWS CHANGES ROADMAP -README_TXT_FILES = AUTHORS.txt README.txt INSTALL.txt FAQ.txt +#include VERSION +#package=`echo $PACKAGE_NAME | tr '[A-Z]' '[a-z]'` + +SCRIPTS = configure aclocal.m4 autogen.sh lexer-gcc-3.1.sh Doxyfile +README_FILES = ChangeLog COPYING DEDICATION ROADMAP THANKS HACKING +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 +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 - -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 - - -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-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 + $(MAKE) -C Documentation/user local-install-WWW + $(MAKE) -C Documentation/user install-info +web-install: + $(MAKE) out=www install-WWW -long-examples: - $(MAKE) out=www -C mutopia WWW - $(PYTHON) $(buildscript-dir)/mutopia-index.py -o long-examples.html mutopia/ +uninstall-WWW: + #TODO -lily: lily/$(outdir)/lilypond - -lily/$(outdir)/lilypond: - $(MAKE) -C lily - -local-web: fonts lily $(TOP_HTMLS:%.html=%) footify do-top-doc top-web - -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 '*.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 - -web: local-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: - rm -f $(TOP_HTMLS) lily-[0-9]*.png - $(SHELL) $(buildscript-dir)/clean-fonts.sh +web-uninstall: + $(MAKE) out=www uninstall-WWW= +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) +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 \ + $(web-ext:%=-path '*/out-www/*.%' -or) -type l \ + > $(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 -) + +share-prefix = $(builddir)/share +tree-prefix = $(builddir)/share/lilypond/$(TOPLEVEL_VERSION) + +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 + +default: $(config_h) builddir-setup + +builddir-setup: $(tree-prefix)/lilypond-force + +PO_FILES = $(wildcard $(srcdir)/po/*.po) +HELP_CATALOGS = $(PO_FILES:$(srcdir)/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/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/type1 && \ + ln -s ../../../../../mf/$(outconfbase)/*.pfa . + cd $(tree-prefix)/fonts && \ + ln -s $(abs-srcdir)/mf source && \ + true + -cd $(tree-prefix)/elisp && \ + ln -sf ../../../../../elisp/$(outconfbase)/lilypond-words.el . && \ + ln -s $(abs-srcdir)/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 +# +# 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 -WWW: