X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=configure.in;h=d2b8289cad50bfff78f58adee652cf439ce5b417;hb=f17281ba19ee591b2199cf8edb15f69d72bb772a;hp=1355b73bf5d01696453a575894919d6d616e6400;hpb=3b764dbab9c6ba03a1a5c2caa0c3046e96a6f596;p=lilypond.git diff --git a/configure.in b/configure.in index 1355b73bf5..d2b8289cad 100644 --- a/configure.in +++ b/configure.in @@ -1,58 +1,137 @@ dnl configure.in -*-shell-script-*- dnl Process this file with autoconf to produce a configure script. -# Bootstrap the init proces. List a file identifies your package. -AC_INIT(make/lilypond.lsm.in) -AC_CONFIG_HEADER($CONFIGFILE.h:config.hh.in) +# Bootstrap the init proces. +AC_INIT # Bootstrap StepMake configure -AC_STEPMAKE_INIT +# For user package: +AC_CONFIG_AUX_DIR([stepmake/bin]) +# For stepmake package: +# AC_CONFIG_AUX_DIR(bin) -# For all packages except the StepMake package itself -AC_CONFIG_SUBDIRS(stepmake) + +STEPMAKE_INIT + +# List a file that identifies your package. +AC_CONFIG_SRCDIR([lily/main.cc]) + +# Move to aclocal.m4? +AC_CONFIG_HEADER([$CONFIGFILE.hh:config.hh.in]) # Uncomment the configuration options your package needs. -AC_STEPMAKE_COMPILE -# AC_HAVE_HEADERS(limits.h malloc.h string.h unistd.h values.h) - -printing_b=no -AC_ARG_ENABLE(printing, - [ enable-printing turn on debug printing. Default: off], - [printing_b=$enableval]) - -if test "$optimise_b" = yes; then - DEFINES="$DEFINES -DSTRING_UTILS_INLINED" - AC_DEFINE(STRINGS_UTILS_INLINED) -fi -AC_STEPMAKE_CXX -AC_STEPMAKE_GXX -AC_STEPMAKE_CXXTEMPLATE -AC_STEPMAKE_LEXYACC -AC_STEPMAKE_LIB -# AC_STEPMAKE_LIBTOOL -AC_STEPMAKE_LOCALE -AC_STEPMAKE_GETTEXT -AC_STEPMAKE_MSGFMT -AC_STEPMAKE_TEXMF -AC_STEPMAKE_TEXMF_DIRS -AC_STEPMAKE_YODL -AC_STEPMAKE_GUILE - -dnl should check out -print -dnl huh? -dnl AC_CHECK_SEARCH_RESULT($FIND, find, Please use --enable-tex-dir) +gui_b=no +AC_ARG_ENABLE(gui, + [ --enable-gui compile with experimental GNOME output module. Default: off], + [gui_b=$enableval]) + +# must come before any header checks +STEPMAKE_COMPILE + +STEPMAKE_PYTHON(REQUIRED,2.1) +STEPMAKE_GCC(REQUIRED, 2.8) +STEPMAKE_CXX(REQUIRED) +STEPMAKE_GXX(REQUIRED, 3.0.5) +STEPMAKE_CXXTEMPLATE +STEPMAKE_LIB(REQUIRED) +# Do not use bison 1.50 and 1.75. +# 1.29 is required fr %locations, but I'm not sure it's enough --ns +STEPMAKE_BISON(REQUIRED, 1.29) +STEPMAKE_FLEX(REQUIRED) +STEPMAKE_FLEXLEXER(REQUIRED) +AC_LANG_C +STEPMAKE_LOCALE +STEPMAKE_GETTEXT +STEPMAKE_MSGFMT(REQUIRED) +STEPMAKE_TEXMF(REQUIRED) +STEPMAKE_TEXMF_DIRS +STEPMAKE_GUILE_DEVEL(REQUIRED, 1.6) +STEPMAKE_KPATHSEA +STEPMAKE_MAKEINFO(REQUIRED) +STEPMAKE_PYTHON_DEVEL(REQUIRED) + +# mftrace for generating pfa's, pfb's +STEPMAKE_PROGS(MFTRACE, mftrace, REQUIRED, 1.1.1) + +# mftrace for generating pfa's, pfb's +STEPMAKE_PATH_PROG(FONTFORGE, fontforge, REQUIRED, 20041208) + + +AC_CHECK_HEADERS([assert.h sys/stat.h]) +AC_LANG_PUSH(C++) +AC_CHECK_HEADERS([sstream]) +AC_LANG_POP(C++) +AC_HEADER_STAT AC_FUNC_MEMCMP AC_FUNC_VPRINTF -AC_CHECK_FUNCS(memmem snprintf vsnprintf gettext) +AC_CHECK_FUNCS([gettext isinf memmem snprintf vsnprintf gettext]) + +AC_MSG_CHECKING([for ec-fonts-mftraced]) +ecb10=`kpsewhich ecb10.pfa 2>/dev/null` +if test -n "$ecb10"; then + AC_MSG_RESULT([$ecb10]) +else + AC_MSG_RESULT(no) + AC_MSG_CHECKING([for lmodern]) + lmr10=`kpsewhich lmr10.pfb 2>/dev/null` + if test -n "$lmr10"; then + AC_MSG_RESULT([$lmr10]) + else + STEPMAKE_ADD_ENTRY(REQUIRED, 'package ec-fonts-mftraced >= 1.0.5') + AC_MSG_CHECKING([for old version of ec-fonts-mftraced]) + ecrm10=`kpsewhich ecrm10.pfa 2>/dev/null` + if test -n "$ecrm10"; then + AC_MSG_RESULT([$ecrm10]) + AC_MSG_WARN([old version of ec-fonts-mftraced found, install 1.0.5 or newer]) + fi + fi +fi + +if test "$gui_b" = "yes"; then + STEPMAKE_GTK2 +fi + +STEPMAKE_FREETYPE2 +STEPMAKE_PANGO_FT2 + +## Optional tools for building documentation, website, extra fonts. + +# guile executable for some scripts +STEPMAKE_GUILE(OPTIONAL) +# perl for help2man. +STEPMAKE_PERL(OPTIONAL) + + + +# New makeinfo for multi-page website docs Simply always require new +# makeinfo should avoid bug reports; if people want to build lily +# without the docs, they can find this comment and use an older +# makeinfo -- but hopefully won't report makeinfo problems. +STEPMAKE_PROGS(MAKEINFO, makeinfo, REQUIRED, 4.7) +AC_SUBST(MAKEINFO_VERSION) + + +if test "$optimise_b" = yes; then + DEFINES="$DEFINES -DSTRING_UTILS_INLINED" + AC_DEFINE(STRINGS_UTILS_INLINED) +fi AC_DEFINE_UNQUOTED(TOPLEVEL_VERSION, "${FULL_VERSION}") AC_DEFINE_UNQUOTED(FLOWER_VERSION, "${FULL_FLOWER_VERSION}") -AC_CHECK_PROGS(MAKEINFO, makeinfo, error) -AC_CHECK_SEARCH_RESULT($YODL2TEXINFO, yodl, - You should install Yodl 1.30.2 or newer) +# Gather requirements and generate output. +STEPMAKE_END + + +test -n "$CONFIGURATION" && mc=" conf=$CONFIGURATION" || mc="" + +cat <