X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=configure.ac;h=6d854b9f2ab6fde825a2d9359ddc5b123c42ae72;hb=ff1ebed78f259fd9f0797d8ec95e311ca1e034b8;hp=9d1b05738322830476883f665df51f0f601e66b6;hpb=2f5de1ff97311ede363f12f7a6c9d518c7d8d6a5;p=lyx.git diff --git a/configure.ac b/configure.ac index 9d1b057383..6d854b9f2a 100644 --- a/configure.ac +++ b/configure.ac @@ -1,6 +1,7 @@ dnl Process with autoconf to generate configure script -*- sh -*- -AC_INIT(LyX,1.4.0cvs,[lyx-devel@lists.lyx.org],[lyx]) +AC_INIT(LyX,1.5.0svn,[lyx-devel@lists.lyx.org],[lyx]) +AC_SUBST(LYX_DATE, ["Wed, Nov 15, 2006"]) AC_PREREQ(2.52) AC_CONFIG_SRCDIR(src/main.C) AC_CONFIG_HEADERS([src/config.h]) @@ -9,11 +10,13 @@ AC_CONFIG_AUX_DIR(config) # First check the version LYX_CHECK_VERSION -AC_CANONICAL_TARGET - +LYX_VERSION_SUFFIX # Check how the files should be packaged +AC_CANONICAL_TARGET LYX_USE_PACKAGING -LYX_VERSION_SUFFIX +# We need to define these variables here and the no-define option of +# AM_INIT_AUTOMAKE above because we alter $PACKAGE in LYX_USE_PACKAGING. +AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) dnl default maintainer mode to true for development versions if test "${enable_maintainer_mode+set}" != set; then @@ -21,10 +24,12 @@ if test "${enable_maintainer_mode+set}" != set; then fi AM_MAINTAINER_MODE -AM_INIT_AUTOMAKE([foreign dist-bzip2 tar-ustar]) +save_PACKAGE=$PACKAGE +AM_INIT_AUTOMAKE([foreign dist-bzip2 tar-ustar no-define 1.9]) +PACKAGE=$save_PACKAGE ### Set the execute permissions of the various scripts correctly -for file in config/install-sh config/mkinstalldirs lib/configure ; do +for file in config/install-sh config/mkinstalldirs ; do chmod 755 ${srcdir}/${file} done @@ -44,7 +49,7 @@ fi AC_CHECK_PROGS(M4, gm4 gnum4 m4, m4) # Check for installed python -AM_PATH_PYTHON(1.5.2,, :) +AM_PATH_PYTHON(2.3,, :) # Work around a problem in automake 1.4: when invoking install-strip, # INSTALL_PROGRAM is changed to 'install -s', and since @@ -59,6 +64,9 @@ AC_PROG_CC AC_ISC_POSIX AC_AIX +### we need to know the byte order for unicode conversions +AC_C_BIGENDIAN + ### check which frontend we want to use LYX_USE_FRONTENDS @@ -113,6 +121,11 @@ LYX_LOOP_DIR($lyx_cv_extra_prefix,[ LYX_ADD_INC_DIR(CPPFLAGS,$dir/include) LYX_ADD_LIB_DIR(LDFLAGS,$dir/lib)]) +### These are needed in windows +AC_CHECK_LIB(shlwapi, main, [LIBSHLWAPI=-lshlwapi]) +AC_SUBST(LIBSHLWAPI) +AC_CHECK_LIB(gdi32, main) + AC_ARG_WITH(aiksaurus, [ --without-aiksaurus do not use the Aiksaurus library], [lyx_use_aiksaurus=$withval]) @@ -134,15 +147,20 @@ AC_SUBST(AIKSAURUS_LIBS) LYX_USE_INCLUDED_BOOST +# Needed for our char_type +AC_CHECK_SIZEOF(wchar_t) + ### Setup libtool +dnl Dirty trick ahead: disable libtool checking for a fortran compiler +dnl see http://permalink.gmane.org/gmane.comp.gnu.libtool.general/6699 +dnl Note that this will reportedly not be needed with libtool 2.0 +m4_undefine([AC_PROG_F77]) +m4_defun([AC_PROG_F77],[]) AC_DISABLE_SHARED AC_LIBTOOL_WIN32_DLL #AM_PROG_LIBTOOL LYX_PROG_LIBTOOL -### Check for some Cygwin-specific details. -CHECK_WITH_CYGWIN - ### Check for X libraries AC_PATH_XTRA case $have_x in @@ -157,58 +175,27 @@ esac ### check which frontend we want to use -dnl if the gtk frontend has been specified, then xforms is needed too -if echo $FRONTENDS | grep gtk | grep -v xforms ; then - FRONTENDS="xforms $FRONTENDS" - noxformsbin=yes -fi - dnl The code below is not in a macro, because this would cause big dnl problems with the AC_REQUIRE contained in QT_DO_IT_ALL. for frontend in $FRONTENDS ; do case "$frontend" in - xforms) - XFORMS_DO_IT_ALL - if test -z "$noxformsbin" ; then - FRONTENDS_PROGS="$FRONTENDS_PROGS lyx-xforms\$(EXEEXT)" - fi - FRONTENDS_SUBDIRS="$FRONTENDS_SUBDIRS xforms" - RPM_FRONTEND="xforms" - FRONTEND_INFO="${FRONTEND_INFO}\ - XForms Frontend:\n\ - libXpm version:\t\t${XPM_VERSION}\n\ - libforms version:\t\t${XFORMS_VERSION}\n" - ;; - gtk) - PKG_CHECK_MODULES(GTK_FRONTEND, gtkmm-2.4 libglademm-2.4 xft) - FRONTENDS_PROGS="$FRONTENDS_PROGS lyx-gtk\$(EXEEXT)" - FRONTENDS_SUBDIRS="$FRONTENDS_SUBDIRS gtk" - RPM_FRONTEND="gtk" - GTKMM_VERSION=`pkg-config --modversion gtkmm-2.4` - LIBGLADEMM_VERSION=`pkg-config --modversion libglademm-2.4` - FRONTEND_INFO="${FRONTEND_INFO}\ - GTK Frontend:\n\ - libgtkmm version:\t\t${GTKMM_VERSION}\n\ - libglademm version:\t\t${LIBGLADEMM_VERSION}\n" - ;; - - qt) - QT_DO_IT_ALL - FRONTENDS_PROGS="$FRONTENDS_PROGS lyx-qt\$(EXEEXT)" - FRONTENDS_SUBDIRS="$FRONTENDS_SUBDIRS qt2" - RPM_FRONTEND="qt" + qt4) + QT4_DO_IT_ALL + FRONTENDS_PROGS="$FRONTENDS_PROGS lyx-qt4\$(EXEEXT)" + FRONTENDS_SUBDIRS="$FRONTENDS_SUBDIRS qt4" + RPM_FRONTEND="qt4" FRONTEND_INFO="${FRONTEND_INFO}\ - Qt Frontend:\n\ - Qt version:\t\t${QT_VERSION}\n" -dnl qt build will fail without moc or uic - if test -z "$MOC"; then - LYX_ERROR([moc binary not found !]) + Qt 4 Frontend:\n\ + Qt 4 version:\t\t${QT4_VERSION}\n" +dnl qt 4 build will fail without moc or uic + if test -z "$MOC4"; then + LYX_ERROR([moc 4 binary not found !]) fi - if test -z "$UIC"; then - LYX_ERROR([uic binary not found !]) + if test -z "$UIC4"; then + LYX_ERROR([uic 4 binary not found !]) fi - if test -z "$QT_LIB"; then - LYX_ERROR([qt library not found !]) + if test -z "$QT4_LIB"; then + LYX_ERROR([qt 4 library not found !]) fi ;; *) @@ -227,6 +214,12 @@ if echo $prefix |grep ' ' >/dev/null 2>/dev/null ; then prefix=`pwd`/installprefix fi +### We need iconv for unicode support +AM_ICONV +if test "$am_cv_func_iconv" = no; then + LYX_ERROR([Cannot find required library iconv]) +fi + ### Setup GNU gettext dnl GNU gettext is written in C AC_LANG_PUSH(C) @@ -243,7 +236,7 @@ AC_HEADER_STAT AC_HEADER_TIME # some standard types -AC_TYPE_MODE_T +AC_CHECK_TYPE(mode_t,[AC_DEFINE(HAVE_MODE_T, 1, [Define this to 1 if your compiler supports the mode_t type.])]) AC_TYPE_OFF_T AC_TYPE_PID_T AC_TYPE_SIGNAL @@ -257,32 +250,17 @@ LYX_CHECK_DECL(mkstemp,[unistd.h stdlib.h]) # Check the form of mkdir() AC_FUNC_MKDIR -AC_ARG_ENABLE(compression-support, AC_HELP_STRING([--enable-compression-support],[Support for compressed files.]),[ - case "${enableval}" in - yes) use_compression=true ;; - no) use_compression=false ;; - *) AC_MSG_ERROR(bad value ${enableval} for --enable-compression-support) ;; - esac -],[use_compression=true]) -if test $use_compression=true ; then - AC_CHECK_HEADERS(zlib.h, use_compression=true, use_compression=false) - AC_CHECK_LIB(z, gzopen,[use_compression=true;LIBS="$LIBS -lz"], use_compression=false) - if test $use_compression = true ; then - AC_DEFINE(USE_COMPRESSION, 1, [Define as 1 if you want to support compressed files.]) - lyx_flags="compression $lyx_flags" - fi -fi -AM_CONDITIONAL(USE_COMPRESSION, test x$use_compression = xtrue) -AC_MSG_CHECKING([whether to support compressed files]) -AC_MSG_RESULT($use_compression) - +# check for compression support +AC_CHECK_HEADERS(zlib.h, + [AC_CHECK_LIB(z, gzopen, [LIBS="$LIBS -lz"], LYX_LIB_ERROR(libz,zlib))], + [LYX_LIB_ERROR(zlib.h,zlib)]) dnl This is a slight hack: the tests generated by autoconf 2.52 do not dnl work correctly because of some conflict with stdlib.h with g++ 2.96 dnl We aim to remove this eventually, since we should test as much as dnl possible with the compiler which will use the functions (JMarc) AC_LANG_PUSH(C) -AC_CHECK_FUNCS(close _close getpid _getpid lstat mkfifo mkstemp mktemp open _open pclose _pclose popen _popen readlink) +AC_CHECK_FUNCS(chmod close _close getpid _getpid lstat mkfifo mkstemp mktemp open _open pclose _pclose popen _popen readlink) AC_LANG_POP(C) LYX_CHECK_SPELL_ENGINES @@ -294,9 +272,9 @@ save_LIBS="$LIBS" LIBS= AC_CHECK_FUNCS(fcntl, [AC_SEARCH_LIBS([gethostbyname], [nsl]) - AC_SEARCH_LIBS([socket], [socket], [], + AC_SEARCH_LIBS([socket], [socket], [], [AC_CHECK_LIB([socket], [socket], [LIBS="-lsocket -lnsl $LIBS"], - [], [-lnsl])])], + [], [-lnsl])])], [lyx_client_subdir=false]) AC_SUBST(SOCKET_LIBS,$LIBS) LIBS="$save_LIBS" @@ -307,7 +285,8 @@ AC_FUNC_SELECT_ARGTYPES ### Some information on what just happened real_bindir=`eval "echo \`eval \"echo ${bindir}\"\`"` -real_datadir=`eval "echo \`eval \"echo ${datadir}/${PACKAGE}\"\`"` +real_pkgdatadir=`eval "echo \`eval \"echo \\\`eval \\\"echo ${pkgdatadir}\\\"\\\`\"\`"` +real_localedir=`eval "echo \`eval \"echo ${datadir}/locale\"\`"` VERSION_INFO="Configuration\n\ Host type: ${host}\n\ Special build flags: ${lyx_flags}\n\ @@ -322,12 +301,11 @@ VERSION_INFO="Configuration\n\ ${FRONTEND_INFO}\ Packaging: ${lyx_use_packaging}\n\ LyX binary dir: ${real_bindir}\n\ - LyX files dir: ${real_datadir}\n" + LyX files dir: ${real_pkgdatadir}\n" -real_localedir=`eval "echo \`eval \"echo ${datadir}/locale\"\`"` MSYS_AC_CANONICAL_PATH(LYX_ABS_TOP_SRCDIR, ${srcdir}) MSYS_AC_CANONICAL_PATH(LYX_ABS_INSTALLED_LOCALEDIR, ${real_localedir}) -MSYS_AC_CANONICAL_PATH(LYX_ABS_INSTALLED_DATADIR, ${real_datadir}) +MSYS_AC_CANONICAL_PATH(LYX_ABS_INSTALLED_DATADIR, ${real_pkgdatadir}) AC_SUBST(VERSION_INFO) AC_SUBST(RPM_FRONTEND) @@ -378,46 +356,48 @@ int mkstemp(char*); #endif #endif -#ifdef __EMX__ -#include "support/os2_defines.h" -#endif - #if defined(HAVE_OSTREAM) && defined(HAVE_LOCALE) && defined(HAVE_SSTREAM) -#define USE_BOOST_FORMAT 1 +# define USE_BOOST_FORMAT 1 #else -#define USE_BOOST_FORMAT 0 +# define USE_BOOST_FORMAT 0 #endif #define BOOST_USER_CONFIG -#if defined(ENABLE_ASSERTIONS) -#define BOOST_ENABLE_ASSERT_HANDLER 1 -#else -#define BOOST_DISABLE_ASSERTS 1 +#if !defined(ENABLE_ASSERTIONS) +# define BOOST_DISABLE_ASSERTS 1 #endif +#define BOOST_ENABLE_ASSERT_HANDLER 1 #define BOOST_DISABLE_THREADS 1 #define BOOST_NO_WREGEX 1 #define BOOST_NO_WSTRING 1 #ifdef __CYGWIN__ -#define BOOST_POSIX 1 +# define BOOST_POSIX 1 +# define BOOST_POSIX_API 1 +# define BOOST_POSIX_PATH 1 #endif #if defined(HAVE_NEWAPIS_H) -#define WANT_GETFILEATTRIBUTESEX_WRAPPER 1 +# define WANT_GETFILEATTRIBUTESEX_WRAPPER 1 +#endif + +#if defined(HAVE_WCHAR_T) && SIZEOF_WCHAR_T == 4 +# define LIBC_WCTYPE_USES_UCS4 #endif #endif ]) ### Finish the work. -AC_CONFIG_SUBDIRS(lib) AC_CONFIG_FILES([Makefile m4/Makefile \ boost/Makefile \ boost/libs/Makefile \ boost/libs/filesystem/Makefile \ boost/libs/filesystem/src/Makefile \ + boost/libs/iostreams/Makefile \ + boost/libs/iostreams/src/Makefile \ boost/libs/regex/Makefile \ boost/libs/regex/src/Makefile \ boost/libs/signals/Makefile \ @@ -427,6 +407,7 @@ AC_CONFIG_FILES([Makefile m4/Makefile \ development/lyx.spec \ lib/Makefile \ lib/doc/Makefile \ + lib/lyx2lyx/lyx2lyx_version.py \ lib/lyx2lyx/Makefile \ intl/Makefile \ po/Makefile.in \ @@ -443,17 +424,9 @@ AC_CONFIG_FILES([Makefile m4/Makefile \ src/support/tests/Makefile \ src/frontends/Makefile \ src/frontends/controllers/Makefile \ - src/frontends/xforms/Makefile \ - src/frontends/xforms/lyx_forms.h-tmp:src/frontends/xforms/lyx_forms.h.in \ - src/frontends/xforms/lyx_xpm.h-tmp:src/frontends/xforms/lyx_xpm.h.in \ - src/frontends/xforms/forms/Makefile \ - src/frontends/gtk/Makefile \ - src/frontends/gtk/gimages/Makefile \ - src/frontends/gtk/glade/Makefile \ - src/frontends/qt2/Makefile \ - src/frontends/qt2/moc/Makefile \ - src/frontends/qt2/ui/Makefile \ - src/frontends/qt2/ui/moc/Makefile \ + src/frontends/controllers/tests/Makefile \ + src/frontends/qt4/Makefile \ + src/frontends/qt4/ui/Makefile \ ]) AC_OUTPUT