X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=configure.in;h=a7e1bdf6ae946612daa9d32577db97bfddab39ad;hb=4f816fd13b3388b22a2f73ccfb2a369aa9dd2b3f;hp=36682055eca6087169d4df1a59b8bf815b84f80b;hpb=1d00ad9765ae80f0bde9c0d4b1338545e44ead11;p=lyx.git diff --git a/configure.in b/configure.in index 36682055ec..a7e1bdf6ae 100644 --- a/configure.in +++ b/configure.in @@ -1,6 +1,6 @@ dnl Process with autoconf to generate configure script -*- sh -*- -AC_INIT(src/lyx.C) +AC_INIT(src/main.C) AC_PREREQ(2.13) dnl We want to use autoconf 2.13 AM_CONFIG_HEADER(src/config.h) dnl This is a trick to make autoheader do the right thing @@ -11,11 +11,13 @@ LYX_GET_VERSION(${srcdir}/src/version.h) AC_CANONICAL_SYSTEM AC_VALIDATE_CACHE_SYSTEM_TYPE -AM_INIT_AUTOMAKE(lyx, $VERSION) +LYX_VERSION_SUFFIX + +AM_INIT_AUTOMAKE($lyxname, $VERSION) # The list of languages known to LyX # This is needed by GNU gettext -ALL_LINGUAS="ca cs da de es fi fr hu it nl no pl pt ru sl sv tr wa" +ALL_LINGUAS="ca cs da de es eu fi fr he hu it nl no pl pt ro ru sl sv tr wa" AC_PREFIX_PROGRAM(lyx) @@ -24,8 +26,7 @@ test "x$prefix" = xNONE && prefix=$ac_default_prefix test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' ### Set the execute permissions of the various scripts correctly -for file in config/install-sh config/mkinstalldirs config/hack-gcc \ - lib/configure ; do +for file in config/install-sh config/mkinstalldirs lib/configure ; do chmod 755 ${srcdir}/${file} done @@ -39,6 +40,12 @@ if test "x$KPSEWHICH" = xkpsewhich ; then [Define this if you have the kpsewhich program working on your system.]) fi +# Work around a problem in automake 1.4: when invoking install-strip, +# INSTALL_PROGRAM is changed to 'install -s', and since +# INSTALL_SCRIPT==INSTALL_PROGRAM, we get errors with fileutils-4.0 +# which returns an error condition when stripping fails. +INSTALL_SCRIPT='${INSTALL}' + ### we will also need a C compiler to compile GNU gettext AC_PROG_CC @@ -52,44 +59,53 @@ LYX_SCO ### Check for program extensions (.exe or nothing) AC_EXEEXT +### check which frontend we want to use +LYX_USE_FRONTEND +dnl The code below is not in a macro, because this would cause big +dnl problems with the AC_REQUIRE contained in KDE_DO_IT_ALL. +case "$lyx_use_frontend" in + gnome) + GNOME_INIT + GNOME_COMPILE_WARNINGS + GNOME_X_CHECKS +esac + ### Check for a C++ compiler AC_LANG_CPLUSPLUS LYX_PROG_CXX AC_PROG_CXXCPP AC_DISABLE_SHARED AC_LIBTOOL_WIN32_DLL -AM_PROG_LIBTOOL +#AM_PROG_LIBTOOL +LYX_PROG_LIBTOOL -### check the size of pointers and ints -# the defaults are given for cross compilation. +### Some checks on what the C++ compiler can(not) do LYX_CXX_MUTABLE LYX_CXX_PARTIAL LYX_CXX_EXPLICIT -LYX_CXX_STL_STACK +dnl we do not use stl stack, or at least not on gcc 2.7, which was the +dnl cause for this test. +dnl LYX_CXX_STL_STACK LYX_CXX_STL_STRING +LYX_CXX_GOOD_STD_STRING LYX_CXX_NAMESPACES LYX_CXX_CHEADERS +LYX_CXX_GLOBAL_CSTD +LYX_STD_COUNT dnl we disable rtti for now dnl LYX_CXX_RTTI -AC_CHECK_HEADERS(ostream istream) +AC_CHECK_HEADERS(ostream istream sstream locale limits) LYX_CXX_STL_MODERN_STREAMS +### We need a regex implementation, so we provide our own if none is found. +LYX_REGEX + ### Library Files dnl by testing these we check if it is ok to have dnl -lc and -lm as args to the compiler AC_CHECK_LIB(m, sin) AC_CHECK_LIB(c, fopen) -# A hack to work around gcc compiler errors -AC_ARG_WITH(gcc-hack,[ --with-gcc-hack add a wrapper around gcc]) -if test "x$with_gcc_hack" = xyes ; then - CXX_COMMAND='${top_srcdir}/config/hack-gcc ${CXX}' - lyx_flags="$lyx_flags gcc-hack" -else - CXX_COMMAND='${CXX}' -fi -AC_SUBST(CXX_COMMAND) - ### Add extra directories to check for libraries. LYX_WITH_DIR([extra-lib],[extra library directory],extra_lib, NONE) LYX_LOOP_DIR($lyx_cv_extra_lib,LYX_ADD_LIB_DIR(lyx_ldflags,$dir)) @@ -116,17 +132,73 @@ if test x$lyx_use_liberty = xyes; then AC_CHECK_LIB(iberty,main) fi +### Check which libsigc++ we're using +LYX_WITH_SIGC + +### Check if we want pspell libraries +CHECK_WITH_PSPELL + ### Check for X libraries # Check for the pt library (for SCO, needed for X) AC_CHECK_LIB(pt,ptsname,X_EXTRA_LIBS="-lpt $X_EXTRA_LIBS") # The real thing. AC_PATH_XTRA LIBS="$X_PRE_LIBS $LIBS $X_LIBS -lX11 $X_EXTRA_LIBS" +# Since solaris X headers use int as implicit return type and modern +# gcc's do not like that, let's use -isystem instead of -I. +# We should test for gcc version and see whether it supports -isystem, +# but since at least gcc 2.6.x supports it and it is still too old for +# us, it seems we are safe. +if test -n "$GXX" ; then + X_CFLAGS=`echo ${X_CFLAGS} | sed -e 's/-I/-isystem /'` +fi CPPFLAGS="$CPPFLAGS $X_CFLAGS" ## Check whether X is new enough to handle the input method stuff AC_CHECK_FUNCS(XOpenIM) +### check which frontend we want to use +#LYX_USE_FRONTEND +dnl The code below is not in a macro, because this would cause big +dnl problems with the AC_REQUIRE contained in KDE_DO_IT_ALL. +case "$lyx_use_frontend" in + xforms) + # for now don't set it for xforms as this is always entered + FRONTEND="" + FRONTEND_GUILIB="xforms/libxforms.la";; + gnome) + AM_PATH_GTKMM(1.2.1,, + AC_MSG_ERROR(Cannot find GTK--: Please install Version 1.2.1+)) + AM_PATH_GNOMEMM + +dnl ****************************** +dnl LibGlade checking +dnl ****************************** +dnl Ensure gnome-config is available... + AC_PATH_PROG(GNOME_CONFIG, gnome-config, no) + AC_MSG_CHECKING(for Glade libraries) + if $GNOME_CONFIG --libs libglade > /dev/null 2>&1; then + AC_MSG_RESULT(found) + else + AC_MSG_ERROR(Did not find libGlade installed) + fi + + FRONTEND="gnome" + FRONTEND_GUILIB="gnome/libgnome.la" + FRONTEND_LDFLAGS="\$(GNOMEMM_LIBDIR)" + FRONTEND_INCLUDES="-I\${srcdir}/gnome \$(GNOMEMM_INCLUDEDIR) \$(GTKMM_CFLAGS)" + FRONTEND_LIBS="\$(GNOMEMM_LIBS) \$(GTKMM_LIBS) `gnome-config --libs libglade`";; + qt2) + QT2_DO_IT_ALL + FRONTEND="qt2" + FRONTEND_GUILIB="qt2/libqt2.la" + FRONTEND_LDFLAGS="\$(QT2_LDFLAGS)" + FRONTEND_INCLUDES="-I\${srcdir}/qt2 \$(QT2_INCLUDES)" + FRONTEND_LIBS="\$(QT2_LIBS)";; + *) + LYX_ERROR(Unknown frontend $lyx_use_frontend);; +esac + ### Check for xforms and xpm (only if X has been found). if test "$have_x" = yes ; then # We surely need these two libraries and want to check carefully the @@ -141,7 +213,6 @@ LYX_ERROR(dnl the development tools.]) fi - ### Setup GNU gettext dnl GNU gettext is written in C AC_LANG_C @@ -162,7 +233,11 @@ AC_LANG_CPLUSPLUS # some standard header files AC_HEADER_DIRENT AC_HEADER_MAJOR -AC_CHECK_HEADERS(sys/time.h sys/types.h sys/select.h) +AC_CHECK_HEADERS(sys/time.h sys/types.h sys/select.h strings.h) + +# some annoying header files +#LYX_PATH_HEADER(stl_string_fwd.h) +LYX_STL_STRING_FWD # some standard structures AC_HEADER_STAT @@ -181,41 +256,66 @@ AC_TYPE_UID_T # some functions we'd like to have AC_ARG_WITH(broken-headers, - [ --with-broken-headers define some functions on SunOS4 and SCO], + [ --with-broken-headers define some functions on SunOS4 and SCO], [lyx_broken_headers=$withval]) if test "x$lyx_broken_headers" = "xyes"; then lyx_flags="$lyx_flags broken-headers" AC_DEFINE(BROKEN_HEADERS, 1, [Define on SunOS 4 and SCO, were some functions are missing from the headers]) fi -AC_CHECK_FUNCS(memmove memset strchr putenv setenv mkfifo) +AC_CHECK_FUNCS(snprintf vsnprintf) +LYX_CHECK_DECL(snprintf, stdio.h) +LYX_CHECK_DECL(vsnprintf, stdio.h) +LYX_CHECK_DECL(istreambuf_iterator, iterator) + +AC_CHECK_FUNCS(memmove memset strchr putenv setenv mkfifo \ + mkstemp mktemp) dnl Until this is fixed in autoconf we provide our own version LYX_FUNC_SELECT_ARGTYPES +dnl check whether we have to work around solaris broken putenv() +LYX_FUNC_PUTENV_ARGTYPE + # SunOS 4.1.3 does not have strerror and atexit AC_REPLACE_FUNCS(strerror atexit) +LYX_CHECK_DECL_HDRS(mkstemp,[unistd.h stdlib.h]) + ### and now some special lyx flags. -AC_ARG_WITH(two-colors,[ --with-two-colors use two color pixmaps], - [AC_DEFINE(TWO_COLOR_ICONS) - lyx_flags="$lyx_flags two-colors"]) -AC_ARG_WITH(debug,[ --with-debug output debug information by default], - [AC_DEFINE(DEBUG_AS_DEFAULT,1, - [Define if you want debugging turned on as default.]) - lyx_flags="$lyx_flags debug"]) +AC_ARG_ENABLE(assertions, + [ --enable-assertions add runtime sanity checks in the program],, + [if test $lyx_devel_version = yes -o $lyx_prerelease = yes ; then + enable_assertions=yes; + else + enable_assertions=no; + fi;]) +if test "x$enable_assertions" = xyes ; then + lyx_flags="$lyx_flags assertions" + AC_DEFINE(ENABLE_ASSERTIONS,1, + [Define if you want assertions to be enabled in the code]) +fi ### Finish the work. -AC_CONFIG_SUBDIRS(lib lib/reLyX) +AC_CONFIG_SUBDIRS(sigc++ lib lib/reLyX) AC_OUTPUT([Makefile \ + boost/Makefile \ development/lyx.spec \ lib/Makefile \ intl/Makefile \ po/Makefile.in \ + sourcedoc/Doxyfile \ src/Makefile \ src/mathed/Makefile \ + src/graphics/Makefile \ src/insets/Makefile \ src/support/Makefile \ + src/frontends/Makefile \ + src/frontends/support/Makefile \ + src/frontends/controllers/Makefile \ + src/frontends/xforms/Makefile \ + src/frontends/qt2/Makefile \ + src/frontends/gnome/Makefile \ ], [sed -e "/POTFILES =/r po/POTFILES" po/Makefile.in > po/Makefile]) @@ -235,4 +335,3 @@ EOF # Display a final warning if there has been a LYX_ERROR LYX_CHECK_ERRORS -