+# PkgConfig isn't strictly required.
+# However, some optional deps might not be found if it's not present, so warn!
+find_package(PkgConfig)
+if(NOT PKG_CONFIG_FOUND)
+ message(STATUS "WARNING: PkgConfig not available! Some dependencies for optional features might not be found.")
+ message(STATUS " Affected features might include encryption support, DBus menus and Ayatana notifications.")
+endif(NOT PKG_CONFIG_FOUND)
+
+# Setup OpenSSL
+# We don't link to or include OpenSSL ourselves, but use exclusively the Qt API.
+# Thus, we simply check if OpenSSL support is present in Qt's config and enable our
+# own SSL stuff in this case. Qt should care for adding what it needs itself.
+if(WITH_OPENSSL)
+ if(QT_QCONFIG MATCHES "openssl")
+ message(STATUS "Found OpenSSL support in Qt, enabling SSL")
+ add_definitions(-DHAVE_SSL)
+ set(HAVE_SSL true)
+ else(QT_QCONFIG MATCHES "openssl")
+ message(STATUS "No OpenSSL support found in Qt, disabling SSL")
+ add_definitions(-DQT_NO_OPENSSL)
+ endif(QT_QCONFIG MATCHES "openssl")
+else(WITH_OPENSSL)
+ message(STATUS "Not enabling OpenSSL support")
+endif(WITH_OPENSSL)
+
+# Check for GUI specific stuff
+if(BUILD_GUI)
+
+ # Setup D-Bus support
+ if(WITH_DBUS)
+ if(QT_QTDBUS_FOUND)
+ message(STATUS "Found QtDBus, enabling D-Bus support")
+ add_definitions(-DHAVE_DBUS)
+ set(CLIENT_QT4_VARS ${CLIENT_QT4_VARS} DBUS)
+ set(CLIENT_COMPILE_FLAGS "${CLIENT_COMPILE_FLAGS} -DQT_DBUS_LIB")
+ set(HAVE_DBUS true)
+
+ # check if we have dbusmenu as well
+ find_package(DBusMenuQt)
+ if(DBUSMENUQT_FOUND)
+ message(STATUS "Enabling support for exporting the tray menu via D-Bus")
+ add_definitions(-DHAVE_DBUSMENU)
+ include_directories(${DBUSMENUQT_INCLUDE_DIR})
+ set(CLIENT_LIBRARIES ${CLIENT_LIBRARIES} ${DBUSMENUQT_LIBRARIES})
+ set(CLIENT_COMPILE_FLAGS "${CLIENT_COMPILE_FLAGS} ${DBUSMENUQT_DEFINITIONS}")
+ else(DBUSMENUQT_FOUND)
+ message(STATUS "Disabling support for exporting the tray menu via D-Bus")
+ endif(DBUSMENUQT_FOUND)
+
+ else(QT_QTDBUS_FOUND)
+ message(STATUS "QtDBus not found, disabling D-Bus support")
+ endif(QT_QTDBUS_FOUND)
+ else(WITH_DBUS)
+ message(STATUS "Not enabling D-Bus support")
+ endif(WITH_DBUS)
+
+ # Setup QtWebKit support
+ if(WITH_WEBKIT)
+ if(QT_QTWEBKIT_FOUND)
+ message(STATUS "Found QtWebKit, enabling WebKit support")
+ add_definitions(-DHAVE_WEBKIT)
+ set(CLIENT_QT4_VARS ${CLIENT_QT4_VARS} WEBKIT XMLPATTERNS)
+ set(CLIENT_COMPILE_FLAGS "${CLIENT_COMPILE_FLAGS} -DQT_WEBKIT_LIB -DQT_XMLPATTERNS_LIB")
+ set(HAVE_WEBKIT true)
+ else(QT_QTWEBKIT_FOUND)
+ message(STATUS "QtWebKit not found, disabling WebKit support")
+ endif(QT_QTWEBKIT_FOUND)
+ else(WITH_WEBKIT)
+ message(STATUS "Not enabling WebKit support")
+ endif(WITH_WEBKIT)
+
+ # Setup KDE4 support
+ if(WITH_KDE)
+ find_package(KDE4)
+ if(KDE4_FOUND)
+ message(STATUS "Enabling KDE4 integration")
+ include_directories(${KDE4_INCLUDES})
+ add_definitions(-DHAVE_KDE ${KDE4_DEFINITIONS})
+ set(HAVE_KDE 1)
+ set(CLIENT_LIBRARIES ${CLIENT_LIBRARIES} ${KDE4_KDECORE_LIBS} ${KDE4_KDEUI_LIBRARY} ${KDE4_SOLID_LIBS} knotifyconfig)
+ # We always use external icons for KDE4 support, since we use its iconloader rather than our own
+ set(EMBED_DATA OFF)
+ else(KDE4_FOUND)
+ message(STATUS "KDE4 not found, disabling KDE integration")
+ endif(KDE4_FOUND)
+ else(WITH_KDE)
+ message(STATUS "Not enabling KDE4 integration")
+ endif(WITH_KDE)
+
+ # Setup Phonon support - we only need this if we don't have or want KDE4
+ if(NOT HAVE_KDE)
+ if(WITH_PHONON)
+ find_package(Phonon)
+ if(PHONON_FOUND)
+ message(STATUS "Enabling Phonon support")
+ add_definitions(-DHAVE_PHONON)
+ include_directories(${PHONON_INCLUDES})
+ set(CLIENT_LIBRARIES ${CLIENT_LIBRARIES} ${PHONON_LIBS})
+ set(HAVE_PHONON true)
+ else(PHONON_FOUND)
+ message(STATUS "Phonon not found, disabling audio notifications")
+ endif(PHONON_FOUND)
+ else(WITH_PHONON)
+ message(STATUS "Not enabling Phonon support")
+ endif(WITH_PHONON)
+ endif(NOT HAVE_KDE)
+
+ # Setup libindicate-qt support
+ if(WITH_LIBINDICATE)
+ pkg_check_modules(INDICATEQT QUIET indicate-qt>=0.2.1)
+ if(INDICATEQT_FOUND)
+ message(STATUS "Enabling Ayatana notification support")
+ set(HAVE_INDICATEQT true)
+ add_definitions(-DHAVE_INDICATEQT)
+ link_directories(${INDICATEQT_LIBRARY_DIRS})
+ set(CLIENT_LIBRARIES ${CLIENT_LIBRARIES} ${INDICATEQT_LIBRARIES})
+ else(INDICATEQT_FOUND)
+ message(STATUS "Disabling Ayatana notification support")
+ endif(INDICATEQT_FOUND)
+ else(WITH_LIBINDICATE)
+ message(STATUS "Not enabling Ayatana notification support")
+ # We don't want to link against it even if another package has found it
+ set(INDICATEQT_LIBRARIES "")
+ endif(WITH_LIBINDICATE)
+
+endif(BUILD_GUI)
+
+# Core-only deps