X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=configure.ac;h=3c82a6019b9c7fdf6df24549de0f059ec89b210e;hp=8ae485f8ae6654aaa0d84b4314b86ce05c2d0b76;hb=6255ab89afea92ce0b2e911b4cbdd49c070ad890;hpb=b3cfd0b525b3b20cec49d7a399ae040bc056f72e diff --git a/configure.ac b/configure.ac index 8ae485f..3c82a60 100644 --- a/configure.ac +++ b/configure.ac @@ -26,17 +26,12 @@ # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -AC_INIT([modest],[0.0.1],[http://maemo.org]) +AC_INIT([modest],[1.0],[http://maemo.org]) AC_CONFIG_HEADERS([config.h]) AC_CONFIG_SRCDIR(src/modest-main.c) AM_INIT_AUTOMAKE([dist-bzip2]) -# Check for gettext support -GETTEXT_PACKAGE=modest -AC_SUBST(GETTEXT_PACKAGE) -AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE", ["Description"]) - ALL_LINGUAS="en_GB" MODEST_LOCALE_DIR='$prefix/${DATADIRNAME}/locale' @@ -51,6 +46,7 @@ fi AC_SUBST(prefix) AC_PROG_CC +AC_PROG_CXX AM_PROG_CC_STDC AC_HEADER_STDC AC_PROG_LIBTOOL @@ -69,90 +65,348 @@ fi dnl # GLib/Gobject/Gtk/Gconf => mandatory -PKG_CHECK_MODULES(MODEST_GSTUFF,glib-2.0 >= 2.6 gobject-2.0 gtk+-2.0 >= 2.6 gconf-2.0 gnome-vfs-2.0 libgtkhtml-3.8 libtinymail-1.0 libtinymail-camel-1.0 libtinymailui-1.0 libtinymailui-gtk-1.0) +PKG_CHECK_MODULES(MODEST_GSTUFF,glib-2.0 >= 2.6 gobject-2.0 gtk+-2.0 >= 2.6 gconf-2.0 gnome-vfs-2.0 libgtkhtml-3.8 libtinymail-1.0 libtinymail-camel-1.0 libtinymail-gnomevfs-1.0 libtinymailui-1.0 libtinymailui-gtk-1.0) AC_SUBST(MODEST_GSTUFF_CFLAGS) AC_SUBST(MODEST_GSTUFF_LIBS) -dnl dnl now, determine what to build -AC_MSG_NOTICE([Determining what platform to build]) -PKG_CHECK_MODULES(LIBOSSO,libosso,[with_platform=maemo],true) +modest_save_cflags="$CFLAGS" +modest_save_libs="$LIBS" +CFLAGS="$MODEST_GSTUFF_CFLAGS" +LIBS="$MODEST_GSTUFF_LIBS" +AC_CHECK_DECLS([gtk_widget_tap_and_hold_setup],[],[], [#include ]) +CFLAGS="$modest_save_cflags" +LIBS="$modest_save_libs" -AC_ARG_WITH(platform, -[--with-platform=gnome platform to build for [gnome]], +__COPY_LIBS="$LIBS" +LIBS="$LIBS $MODEST_GSTUFF_LIBS" +AC_CHECK_FUNCS(gtk_html_get_selection_area) +LIBS="$__COPY_LIBS" +AC_SUBST(HAVE_GTK_HTML_GET_SELECTION_AREA) + +dnl dnl now, determine what to build +dnl AC_MSG_NOTICE([Determining what platform to build]) +PKG_CHECK_MODULES(MODEST_MAEMO_LIBS,conic,[detected_platform=maemo],[detected_platform=gnome]) + +AC_ARG_WITH(platform, [ +Target platform: + --with-platform=detect detect target platform (default) + --with-platform=gnome build for Gnome + --with-platform=maemo build for Maemo +], [case "${with_platform}" in - gnome) MODEST_PLATFORM=gnome;; - maemo) MODEST_PLATFORM=maemo;; - *) MODEST_PLATFORM=${with_platform} -esac], [MODEST_PLATFORM=gnome - with_platform=gnome]) + gnome|maemo|detect) MODEST_PLATFORM=${with_platform};; + *) AC_MSG_ERROR([Unknown platform selected]);; +esac], [MODEST_PLATFORM=detect]) + +if test "$MODEST_PLATFORM" = "detect"; then + MODEST_PLATFORM="$detected_platform" + with_platform=$detected_platform +fi + + +dnl Whether to use maemo-launcher or not +AC_ARG_ENABLE([maemo-launcher], + [AS_HELP_STRING([--enable-maemo-launcher], + [build with maemo-launcher support])], + [case "${enableval}" in + yes) maemo_launcher=true ;; + no) maemo_launcher=false ;; + *) AC_MSG_ERROR([bad value ${enableval} for --enable-maemo-launcher]) ;; + esac], [maemo_launcher=false]) +if test x$maemo_launcher = xtrue +then + PKG_CHECK_MODULES(MAEMO_LAUNCHER, [maemo-launcher-app]) + AC_SUBST(MAEMO_LAUNCHER_CFLAGS) + AC_SUBST(MAEMO_LAUNCHER_LIBS) +fi + +have_easysetup=false +if test "x$with_platform" == "xgnome"; then + PKG_CHECK_MODULES(MODEST_PLATFORM,libtinymail-gnome-desktop-1.0 libnm_glib glib-2.0 >= 2.8 gtk+-2.0 >= 2.10 libnotify) + AC_DEFINE_UNQUOTED(MODEST_PLATFORM_GNOME, 1, ["Whether modest is being built for the GNOME platform."]) +dnl AC_MSG_ERROR([The GNOME Build is currently broken; please try the Maemo build instead]) +else + have_easysetup=true + have_dbusapi=true + PKG_CHECK_MODULES(MODEST_PLATFORM,libosso dbus-1 libtinymail-maemo-1.0 libebook-1.2 ) + AC_DEFINE_UNQUOTED(MODEST_PLATFORM_MAEMO, 1, ["Whether modest is being built for the MAEMO platform."]) + AC_DEFINE_UNQUOTED(MODEST_HAVE_EASYSETUP, 1, ["Whether we have the easysetup feature"]) +fi + +AM_CONDITIONAL(MODEST_HAVE_EASYSETUP,test "x$have_easysetup" == "xtrue") +AM_CONDITIONAL(MODEST_HAVE_DBUS_API,test "x$have_dbusapi" == "xtrue") AC_SUBST(MODEST_PLATFORM) -if test "x$with_platform" = "xmaemo"; then - - PKG_CHECK_MODULES(HILDON, hildon-1 >= 0.9.9, hildon1=yes, hildon1=no) - if test "$hildon1" == "yes"; then # the 'new' hildon - PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_MAEMO, conic libtinymail-maemo-1.0 hildon-libs libosso libhildonmime libedataserver-1.2 wpeditor hildon-help libebook-1.2 osso-addressbook-1.0) - - else # the old hildon - PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_MAEMO, conic libtinymail-maemo-1.0 hildon-libs >= 0.12.0 libossomime libossohelp osso-addressbook-1.0 wpeditor libebook-1.2 ) - AC_DEFINE_UNQUOTED(MODEST_HILDON_VERSION_0, 1, ["The Hildon version we support."]) - fi - - AC_SUBST(MODEST_LIBTINYMAIL_MAEMO_CFLAGS) - AC_SUBST(MODEST_LIBTINYMAIL_MAEMO_LIBS) - - AC_DEFINE_UNQUOTED(MODEST_PLATFORM_MAEMO, 1, ["Whether modest is being built for the Maemo platform."]) - - desktopentrydir=`$PKG_CONFIG osso-af-settings --variable=desktopentrydir` - serviceentrydir=`$PKG_CONFIG dbus-glib-1 --variable=prefix`/share/dbus-1/services - localedir=`$PKG_CONFIG osso-af-settings --variable=localedir` - pixmapdir=`$PKG_CONFIG osso-af-settings --variable=hildonpixmapdir` - icon_26x26dir=$datadir/icons/hicolor/26x26/hildon - icon_34x34dir=$datadir/icons/hicolor/34x34/hildon - icon_40x40dir=$datadir/icons/hicolor/40x40/hildon - icon_50x50dir=$datadir/icons/hicolor/50x50/hildon - icon_scalabledir=$datadir/icons/hicolor/scalable/hildon - pluginlibdir=`$PKG_CONFIG hildon-control-panel --variable=plugindir` - plugindesktopentrydir=`$PKG_CONFIG hildon-control-panel --variable=plugindesktopentrydir` - - # Define as variables in Makefiles - AC_SUBST(desktopentrydir) - AC_SUBST(serviceentrydir) - AC_SUBST(localedir) - AC_SUBST(pixmapdir) - AC_SUBST(icon_26x26dir) - AC_SUBST(icon_34x34dir) - AC_SUBST(icon_40x40dir) - AC_SUBST(icon_50x50dir) - AC_SUBST(icon_scalabledir) - AC_SUBST(pluginlibdir) - AC_SUBST(plugindesktopentrydir) + +# +# check for wpeditor or libwpeditor-plus (on maemo) +# +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_WPEDITOR,wpeditor,have_wpeditor=true,have_wpeditor=false) +if test "x$have_wpeditor" == "xfalse"; then + PKG_CHECK_MODULES(MODEST_WPEDITOR,libwpeditor-plus,have_libwpeditorplus=true,have_libwpeditorplus=false) + if test "x$have_libwpeditorplus" == "xtrue"; then + wpeditor="libwpeditor-plus" + AC_DEFINE_UNQUOTED(MODEST_HAVE_LIBWPEDITOR_PLUS, 1, ["Whether libwpeditor-plus is used."]) + else + AC_MSG_ERROR([you need to have either wpeditor or libwpeditor-plus installed]) + fi +else + wpeditor="wpeditor" + AC_DEFINE_UNQUOTED(MODEST_HAVE_WPEDITOR, 1, ["Whether wpeditor is used."]) +fi +fi + + +# +# check libalarm +# +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_LIBALARM,libalarm,have_libalarm=true,have_libalarm=false) +if test "x$have_libalarm" == "xtrue"; then + libalarm="libalarm" + AC_DEFINE_UNQUOTED(MODEST_HAVE_LIBALARM, 1, ["Whether libalarm is used."]) + AC_SUBST(MODEST_LIBALARM_CFLAGS) + AC_SUBST(MODEST_LIBALARM_LIBS) +else + libalarm="" +fi +fi + +# +# check for MCE +# +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_MCE,mce,have_mce=true,have_mce=false) +if test "x$have_mce" == "xtrue"; then + mce="mce" + AC_DEFINE_UNQUOTED(MODEST_HAVE_MCE, 1, ["Whether mce is used."]) + AC_SUBST(MODEST_MCE_CFLAGS) + AC_SUBST(MODEST_MCE_LIBS) +else + mce="" +fi +fi + +# +# check for libconic; this is a trick to check whether we run +# on a 'real' maemo platform, or on, say, ubuntu embedded +# this determines whether we build with the non-hildon GTK+ +# +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_LIBCONIC,conic,have_libconic=true,have_libconic=false) +if test "x$have_libconic" == "xtrue"; then + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON_GTK,1,["Whether modest is being built with Hildon/Gtk"]) + AC_DEFINE_UNQUOTED(MODEST_HAVE_CONIC,1,["Whether modest has conic available"]) + AC_SUBST(MODEST_LIBCONIC_CLAGS) + AC_SUBST(MODEST_LIBCONIC_LIBS) +else +# if we define this, tinymail will not try to #include conic headers + CFLAGS="$CFLAGS -DLIBTINYMAIL_MAEMO_WITHOUT_CONIC" +fi +fi + +# +# check hildon-help (only for maemo) +# +if test "x$with_platform" == "xmaemo"; then + PKG_CHECK_MODULES(MODEST_HILDON_HELP,hildon-help,have_hildon_help=true,have_hildon_help=false) + if test "x$have_hildon_help" == "xfalse"; then + PKG_CHECK_MODULES(MODEST_HILDON_HELP,libossohelp,have_osso_help=true,have_osso_help=false) + if test "x$have_osso_help" == "xtrue"; then + helplib="osso-help" + AC_DEFINE_UNQUOTED(MODEST_HAVE_OSSO_HELP, 1, ["Whether osso-help is used."]) + else + AC_MSG_ERROR([you need to have either osso-help or hildon-help installed]) + fi + else + helplib="hildon-help" + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON_HELP, 1, ["Whether hildon-help is used."]) + fi +fi + + + +# +# check for the notification stuff (only maemo) +# +if test "x$with_platform" == "xmaemo"; then + PKG_CHECK_MODULES(MODEST_HILDON_NOTIFY,hildon-notify libnotify,have_hildon_notify=true,have_hildon_notify=false) + if test "x$have_hildon_notify" == "xtrue"; then + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON_NOTIFY, 1, ["Whether hildon-notify is available"]) + fi +fi + + +# +# check for the uri/mime stuff +# +if test "x$with_platform" == "xmaemo"; then + PKG_CHECK_MODULES(MODEST_HILDON_MIME,libhildonmime,have_hildonmime=true,have_hildonmime=false) + if test "x$have_hildonmime" == "xfalse"; then + PKG_CHECK_MODULES(MODEST_HILDON_MIME,libossomime,have_ossomime=true,have_ossomime=false) + if test "x$have_ossomime" == "xtrue"; then + mimelib="osso-mime" + AC_DEFINE_UNQUOTED(MODEST_HAVE_OSSO_MIME, 1, ["Whether osso-mime is used."]) + else + AC_MSG_ERROR([you need to have either osso-mime or hildon-mime installed]) + fi + else + mimelib="hildon-mime" + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON_MIME, 1, ["Whether hildon-mime is used."]) + fi +fi + +PKG_CHECK_MODULES(MODEST_MOZEMBED, libtinymailui-mozembed-1.0, have_mozembed=true, have_mozembed=false) +AC_ARG_ENABLE(mozembed, +AC_HELP_STRING([--enable-mozembed], + [Build with GtkMozEmbed (yes, no)]), +[case "${enableval}" in + yes) + if test x$have_mozembed = xfalse; then + AC_MSG_ERROR([building of GtkMozEmbed support requested and gtkmozembed not found]) + fi + use_mozembed=true + ;; + *) + use_mozembed=false + ;; +esac],[use_mozembed=false]) + +AM_CONDITIONAL(BUILD_MOZEMBED, test x$use_mozembed = xtrue) + +if test x$use_mozembed = xtrue; then + AC_DEFINE_UNQUOTED(MODEST_USE_MOZEMBED, 1, ["Whether we use GtkMozEmbed."]) +fi + +#dnl wether we can and should build the +#dnl search plugin (on maemo) +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_OGS, libosso >= 0.8.5 libogs-1.2, have_ogs=true, have_ogs=false) +have_ogs_support=false +AC_ARG_ENABLE(ogs_support, +AC_HELP_STRING([--enable-ogs-support], + [Build with osso global search support (yes, no)]), +[case "${enableval}" in + yes) + if test x$have_ogs = xfalse; then + AC_MSG_ERROR([building of ogs support requested and libogs-1.2 not found]) + fi + ;; + *) + have_ogs_support=false + ;; +esac],[have_ogs_support=$have_ogs]) + +if test x$have_ogs_support = xtrue; then + AC_DEFINE_UNQUOTED(MODEST_HAVE_OGS, 1, ["Whether ogs is available."]) +fi +fi + + + +# +# check the version of the widgets on maemo +# +if test "x$with_platform" == "xmaemo"; then +PKG_CHECK_MODULES(MODEST_HILDON_WIDGETS, hildon-1 >= 0.9.9 hildon-fm-2, have_hildon1=true,have_hildon1=false) +if test "x$have_hildon1" == "xfalse"; then + PKG_CHECK_MODULES(MODEST_HILDON_WIDGETS, hildon-libs >= 0.12.0 hildon-fm, have_hildon0=true,have_hildon0=false) + if test "x$have_hildon0" == "xtrue"; then + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON0_WIDGETS, 1, ["Whether hildon0 widgets are used."]) + else + AC_MSG_ERROR([hildon widgets and/or hildon-fm not found]) + fi +else + AC_DEFINE_UNQUOTED(MODEST_HAVE_HILDON1_WIDGETS, 1, ["Whether hildon1 widgets are used."]) +fi +fi + + + +# +# check the version of the addressbook on maemo +# +if test "x$with_platform" == "xmaemo"; then + PKG_CHECK_MODULES(MODEST_ABOOK,osso-addressbook-1.0,have_abook=true,have_abook=false) + AC_SUBST(MODEST_ABOOK_CFLAGS) + AC_SUBST(MODEST_ABOOK_LIBS) + + if test "x$have_abook" == "xtrue"; then + PKG_CHECK_MODULES(MODEST_ABOOK_OLD, osso-addressbook-1.0 < 2.0, have_old_abook=true,have_old_abook=false) + if test "x$have_old_abook" == "xtrue"; then + AC_DEFINE_UNQUOTED(MODEST_HAVE_OLD_ABOOK, 1, ["whether we have an old osso-addressbook"]) + fi + AC_DEFINE_UNQUOTED(MODEST_HAVE_ABOOK,1, ["whether we have osso-addressbook"]) + addressbook="osso-addressbook" + fi +fi + + +# +# if we don't have an addressbook, use the dummy one +# +AM_CONDITIONAL(MODEST_USE_DUMMY_ADDRESS_BOOK,test "x$have_abook" != "xtrue") + + +# gettext support +GETTEXT_PACKAGE=modest +AC_SUBST(GETTEXT_PACKAGE) +AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE", ["gettext package"]) + + +# +# settings for maemo platform +# +if test "x$with_platform" == "xmaemo"; then # warnings are errors, but don't check format errors, because - # it breaks with logical id's + # it breaks with logical ids CFLAGS="$CFLAGS -Wno-format-extra-args -Werror" + + desktopentrydir=`$PKG_CONFIG osso-af-settings --variable=desktopentrydir` + serviceentrydir=`$PKG_CONFIG dbus-glib-1 --variable=prefix`/share/dbus-1/services + localedir=`$PKG_CONFIG osso-af-settings --variable=localedir` + backupsettingsdir=/etc/osso-backup/applications + pixmapdir=`$PKG_CONFIG osso-af-settings --variable=hildonpixmapdir` + icon_26x26dir=$datadir/icons/hicolor/26x26/hildon + icon_34x34dir=$datadir/icons/hicolor/34x34/hildon + icon_40x40dir=$datadir/icons/hicolor/40x40/hildon + icon_50x50dir=$datadir/icons/hicolor/50x50/hildon + icon_scalabledir=$datadir/icons/hicolor/scalable/hildon + pluginlibdir=`$PKG_CONFIG hildon-control-panel --variable=plugindir` + plugindesktopentrydir=`$PKG_CONFIG hildon-control-panel --variable=plugindesktopentrydir` + + dbus_api="dbus_api" + AC_SUBST(dbus_api) + + # Define as variables in Makefiles + AC_SUBST(desktopentrydir) + AC_SUBST(serviceentrydir) + AC_SUBST(backupsettingsdir) + AC_SUBST(localedir) + AC_SUBST(pixmapdir) + AC_SUBST(icon_26x26dir) + AC_SUBST(icon_34x34dir) + AC_SUBST(icon_40x40dir) + AC_SUBST(icon_50x50dir) + AC_SUBST(icon_scalabledir) + AC_SUBST(pluginlibdir) + AC_SUBST(plugindesktopentrydir) + else # gnome frontend - PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_GNOME_DESKTOP,libtinymail-gnome-desktop-1.0 libnm_glib glib-2.0 >= 2.8 gtk+-2.0 >= 2.10) + PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_GNOME_DESKTOP,libtinymail-gnome-desktop-1.0 libnm_glib glib-2.0 >= 2.8 gtk+-2.0 >= 2.10 libnotify) AC_SUBST(MODEST_LIBTINYMAIL_GNOME_DESKTOP_CFLAGS) AC_SUBST(MODEST_LIBTINYMAIL_GNOME_DESKTOP_LIBS) AC_DEFINE_UNQUOTED(MODEST_PLATFORM_GNOME, 1, ["Whether modest is being built for the GNOME platform."]) -fi -dnl do we have the easy setup stuff? -have_easysetup=false -if test -d src/${with_platform}/easysetup; then - have_easysetup=true - AC_DEFINE_UNQUOTED(MODEST_HAVE_EASYSETUP, 1, ["Whether the easysetup feature is available."]) + # no dbus api for gnome + dbus_api="" + AC_SUBST(dbus_api) - # Just check that the dependency exists: - PKG_CHECK_MODULES(MODEST_PROVIDERS_DATA, modest-providers-data) - - # Get the location of the ISO-Codes (currencies, languages) files: - AC_DEFINE_UNQUOTED([MODEST_PROVIDERS_DATA_PATH],["`$PKG_CONFIG --variable=path modest-providers-data`"],[modest-providers-data file path]) fi -AM_CONDITIONAL(MODEST_HAVE_EASYSETUP,test x$have_easysetup = xtrue) dnl ## setup the testing framework (ie., make check) @@ -192,8 +446,7 @@ dnl ## gtk-doc GTK_DOC_CHECK([1.0]) dnl Intltool utility programs -dnl AC_PROG_INTLTOOL([0.33.0],[no-xml]) - +#AC_PROG_INTLTOOL([0.33.0],[no-xml]) AC_OUTPUT([ po/Makefile.in @@ -210,7 +463,7 @@ docs/reference/Makefile tests/Makefile tests/dbus_api/Makefile src/maemo/modest.desktop -src/maemo/modest.service +src/maemo/com.nokia.modest.service libmodest-dbus-client/Makefile libmodest-dbus-client/libmodest-dbus-client-1.0.pc ]) @@ -220,9 +473,25 @@ echo echo "modest configure results" echo "-----------------------------------" echo "Platform : $with_platform" -echo "Build easy setup : $have_easysetup" +echo "Prefix : ${prefix}" echo "Build tests : $build_tests" echo "Build docs : $build_docs" +echo "Gettext Package : $GETTEXT_PACKAGE" + +if test "x$with_platform" == "xmaemo"; then + echo "Maemo Launcher : $maemo_launcher" + echo "Editor lib : $wpeditor" + echo "Addressbook : $have_abook" + echo "Help lib : $helplib" + echo "libconic support : $have_libconic" + echo "Alarm : $have_libalarm" + echo "MCE : $have_mce" + echo "Hildon-Notify : $have_hildon_notify" + echo "LibOGS support : $have_ogs_support" + echo "MozEmbed support : $use_mozembed" +fi + +echo "CFLAGS : $CFLAGS" echo "Debug version : $with_debug" echo "" echo "NOTE: you should do a 'make clean' after changing architecture or platform (--with-platform=)"