X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=configure.ac;h=6c9ba149c613f33ddc1492abc6b21b777bf0500d;hp=2e4804fcde8e4957bce261530d1bb4915a9abb47;hb=5fada852803f8ffc68c6f28ee2cf91808afa906f;hpb=c16c534dcb35f88439e31d0f21a415bf43fb40f7 diff --git a/configure.ac b/configure.ac index 2e4804fcd..6c9ba149c 100644 --- a/configure.ac +++ b/configure.ac @@ -49,6 +49,8 @@ AC_SEARCH_LIBS([clock_gettime], [rt], [], [AC_MSG_ERROR([*** POSIX RT library no AC_SEARCH_LIBS([cap_init], [cap], [], [AC_MSG_ERROR([*** POSIX caps library not found])]) AC_CHECK_HEADERS([sys/capability.h], [], [AC_MSG_ERROR([*** POSIX caps headers not found])]) +# This makes sure pkg.m4 is available. +m4_pattern_forbid([^_?PKG_[A-Z_]+$],[pkg.m4 missing, please install pkg-config]) PKG_CHECK_MODULES(UDEV, [ libudev ]) AC_SUBST(UDEV_CFLAGS) AC_SUBST(UDEV_LIBS) @@ -61,19 +63,31 @@ PKG_CHECK_MODULES(DBUSGLIB, [ dbus-glib-1 ]) AC_SUBST(DBUSGLIB_CFLAGS) AC_SUBST(DBUSGLIB_LIBS) -PKG_CHECK_MODULES(GEE, [ gee-1.0 ]) -AC_SUBST(GEE_CFLAGS) -AC_SUBST(GEE_LIBS) - PKG_CHECK_MODULES(GTK, [ gtk+-2.0 ]) AC_SUBST(GTK_CFLAGS) AC_SUBST(GTK_LIBS) -PKG_CHECK_MODULES(CGROUP, [ libcgroup ]) +PKG_CHECK_MODULES( CGROUP, [ libcgroup >= 0.35 ], [], + [AC_CHECK_HEADER( [libcgroup.h], [], [AC_MSG_ERROR([*** libcgroup.h not found])], ) + save_CPPFLAGS="$CPPFLAGS" + save_LIBS="$LIBS" + CGROUP_LIBS=${CGROUP_LIBS:--lcgroup} + LIBS="$LIBS $CGROUP_LIBS" + CPPFLAGS="$CPPFLAGS $CGROUP_CFLAGS" + AC_MSG_CHECKING([for libcgroup >= 0.35]) + AC_LINK_IFELSE( + [AC_LANG_PROGRAM([[#include ]], [[ CGFLAG_DELETE_RECURSIVE; cgroup_init(); ]])], + [AC_MSG_RESULT([yes])], + [AC_MSG_RESULT([no]); AC_MSG_ERROR([*** systemd needs libcgroup 0.35 or newer])], + [${CGROUP_LIBS}]) + CPPFLAGS="$save_CPPFLAGS" + LIBS="$save_LIBS" + ]) + AC_SUBST(CGROUP_CFLAGS) AC_SUBST(CGROUP_LIBS) -AM_PROG_VALAC() +AM_PROG_VALAC([0.7]) AC_SUBST(VAPIDIR) AC_ARG_WITH(distro, AS_HELP_STRING([--with-distro=DISTRO],[Specify the distribution to target: One of fedora, suse, debian, or none])) @@ -84,6 +98,7 @@ if test "z$with_distro" = "z"; then AC_CHECK_FILE(/etc/redhat-release,with_distro="fedora") AC_CHECK_FILE(/etc/SuSE-release,with_distro="suse") AC_CHECK_FILE(/etc/debian_version,with_distro="debian") + AC_CHECK_FILE(/etc/arch-release,with_distro="arch") fi if test "z$with_distro" = "z"; then with_distro=`uname -s` @@ -95,18 +110,36 @@ case $with_distro in fedora) SYSTEM_SYSVINIT_PATH=/etc/rc.d/init.d SYSTEM_SYSVRCND_PATH=/etc/rc.d + special_dbus_service=messagebus.service + special_syslog_service=rsyslog.service + AC_DEFINE(TARGET_FEDORA, [], [Target is Fedora/RHEL]) ;; suse) SYSTEM_SYSVINIT_PATH=/etc/init.d SYSTEM_SYSVRCND_PATH=/etc/init.d + special_dbus_service=dbus.service + special_syslog_service=syslog.service + AC_DEFINE(TARGET_SUSE, [], [Target is OpenSUSE/SLES]) ;; debian) SYSTEM_SYSVINIT_PATH=/etc/init.d SYSTEM_SYSVRCND_PATH=/etc + special_dbus_service=dbus.service + special_syslog_service=sysklogd.service + AC_DEFINE(TARGET_DEBIAN, [], [Target is Debian/Ubuntu]) + ;; + arch) + SYSTEM_SYSVINIT_PATH=/etc/rc.d + SYSTEM_SYSVRCND_PATH=/etc + special_dbus_service=dbus.service + special_syslog_service=syslog-ng.service + AC_DEFINE(TARGET_ARCH, [], [Target is ArchLinux]) ;; none) - SYSTEM_SYSVINIT_PATH=/etc/fix/the/configure/script - SYSTEM_SYSVRCND_PATH=/etc/fix/the/configure/script + SYSTEM_SYSVINIT_PATH=/fix/the/configure/script + SYSTEM_SYSVRCND_PATH=/fix/the/configure/script + special_dbus_service=fix-the-configure-script.service + special_syslog_service=fix-the-configure-script.service ;; *) AC_MSG_ERROR([Your distribution (${with_distro}) is not yet supported, SysV init scripts could not be found! (patches welcome); you can specify --with-distro=none to skip this check]) @@ -114,17 +147,24 @@ case $with_distro in esac AC_SUBST(SYSTEM_SYSVINIT_PATH) -AC_SUBST(SYSTEM_RCND_PATH) +AC_SUBST(SYSTEM_SYSVRCND_PATH) AM_CONDITIONAL(TARGET_FEDORA, test x"$with_distro" = xfedora) AM_CONDITIONAL(TARGET_SUSE, test x"$with_distro" = xsuse) AM_CONDITIONAL(TARGET_DEBIAN, test x"$with_distro" = xdebian) +AM_CONDITIONAL(TARGET_ARCH, test x"$with_distro" = xarch) + +AC_DEFINE_UNQUOTED(SPECIAL_DBUS_SERVICE, ["$special_dbus_service"], [D-Bus service name]) +AC_DEFINE_UNQUOTED(SPECIAL_SYSLOG_SERVICE, ["$special_syslog_service"], [syslog service name]) AC_OUTPUT([Makefile]) echo " $PACKAGE_NAME $VERSION + Distribution: ${with_distro} SysV init scripts: ${SYSTEM_SYSVINIT_PATH} SysV rc?.d directories: ${SYSTEM_SYSVRCND_PATH} + Syslog service: ${special_syslog_service} + D-Bus service: ${special_dbus_service} "