blob: 217e2002e121abd7557d0117c0aa28761af5db50 [file] [log] [blame]
Patrick Williams5e0b6812016-11-04 16:45:33 -05001# Initialization
2AC_PREREQ([2.69])
3AC_INIT([sdbusplus], [1.0], [https://github.com/openbmc/sdbusplus/issues])
4AC_CONFIG_HEADERS([config.h])
William A. Kennington IIIc65d74e2018-06-19 18:32:09 -07005AC_CONFIG_MACRO_DIRS([m4])
6AC_CONFIG_AUX_DIR([build-aux])
Patrick Williams5e0b6812016-11-04 16:45:33 -05007AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
8AM_SILENT_RULES([yes])
9
10# Checks for programs.
Patrick Williams83a9d0b2016-11-04 17:06:13 -050011AC_PROG_CXX
Patrick Williams5e0b6812016-11-04 16:45:33 -050012AC_PROG_CC
13AM_PROG_AR
14AC_PROG_INSTALL
15AC_PROG_MAKE_SET
16
Brad Bishopbba7f8c2016-11-10 09:32:58 -050017# setup sdbus++
18AM_PATH_PYTHON([2.7], [AC_SUBST([PYTHON], [echo "$PYTHON"])])
19AC_SUBST([PYTHONDIR], ${pythondir})
20AS_IF([test "$PYTHON" != :], [have_python=yes], [have_python=no])
21
22AC_ARG_ENABLE([sdbuspp],
23 AS_HELP_STRING([--disable-sdbuspp], [Disable sdbus++]))
24
25AS_IF([test "x$enable_sdbuspp" != "xno"],
26 [AS_IF([test "x$have_python" = "xno"], [AC_MSG_ERROR([sdbus++ requires python])])])
27
28AM_CONDITIONAL([WANT_SDBUSPP], [test "x$enable_sdbuspp" != "xno"])
29
Brad Bishop14275cf2016-11-10 16:24:48 -050030# setup libsdbusplus
Brad Bishop5e703892017-02-10 11:52:48 -050031AX_PKG_CHECK_MODULES(
32 [SYSTEMD],
33 [libsystemd >= 221],
34 [],
35 [have_systemd=yes],
36 [have_systemd=no])
Brad Bishop14275cf2016-11-10 16:24:48 -050037AC_ARG_ENABLE([libsdbusplus],
38 AS_HELP_STRING([--disable-libsdbusplus], [Disable libsdbusplus]))
39
40AS_IF([test "x$enable_libsdbusplus" != "xno"],
41 [AS_IF([test "x$have_systemd" = "xno"], [AC_MSG_ERROR([libsdbusplus requires systemd])])])
42
43AM_CONDITIONAL([WANT_LIBSDBUSPLUS], [test "x$enable_libsdbusplus" != "xno"])
Patrick Williams5e0b6812016-11-04 16:45:33 -050044
Adriana Kobylakfd43ef72017-02-12 09:12:37 -060045# setup transaction
46AC_ARG_ENABLE([transaction],
47 AS_HELP_STRING([--enable-transaction], [Enable transaction id support.]))
48AC_ARG_VAR(WANT_TRANSACTION, [Enable transaction id support.])
49AS_IF([test "x$enable_transaction" = "xyes"], \
50 [WANT_TRANSACTION="1"], \
51 [WANT_TRANSACTION="0"])
52AM_CONDITIONAL([WANT_TRANSACTION], [test "x$enable_transaction" = "xyes"])
53
Patrick Williams5e0b6812016-11-04 16:45:33 -050054# Checks for header files.
Patrick Williamsab7de322017-01-06 15:14:45 -060055AS_IF([test "x$enable_libsdbusplus" != "xno"],
Gunnar Millsa4b4a0b2018-04-08 14:30:38 -050056 [AC_CHECK_HEADER(systemd/sd-bus.h, ,[AC_MSG_ERROR([Could not find systemd/sd-bus.h...systemd development package required])])])
Patrick Williams5e0b6812016-11-04 16:45:33 -050057
58# Checks for typedefs, structures, and compiler characteristics.
Patrick Williamsab7de322017-01-06 15:14:45 -060059AS_IF([test "x$enable_libsdbusplus" != "xno"],
Brad Bishop14275cf2016-11-10 16:24:48 -050060 [AX_CXX_COMPILE_STDCXX_14([noext])])
Patrick Williams83a9d0b2016-11-04 17:06:13 -050061AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CFLAGS])
62AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS])
Patrick Williams5e0b6812016-11-04 16:45:33 -050063
64# Checks for library functions.
65LT_INIT # Removes 'unrecognized options: --with-libtool-sysroot'
66
William A. Kennington IIIb4b32472018-06-21 16:38:47 -070067# Make it possible for users to choose if they want test support
68# explicitly or not at all
69AC_ARG_ENABLE([tests], [Whether we should build test cases])
70
71# Legacy tests require pthread support
72AS_IF([test "x$enable_tests" != "xno"], [
73 AX_PTHREAD([], [
74 AS_IF([test "x$enable_tests" != "xyes"], [
75 AC_MSG_ERROR([Testing enabled but could not find pthreads])
76 ])
77 ])
78])
79
Patrick Williams5e0b6812016-11-04 16:45:33 -050080# Check/set gtest specific functions.
William A. Kennington IIIb4b32472018-06-21 16:38:47 -070081AS_IF([test "x$enable_tests" != "xno"], [
William A. Kennington III40c22792018-06-29 16:21:17 -070082 PKG_CHECK_MODULES([GTEST], [gtest], [], [true])
William A. Kennington IIIb4b32472018-06-21 16:38:47 -070083
84 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
85 AX_APPEND_COMPILE_FLAGS([$GTEST_CFLAGS], [CPPFLAGS])
86 AC_LANG_PUSH([C++])
87 AC_CHECK_HEADERS([gtest/gtest.h], [
88 AS_IF([test "x$GTEST_CFLAGS" = "x"], [
89 AS_IF([test "x$PTHREAD_CFLAGS" = "x"], [
90 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=0"], [GTEST_CFLAGS])
91 ], [
92 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=1"], [GTEST_CFLAGS])
93 AX_APPEND_COMPILE_FLAGS([$PTHREAD_CFLAGS], [GTEST_CFLAGS])
94 ])
95 ])
96 ], [
97 AS_IF([test "x$enable_tests" = "xyes"], [
98 AC_MSG_ERROR([Testing enabled but could not find gtest/gtest.h])
99 ])
100 ])
101 AC_LANG_POP([C++])
102 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
103
104 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
105 AX_APPEND_COMPILE_FLAGS([$GTEST_LIBS], [LDFLAGS])
106 AC_CHECK_LIB([gtest], [main], [
107 AS_IF([test "x$GTEST_LIBS" = "x"], [
108 AX_APPEND_COMPILE_FLAGS([-lgtest], [GTEST_LIBS])
109 ])
110 ], [
111 AS_IF([test "x$enable_tests" = "xyes"], [
112 AC_MSG_ERROR([Testing enabled but couldn't find gtest libs])
113 ])
114 ])
115 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
116])
Patrick Williams5e0b6812016-11-04 16:45:33 -0500117
118AC_ARG_ENABLE([oe-sdk],
119 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
120)
121AC_ARG_VAR(OECORE_TARGET_SYSROOT,
122 [Path to the OE SDK SYSROOT])
123AS_IF([test "x$enable_oe_sdk" == "xyes"],
124 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
125 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
126 )
127 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
128 [
129 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
130 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
131 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
132 ]
133 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
134)
135
James Feist284a0f92018-04-05 15:28:16 -0700136AC_ARG_ENABLE([boost],
137 AS_HELP_STRING([--enable-boost], [Enable building with boost.]))
138AM_CONDITIONAL(BOOST, [test "x$enable_boost" = "xyes"])
139
Patrick Williams5e0b6812016-11-04 16:45:33 -0500140# Create configured output
Brad Bishopbba7f8c2016-11-10 09:32:58 -0500141AC_CONFIG_FILES([Makefile test/Makefile tools/Makefile tools/setup.py])
Patrick Williams4edb7852017-07-03 11:50:11 -0500142AC_CONFIG_FILES([example/Makefile])
Adriana Kobylaka1fb5e62017-01-30 11:41:19 -0600143AC_CONFIG_FILES([sdbusplus.pc])
Adriana Kobylakfd43ef72017-02-12 09:12:37 -0600144AC_CONFIG_FILES([sdbusplus/bus.hpp])
145AC_CONFIG_FILES([sdbusplus/server.hpp])
146AC_CONFIG_FILES([tools/sdbusplus/templates/interface.mako.server.cpp])
147AC_CONFIG_FILES([tools/sdbusplus/templates/method.mako.prototype.hpp])
Adriana Kobylakee6ac692018-06-06 09:36:51 -0500148AC_CONFIG_FILES([tools/sdbusplus/templates/property.mako.prototype.hpp])
Patrick Williams5e0b6812016-11-04 16:45:33 -0500149AC_OUTPUT