Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 1 | # Initialization |
| 2 | AC_PREREQ([2.69]) |
| 3 | AC_INIT([sdbusplus], [1.0], [https://github.com/openbmc/sdbusplus/issues]) |
| 4 | AC_CONFIG_HEADERS([config.h]) |
William A. Kennington III | c65d74e | 2018-06-19 18:32:09 -0700 | [diff] [blame] | 5 | AC_CONFIG_MACRO_DIRS([m4]) |
| 6 | AC_CONFIG_AUX_DIR([build-aux]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 7 | AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz]) |
| 8 | AM_SILENT_RULES([yes]) |
| 9 | |
William A. Kennington III | 592128c | 2018-06-19 18:34:17 -0700 | [diff] [blame] | 10 | # Make sure the default CFLAGS of `-O2 -g` don't override CODE_COVERAGE_CFLAGS |
| 11 | # It is important that this comes before AC_PROG_C{C,XX}, as we are attempting |
| 12 | # to stop them from populating default CFLAGS and CXXFLAGS. |
William A. Kennington III | 387110b | 2018-08-21 19:23:19 -0700 | [diff] [blame] | 13 | AS_IF([test "x$enable_tests" = "xno"], [enable_code_coverage=no]) |
| 14 | AS_IF([test "x$enable_code_coverage" != "xno"], [ |
| 15 | AS_IF([test "x${CXXFLAGS+set}" != "xset"], [ |
| 16 | AC_SUBST(CXXFLAGS, [""]) |
| 17 | ]) |
| 18 | AS_IF([test "x${CFLAGS+set}" != "xset"], [ |
| 19 | AC_SUBST(CFLAGS, [""]) |
William A. Kennington III | 592128c | 2018-06-19 18:34:17 -0700 | [diff] [blame] | 20 | ]) |
| 21 | ]) |
| 22 | |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 23 | # Checks for programs. |
Patrick Williams | 83a9d0b | 2016-11-04 17:06:13 -0500 | [diff] [blame] | 24 | AC_PROG_CXX |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 25 | AC_PROG_CC |
| 26 | AM_PROG_AR |
| 27 | AC_PROG_INSTALL |
| 28 | AC_PROG_MAKE_SET |
| 29 | |
Brad Bishop | bba7f8c | 2016-11-10 09:32:58 -0500 | [diff] [blame] | 30 | # setup sdbus++ |
| 31 | AM_PATH_PYTHON([2.7], [AC_SUBST([PYTHON], [echo "$PYTHON"])]) |
| 32 | AC_SUBST([PYTHONDIR], ${pythondir}) |
| 33 | AS_IF([test "$PYTHON" != :], [have_python=yes], [have_python=no]) |
| 34 | |
| 35 | AC_ARG_ENABLE([sdbuspp], |
| 36 | AS_HELP_STRING([--disable-sdbuspp], [Disable sdbus++])) |
| 37 | |
| 38 | AS_IF([test "x$enable_sdbuspp" != "xno"], |
| 39 | [AS_IF([test "x$have_python" = "xno"], [AC_MSG_ERROR([sdbus++ requires python])])]) |
| 40 | |
| 41 | AM_CONDITIONAL([WANT_SDBUSPP], [test "x$enable_sdbuspp" != "xno"]) |
| 42 | |
Brad Bishop | 14275cf | 2016-11-10 16:24:48 -0500 | [diff] [blame] | 43 | # setup libsdbusplus |
Brad Bishop | 5e70389 | 2017-02-10 11:52:48 -0500 | [diff] [blame] | 44 | AX_PKG_CHECK_MODULES( |
| 45 | [SYSTEMD], |
| 46 | [libsystemd >= 221], |
| 47 | [], |
| 48 | [have_systemd=yes], |
| 49 | [have_systemd=no]) |
Brad Bishop | 14275cf | 2016-11-10 16:24:48 -0500 | [diff] [blame] | 50 | AC_ARG_ENABLE([libsdbusplus], |
| 51 | AS_HELP_STRING([--disable-libsdbusplus], [Disable libsdbusplus])) |
| 52 | |
| 53 | AS_IF([test "x$enable_libsdbusplus" != "xno"], |
| 54 | [AS_IF([test "x$have_systemd" = "xno"], [AC_MSG_ERROR([libsdbusplus requires systemd])])]) |
| 55 | |
| 56 | AM_CONDITIONAL([WANT_LIBSDBUSPLUS], [test "x$enable_libsdbusplus" != "xno"]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 57 | |
Adriana Kobylak | fd43ef7 | 2017-02-12 09:12:37 -0600 | [diff] [blame] | 58 | # setup transaction |
| 59 | AC_ARG_ENABLE([transaction], |
| 60 | AS_HELP_STRING([--enable-transaction], [Enable transaction id support.])) |
| 61 | AC_ARG_VAR(WANT_TRANSACTION, [Enable transaction id support.]) |
| 62 | AS_IF([test "x$enable_transaction" = "xyes"], \ |
| 63 | [WANT_TRANSACTION="1"], \ |
| 64 | [WANT_TRANSACTION="0"]) |
| 65 | AM_CONDITIONAL([WANT_TRANSACTION], [test "x$enable_transaction" = "xyes"]) |
| 66 | |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 67 | # Checks for header files. |
Patrick Williams | ab7de32 | 2017-01-06 15:14:45 -0600 | [diff] [blame] | 68 | AS_IF([test "x$enable_libsdbusplus" != "xno"], |
Gunnar Mills | a4b4a0b | 2018-04-08 14:30:38 -0500 | [diff] [blame] | 69 | [AC_CHECK_HEADER(systemd/sd-bus.h, ,[AC_MSG_ERROR([Could not find systemd/sd-bus.h...systemd development package required])])]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 70 | |
| 71 | # Checks for typedefs, structures, and compiler characteristics. |
Patrick Williams | ab7de32 | 2017-01-06 15:14:45 -0600 | [diff] [blame] | 72 | AS_IF([test "x$enable_libsdbusplus" != "xno"], |
Vernon Mauery | ca46b9d | 2018-10-02 14:05:09 -0700 | [diff] [blame] | 73 | [AX_CXX_COMPILE_STDCXX_17([noext])]) |
Patrick Williams | 83a9d0b | 2016-11-04 17:06:13 -0500 | [diff] [blame] | 74 | AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CFLAGS]) |
| 75 | AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 76 | |
| 77 | # Checks for library functions. |
| 78 | LT_INIT # Removes 'unrecognized options: --with-libtool-sysroot' |
| 79 | |
William A. Kennington III | b4b3247 | 2018-06-21 16:38:47 -0700 | [diff] [blame] | 80 | # Make it possible for users to choose if they want test support |
| 81 | # explicitly or not at all |
| 82 | AC_ARG_ENABLE([tests], [Whether we should build test cases]) |
| 83 | |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 84 | # Check/set gtest specific functions. |
William A. Kennington III | b4b3247 | 2018-06-21 16:38:47 -0700 | [diff] [blame] | 85 | AS_IF([test "x$enable_tests" != "xno"], [ |
William A. Kennington III | 40c2279 | 2018-06-29 16:21:17 -0700 | [diff] [blame] | 86 | PKG_CHECK_MODULES([GTEST], [gtest], [], [true]) |
William A. Kennington III | c20acf6 | 2018-06-22 18:38:03 -0700 | [diff] [blame] | 87 | PKG_CHECK_MODULES([GMOCK], [gmock], [], [true]) |
William A. Kennington III | 6f57467 | 2018-06-27 11:19:03 -0700 | [diff] [blame] | 88 | AX_PTHREAD |
William A. Kennington III | b4b3247 | 2018-06-21 16:38:47 -0700 | [diff] [blame] | 89 | |
| 90 | AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS]) |
| 91 | AX_APPEND_COMPILE_FLAGS([$GTEST_CFLAGS], [CPPFLAGS]) |
| 92 | AC_LANG_PUSH([C++]) |
| 93 | AC_CHECK_HEADERS([gtest/gtest.h], [ |
| 94 | AS_IF([test "x$GTEST_CFLAGS" = "x"], [ |
| 95 | AS_IF([test "x$PTHREAD_CFLAGS" = "x"], [ |
| 96 | AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=0"], [GTEST_CFLAGS]) |
| 97 | ], [ |
| 98 | AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=1"], [GTEST_CFLAGS]) |
| 99 | AX_APPEND_COMPILE_FLAGS([$PTHREAD_CFLAGS], [GTEST_CFLAGS]) |
| 100 | ]) |
| 101 | ]) |
| 102 | ], [ |
| 103 | AS_IF([test "x$enable_tests" = "xyes"], [ |
| 104 | AC_MSG_ERROR([Testing enabled but could not find gtest/gtest.h]) |
| 105 | ]) |
| 106 | ]) |
| 107 | AC_LANG_POP([C++]) |
| 108 | AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS]) |
| 109 | |
William A. Kennington III | c20acf6 | 2018-06-22 18:38:03 -0700 | [diff] [blame] | 110 | AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS]) |
| 111 | AX_APPEND_COMPILE_FLAGS([$GMOCK_CFLAGS], [CPPFLAGS]) |
| 112 | AC_LANG_PUSH([C++]) |
| 113 | AC_CHECK_HEADERS([gmock/gmock.h], [], [ |
| 114 | AS_IF([test "x$enable_tests" = "xyes"], [ |
| 115 | AC_MSG_ERROR([Testing enabled but could not find gmock/gmock.h]) |
| 116 | ]) |
| 117 | ]) |
| 118 | AC_LANG_POP([C++]) |
| 119 | AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS]) |
| 120 | |
William A. Kennington III | b4b3247 | 2018-06-21 16:38:47 -0700 | [diff] [blame] | 121 | AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS]) |
| 122 | AX_APPEND_COMPILE_FLAGS([$GTEST_LIBS], [LDFLAGS]) |
| 123 | AC_CHECK_LIB([gtest], [main], [ |
| 124 | AS_IF([test "x$GTEST_LIBS" = "x"], [ |
| 125 | AX_APPEND_COMPILE_FLAGS([-lgtest], [GTEST_LIBS]) |
| 126 | ]) |
| 127 | ], [ |
| 128 | AS_IF([test "x$enable_tests" = "xyes"], [ |
| 129 | AC_MSG_ERROR([Testing enabled but couldn't find gtest libs]) |
| 130 | ]) |
| 131 | ]) |
| 132 | AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS]) |
William A. Kennington III | c20acf6 | 2018-06-22 18:38:03 -0700 | [diff] [blame] | 133 | |
| 134 | AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS]) |
| 135 | AX_APPEND_COMPILE_FLAGS([$GMOCK_LIBS], [LDFLAGS]) |
| 136 | AC_CHECK_LIB([gmock], [main], [ |
| 137 | AS_IF([test "x$GMOCK_LIBS" = "x"], [ |
| 138 | AX_APPEND_COMPILE_FLAGS([-lgmock], [GMOCK_LIBS]) |
| 139 | ]) |
| 140 | ], [ |
| 141 | AS_IF([test "x$enable_tests" = "xyes"], [ |
| 142 | AC_MSG_ERROR([Testing enabled but couldn't find gmock libs]) |
| 143 | ]) |
| 144 | ]) |
| 145 | AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS]) |
William A. Kennington III | b4b3247 | 2018-06-21 16:38:47 -0700 | [diff] [blame] | 146 | ]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 147 | |
William A. Kennington III | 6c17d3d | 2018-06-19 18:34:43 -0700 | [diff] [blame] | 148 | # Check for valgrind |
William A. Kennington III | 387110b | 2018-08-21 19:23:19 -0700 | [diff] [blame] | 149 | AS_IF([test "x$enable_tests" = "xno"], [enable_valgrind=no]) |
| 150 | m4_foreach([vgtool], [valgrind_tool_list], |
| 151 | [AX_VALGRIND_DFLT(vgtool, [off])]) |
| 152 | AX_VALGRIND_DFLT([memcheck], [on]) |
| 153 | AX_VALGRIND_CHECK |
| 154 | AM_EXTRA_RECURSIVE_TARGETS([check-valgrind]) |
| 155 | m4_foreach([vgtool], [valgrind_tool_list], |
| 156 | [AM_EXTRA_RECURSIVE_TARGETS([check-valgrind-]vgtool)]) |
William A. Kennington III | 6c17d3d | 2018-06-19 18:34:43 -0700 | [diff] [blame] | 157 | |
William A. Kennington III | 592128c | 2018-06-19 18:34:17 -0700 | [diff] [blame] | 158 | # Code coverage |
William A. Kennington III | 387110b | 2018-08-21 19:23:19 -0700 | [diff] [blame] | 159 | AX_CODE_COVERAGE |
| 160 | AM_EXTRA_RECURSIVE_TARGETS([check-code-coverage]) |
William A. Kennington III | 592128c | 2018-06-19 18:34:17 -0700 | [diff] [blame] | 161 | |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 162 | AC_ARG_ENABLE([oe-sdk], |
| 163 | AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.]) |
| 164 | ) |
| 165 | AC_ARG_VAR(OECORE_TARGET_SYSROOT, |
| 166 | [Path to the OE SDK SYSROOT]) |
| 167 | AS_IF([test "x$enable_oe_sdk" == "xyes"], |
| 168 | AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"], |
| 169 | AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk]) |
| 170 | ) |
| 171 | AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT]) |
| 172 | [ |
| 173 | testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib" |
| 174 | testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib" |
| 175 | testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`" |
| 176 | ] |
| 177 | AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags]) |
| 178 | ) |
| 179 | |
James Feist | 284a0f9 | 2018-04-05 15:28:16 -0700 | [diff] [blame] | 180 | AC_ARG_ENABLE([boost], |
| 181 | AS_HELP_STRING([--enable-boost], [Enable building with boost.])) |
| 182 | AM_CONDITIONAL(BOOST, [test "x$enable_boost" = "xyes"]) |
| 183 | |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 184 | # Create configured output |
Brad Bishop | bba7f8c | 2016-11-10 09:32:58 -0500 | [diff] [blame] | 185 | AC_CONFIG_FILES([Makefile test/Makefile tools/Makefile tools/setup.py]) |
Patrick Williams | 4edb785 | 2017-07-03 11:50:11 -0500 | [diff] [blame] | 186 | AC_CONFIG_FILES([example/Makefile]) |
Adriana Kobylak | a1fb5e6 | 2017-01-30 11:41:19 -0600 | [diff] [blame] | 187 | AC_CONFIG_FILES([sdbusplus.pc]) |
Adriana Kobylak | fd43ef7 | 2017-02-12 09:12:37 -0600 | [diff] [blame] | 188 | AC_CONFIG_FILES([sdbusplus/bus.hpp]) |
| 189 | AC_CONFIG_FILES([sdbusplus/server.hpp]) |
| 190 | AC_CONFIG_FILES([tools/sdbusplus/templates/interface.mako.server.cpp]) |
| 191 | AC_CONFIG_FILES([tools/sdbusplus/templates/method.mako.prototype.hpp]) |
Adriana Kobylak | ee6ac69 | 2018-06-06 09:36:51 -0500 | [diff] [blame] | 192 | AC_CONFIG_FILES([tools/sdbusplus/templates/property.mako.prototype.hpp]) |
Patrick Williams | 5e0b681 | 2016-11-04 16:45:33 -0500 | [diff] [blame] | 193 | AC_OUTPUT |