X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=configure.ac;h=346c1d35b2a7827c9040362f02dd463120ed2555;hb=c235b9f0b14cdbd104a181c6a19b2e6c99a57d28;hp=6a71e8d5552eb1102337924962447a2c15dbe833;hpb=8638ee4569452ead96be5894fb7a2440bb532437;p=inkscape.git diff --git a/configure.ac b/configure.ac index 6a71e8d55..346c1d35b 100644 --- a/configure.ac +++ b/configure.ac @@ -1,7 +1,7 @@ dnl Process this file with autoconf to produce a configure script. AC_PREREQ(2.50) -AC_INIT(inkscape, 0.43+devel) +AC_INIT(inkscape, 0.45+devel) dnl N.B. After 0.40, please change to `0.40+cvs' instead of `0.41cvs'. dnl Rationale: (i) placate simple version comparison software such as dnl `dpkg --compare-versions'. (ii) We don't always know what the next @@ -11,10 +11,25 @@ AC_CANONICAL_HOST AC_CONFIG_SRCDIR(src/main.cpp) AM_INIT_AUTOMAKE +AC_ARG_ENABLE([lsb], AS_HELP_STRING([--enable-lsb], [LSB-compatible build configuration]), [ + prefix=/opt/inkscape + PATH="/opt/lsb/bin:$PATH" + CC=lsbcc + CXX=lsbc++ + export CC CXX +]) + AM_CONFIG_HEADER(config.h) AC_PROG_INTLTOOL(0.22) +AC_LANG(C++) +AC_ISC_POSIX +AC_PROG_CXX +AM_PROG_CC_STDC +AM_PROG_AS +AC_HEADER_STDC + dnl These next few lines are needed only while libcroco is in our source tree. AC_PROG_CC AM_PROG_CC_C_O @@ -27,28 +42,21 @@ if test "$GCC" = "yes"; then CFLAGS="-Wno-pointer-sign $CFLAGS" AC_COMPILE_IFELSE([int dummy; ], , CFLAGS="$ink_svd_CFLAGS",) - CFLAGS="-Wall -W $CFLAGS" + CFLAGS="-Wall -Wformat-security -W -D_FORTIFY_SOURCE=2 $CFLAGS" fi -AC_LANG(C++) -AC_ISC_POSIX -AC_PROG_CXX -AM_PROG_CC_STDC -AM_PROG_AS -AC_HEADER_STDC - dnl Honor aclocal flags ACLOCAL="$ACLOCAL $ACLOCAL_FLAGS" -dnl RANLIB is outdated now -dnl AC_PROG_RANLIB -AM_PROG_LIBTOOL +AC_PROG_RANLIB dnl Verify our GCC version if test "x$GXX" = "xyes"; then AC_MSG_CHECKING([GNU compiler version]) - cc_version=["`$CXX $CXXFLAGS -v 2>&1 &1 = 1.2 is needed to compile inkscape]) @@ -157,6 +168,10 @@ if test "x$gc_ok" != "xyes"; then AC_MSG_ERROR([libgc (the Boehm Conservative Collector) 6.4+, is needed to compile inkscape -- http://www.hpl.hp.com/personal/Hans_Boehm/gc]) fi +dnl This check is to get a FIONREAD definition on Solaris 8 +AC_CHECK_HEADERS([sys/filio.h]) + + AC_CHECK_HEADERS([malloc.h]) AC_CHECK_FUNCS([mallinfo], [ AC_CHECK_MEMBERS([struct mallinfo.usmblks, @@ -192,6 +207,20 @@ esac AC_MSG_RESULT([$platform_win32]) AM_CONDITIONAL(PLATFORM_WIN32, test "$platform_win32" = "yes") +AC_MSG_CHECKING([for Solaris 2.8 platform]) +case "$host" in + *-solaris2.8) + platform_solaris_2_8=yes + CFLAGS="$CFLAGS -DSOLARIS_2_8" + CXXFLAGS="$CXXFLAGS -DSOLARIS_2_8" + ;; + *) + platform_solaris_2_8=no + ;; +esac +AC_MSG_RESULT([$platform_solaris_2_8]) +AM_CONDITIONAL(PLATFORM_SOLARIS_2_8, test "$platform_solaris_2_8" = "yes") + dnl ****************************** dnl Xft checking dnl ****************************** @@ -342,7 +371,7 @@ dnl ****************************** AC_MSG_CHECKING(for Perl development environment) AC_ARG_WITH(perl, - AC_HELP_STRING([--with-perl], [use Perl for embedded scripting]), + AC_HELP_STRING([--with-perl], [use Perl for embedded scripting (EXPERIMENTAL)]), [with_perl=$withval], [with_perl=skipped]) if test "x$with_perl" = "xyes"; then @@ -350,7 +379,7 @@ if test "x$with_perl" = "xyes"; then if test "$?" -gt "0"; then with_perl="no" else - checkPERL_LDFLAGS=`perl -MExtUtils::Embed -e ldopts 2>/dev/null` + checkPERL_LIBS=`perl -MExtUtils::Embed -e ldopts 2>/dev/null` if test "$?" -gt "0"; then with_perl="no" else @@ -362,22 +391,22 @@ AC_MSG_RESULT([$with_perl]) if test "x$with_perl" = "xyes"; then # Test that we actually have the perl libraries installed oldCFLAGS="$CFLAGS" - oldLDFLAGS="$LDFLAGS" + oldLIBS="$LIBS" CFLAGS="$CFLAGS $checkPERL_CFLAGS" - LDFLAGS="$LDFLAGS $checkPERL_LDFLAGS" + LIBS="$LIBS $checkPERL_LIBS" AC_CHECK_FUNC([perl_parse],[ PERL_CFLAGS="$checkPERL_CFLAGS" - PERL_LDFLAGS="$checkPERL_LDFLAGS" + PERL_LIBS="$checkPERL_LIBS" AC_DEFINE(WITH_PERL, 1, [use Perl for embedded scripting]) ],[ with_perl="no" ]) CFLAGS="$oldCFLAGS" - LDFLAGS="$oldLDFLAGS" + LIBS="$oldLIBS" fi AM_CONDITIONAL(WITH_PERL, test "x$with_perl" = "xyes") AC_SUBST(PERL_CFLAGS) -AC_SUBST(PERL_LDFLAGS) +AC_SUBST(PERL_LIBS) dnl ****************************** dnl Python checking @@ -385,7 +414,7 @@ dnl ****************************** AC_MSG_CHECKING(for Python development environment) AC_ARG_WITH(python, - AC_HELP_STRING([--with-python], [use Python for embedded scripting]), + AC_HELP_STRING([--with-python], [use Python for embedded scripting (EXPERIMENTAL)]), [with_python=$withval], [with_python=skipped]) if test "x$with_python" = "xyes"; then @@ -393,7 +422,7 @@ if test "x$with_python" = "xyes"; then if test "$?" -gt "0"; then with_python="no" else - checkPYTHON_LIBS=`python -c "import distutils.sysconfig ; print '%s/%s %s' % (distutils.sysconfig.get_config_var('LIBPL'),distutils.sysconfig.get_config_var('LIBRARY'),distutils.sysconfig.get_config_var('LIBS'))" 2>/dev/null` + checkPYTHON_LIBS=`python -c "import distutils.sysconfig ; print '%s/%s %s' % (distutils.sysconfig.get_config_var('LIBPL'),distutils.sysconfig.get_config_var('LDLIBRARY'),distutils.sysconfig.get_config_var('LIBS'))" 2>/dev/null` if test "$?" -gt "0"; then with_python="no" else @@ -464,41 +493,55 @@ dnl Inkboard dependency checking dnl ****************************** with_inkboard="no" +with_inkboard_ssl="no" -AC_MSG_CHECKING(for loudmouth-1.0+) +INKBOARD_CFLAGS="" AC_ARG_ENABLE(inkboard, AS_HELP_STRING([--enable-inkboard], [enable Inkboard online whiteboard facility (disabled by default)]), with_inkboard=$enableval,with_inkboard=no) if test "x$with_inkboard" = "xyes"; then - PKG_CHECK_MODULES(LIBLOUDMOUTH, loudmouth-1.0, loudmouth_ok=yes, loudmouth_ok=no) - if test "x$loudmouth_ok" = "xyes"; then with_inkboard="yes" AC_DEFINE(WITH_INKBOARD,1,[Build in Inkboard support]) - else - with_inkboard="no" - fi + + dnl Test for OpenSSL + PKG_CHECK_MODULES(INKBOARD, openssl, with_inkboard_ssl=yes, with_inkboard_ssl=no) + if test "x$with_inkboard_ssl" = "xyes"; then + dnl OpenSSL found; enable SSL support in Pedro + INKBOARD_CFLAGS="$INKBOARD_CFLAGS -DHAVE_SSL" + RELAYTOOL([ssl], INKBOARD_LIBS, INKBOARD_CFLAGS, [inkboard_weak=yes]) + RELAYTOOL([crypto], INKBOARD_LIBS, INKBOARD_CFLAGS, [inkboard_weak=yes]) + AC_DEFINE(WITH_INKBOARD_SSL,1,[Build in SSL support for Inkboard]) + fi else with_inkboard="no" fi -AC_MSG_RESULT($with_inkboard) AM_CONDITIONAL(WITH_INKBOARD, test "x$with_inkboard" = "xyes") -AC_SUBST(LIBLOUDMOUTH_CFLAGS) -AC_SUBST(LIBLOUDMOUTH_LIBS) +AC_SUBST(INKBOARD_LIBS) +AC_SUBST(INKBOARD_CFLAGS) dnl ****************************** dnl Unconditional dependencies dnl ****************************** -dnl *** NOTE: when we move to gtk 2.6 or later, we can remove the -dnl ********* the override for g_ascii_strtod below... dnl sigc++-2.0 >= 2.0.12: using "visit_each" not available in 2.0.10 if test $cc_vers_major -gt 3; then - PKG_CHECK_MODULES(INKSCAPE, gdkmm-2.4 glibmm-2.4 gtkmm-2.4 gtk+-2.0 >= 2.4.0 libxml-2.0 >= 2.6.11 libxslt >= 1.0.15 sigc++-2.0 >= 2.0.12 $ink_spell_pkg gthread-2.0 >= 2.0) + min_sigc_version=2.0.12 else - PKG_CHECK_MODULES(INKSCAPE, gdkmm-2.4 glibmm-2.4 gtkmm-2.4 gtk+-2.0 >= 2.4.0 libxml-2.0 >= 2.6.11 libxslt >= 1.0.15 sigc++-2.0 >= 2.0.11 $ink_spell_pkg gthread-2.0 >= 2.0) + min_sigc_version=2.0.11 +fi +PKG_CHECK_MODULES(INKSCAPE, gdkmm-2.4 glibmm-2.4 gtkmm-2.4 gtk+-2.0 >= 2.8.0 libxml-2.0 >= 2.6.11 libxslt >= 1.0.15 cairo sigc++-2.0 >= $min_sigc_version $ink_spell_pkg gthread-2.0 >= 2.0 libpng >= 1.2) + +PKG_CHECK_MODULES(CAIRO_PDF, cairo-pdf, cairo_pdf=yes, cairo_pdf=no) +if test "x$cairo_pdf" = "xyes"; then + AC_DEFINE(HAVE_CAIRO_PDF, 1, [Whether the Cairo PDF backend is available]) +fi + +PKG_CHECK_MODULES(GTK_UNIX_PRINT, gtk+-unix-print-2.0, gtk_unix_print=yes, gtk_unix_print=no) +if test "x$gtk_unix_print" = "xyes"; then + AC_DEFINE(HAVE_GTK_UNIX_PRINT, 1, [Whether the GTK Unix printing backend is available]) fi dnl Shouldn't we test for libpng and libz? @@ -579,13 +622,6 @@ if test "$enable_osxapp" = "yes"; then AC_DEFINE(ENABLE_OSX_APP_LOCATIONS,,[Build with OSX .app data dir paths?]) fi -dnl ****************************** -dnl Boost graph library is required for graphlayout functions -dnl ****************************** -AC_CHECK_HEADER([boost/graph/adjacency_list.hpp], - [AC_DEFINE([HAVE_BOOST_GRAPH_LIB],[],[Will enable connector network layout])], - [AC_MSG_WARN([Boost graph lib not found, can't include connector network layout functionality.])]) - dnl ****************************** dnl Reported by autoscan dnl ****************************** @@ -654,7 +690,7 @@ if test "$GXX" = "yes"; then # programmer deliberately has an unused parameter (e.g. because it's used # as a callback or similar function pointer use). - CXXFLAGS="-Wall -W -Wpointer-arith -Wcast-align -Wsign-compare -Woverloaded-virtual -Wswitch $CXXFLAGS" + CXXFLAGS="-Wall -Wformat-security -W -Wpointer-arith -Wcast-align -Wsign-compare -Woverloaded-virtual -Wswitch -D_FORTIFY_SOURCE=2 $CXXFLAGS" dnl Test for arch-specific situations. case "$host_cpu" in @@ -667,19 +703,6 @@ if test "$GXX" = "yes"; then esac fi -dnl ****************************** -dnl Plugin Support -dnl ****************************** -dnl -dnl UPDATE: This is unconditional now (Lauris) -dnl -dnl AC_ARG_WITH(modules, AC_HELP_STRING([--with-modules], [Compile with plugin support (experimental)]), [mod=$withval], [mod=yes]) -dnl -dnl AM_CONDITIONAL(USE_MODULES, test "x$mod" = "xyes") -dnl if test "x$mod" = "xyes"; then -dnl AC_DEFINE(WITH_MODULES, 1, [Use experimental module support]) -dnl fi - AC_DEFINE(WITH_MODULES, 1, [Use experimental module support]) dnl ****************************** @@ -749,19 +772,18 @@ fi AM_CONDITIONAL(USE_MMX, test x$use_mmx_asm = xyes) -dnl Override the default g_ascii_strtod -AC_DEFINE(g_ascii_strtod, fixed_g_ascii_strtod, [Pre-1.107 gstrfuncs.c version of g_ascii_strtod is broken]) - dnl Figure out where the datadir actually is -if test "x${datadir}" = 'x${prefix}/share'; then - if test "x${prefix}" = "xNONE"; then - runtime_datadir="${ac_default_prefix}/share" - else - runtime_datadir="${prefix}/share" - fi -else - runtime_datadir="${datadir}" -fi +dnl http://autoconf-archive.cryp.to/ac_define_dir.html +prefix_NONE= +exec_prefix_NONE= +test "x$prefix" = xNONE && prefix_NONE=yes && prefix=$ac_default_prefix +test "x$exec_prefix" = xNONE && exec_prefix_NONE=yes && exec_prefix=$prefix +dnl In Autoconf 2.60, ${datadir} refers to ${datarootdir}, which in turn +dnl refers to ${prefix}. Thus we have to use `eval' twice. +eval runtime_datadir="${datadir}" +eval runtime_datadir="${runtime_datadir}" +test "$prefix_NONE" && prefix=NONE +test "$exec_prefix_NONE" && exec_prefix=NONE inkscape_sharedir="${runtime_datadir}/${PACKAGE_NAME}" @@ -791,7 +813,6 @@ src/dom/makefile src/extension/implementation/makefile src/extension/internal/makefile src/extension/makefile -src/extension/plugin/makefile src/extension/script/makefile src/helper/makefile src/inkjar/makefile @@ -801,11 +822,13 @@ src/libnr/makefile src/libnrtype/makefile src/libavoid/makefile src/livarot/makefile +src/pedro/makefile src/jabber_whiteboard/makefile src/removeoverlap/makefile src/svg/makefile src/trace/makefile src/traits/makefile +src/ui/cache/makefile src/ui/dialog/makefile src/ui/makefile src/ui/view/makefile @@ -856,10 +879,13 @@ Configuration: LDFLAGS: ${LDFLAGS} Use Xft font database: ${xft_ok} - Use gnome-vfs: ${gnome_vfs} + Use gnome-vfs: ${gnome_vfs} Use openoffice files: ${ij} Use MMX optimizations: ${use_mmx_asm} Use relocation support: ${enable_binreloc} - Enable LittleCms: ${enable_lcms} - Enable Inkboard: ${with_inkboard} + Internal Python: ${with_python} + Internal Perl: ${with_perl} + Enable LittleCms: ${enable_lcms} + Enable Inkboard: ${with_inkboard} + Enable SSL in Inkboard: ${with_inkboard_ssl} "