-dnl # tinymail => mandatory
-PKG_CHECK_MODULES(MODEST_TINYMAIL, libtinymail-1.0 libtinymail-camel-1.0 libtinymailui-1.0 libtinymailui-gtk-1.0 libtinymail-gnome-desktop-1.0 camel-1.2)
-AC_SUBST(MODEST_TINYMAIL_CFLAGS)
-AC_SUBST(MODEST_TINYMAIL_LIBS)
-
-dnl # firefox-gtkmozembed => dependency from tinymail
-PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_GNOME_DESKTOP, firefox-nss firefox-xpcom firefox-gtkmozembed libnm_glib glib-2.0 >= 2.8 gobject-2.0 libgnomeui-2.0 gtk+-2.0)
-AC_SUBST(MODEST_LIBTINYMAIL_GNOME_DESKTOP_CFLAGS)
-AC_SUBST(MODEST_LIBTINYMAIL_GNOME_DESKTOP_LIBS)
-
-dnl # GConf => mandatory
-PKG_CHECK_MODULES(MODEST_GCONF,gconf-2.0)
-AC_SUBST(MODEST_GCONF_CFLAGS)
-AC_SUBST(MODEST_GCONF_LIBS)
-
-dnl # Gtk+ => mandatory
-PKG_CHECK_MODULES(MODEST_GTK,gtk+-2.0 >= 2.6)
-AC_SUBST(MODEST_GTK_CFLAGS)
-AC_SUBST(MODEST_GTK_LIBS)
-
-dnl # Glade
-PKG_CHECK_MODULES(MODEST_GLADE,libglade-2.0,glade_support=yes,echo "no";glade_support=no)
-AC_SUBST(MODEST_GLADE_CFLAGS)
-AC_SUBST(MODEST_GLADE_LIBS)
-
-dnl dnl build the Hildon UI?
-PKG_CHECK_MODULES(MODEST_HILDON,hildon libglade-2.0 libtinymailui-gtk-1.0,hildon_support=yes,echo "no";hildon_support=no)
-AC_SUBST(MODEST_HILDON_CFLAGS)
-AC_SUBST(MODEST_HILDON_LIBS)
-
-dnl now, determine what to build
-AC_MSG_NOTICE([Determining what UI to build])
-modest_ui="none"
-if test "x$hildon_support" = "xyes"; then
- AC_SUBST(MODEST_UI_DIR,"hildon")
- AC_DEFINE([MODEST_ENABLE_HILDON_UI],1,[Enable Hildon UI])
- modest_ui="hildon"
-elif test "x$glade_support" = "xyes"; then
- AC_SUBST(MODEST_UI_DIR,"gtk-glade")
- AC_DEFINE([MODEST_ENABLE_GTK_GLADE_UI],1,[Enable Gtk-Glade UI])
- modest_ui="gtk-glade"
-else
- AC_SUBST(MODEST_UI_DIR,"gtk")
- AC_DEFINE([MODEST_ENABLE_GTK_UI],1,[Enable Plain Gtk+ UI])
- modest_ui="gtk"
+dnl dnl now, determine what to build
+AC_MSG_NOTICE([Determining what platform to build])
+PKG_CHECK_MODULES(LIBOSSO,libosso,[with_platform=maemo],true)
+
+AC_ARG_WITH(platform,
+[--with-platform=gnome platform to build for [gnome]],
+[case "${with_platform}" in
+ gnome) MODEST_PLATFORM=gnome;;
+ maemo) MODEST_PLATFORM=maemo;;
+ *) MODEST_PLATFORM=${with_platform}
+esac], [MODEST_PLATFORM=gnome
+ with_platform=gnome])
+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-1 libosso libhildonmime osso-addressbook-1.0 wpeditor libossohelp libebook-1.2 libalarm)
+
+ else # the old hildon
+ PKG_CHECK_MODULES(MODEST_LIBTINYMAIL_MAEMO, conic libtinymail-maemo-1.0 hildon-libs >= 0.12.0 libosso libossomime libossohelp osso-addressbook-1.0 wpeditor libebook-1.2 libalarm)
+ 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`
+
+ dbus_api="dbus_api"
+ AC_SUBST(dbus_api)
+
+ # 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)
+
+ # warnings are errors, but don't check format errors, because
+ # it breaks with logical id's
+ CFLAGS="$CFLAGS -Wno-format-extra-args -Werror"
+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)
+ 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."])
+
+ # no dbus api for gnome
+ dbus_api=""
+ AC_SUBST(dbus_api)
+
+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."])
+
+ # 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)
+build_tests=false
+AC_ARG_ENABLE(tests,
+AC_HELP_STRING([--enable-tests],
+ [Build tests (no, yes)]),
+[case "${enableval}" in
+ yes)
+ build_tests=true ;;
+ *) build_tests=false ;;
+esac],[build_tests=false])
+AM_CONDITIONAL(BUILD_TESTS, test x$build_tests = xtrue)
+
+
+
+dnl ## is the check package installed?
+if test x$build_tests = xtrue; then
+ PKG_CHECK_MODULES(CHECK, check >= 0.9.4 glib-2.0)