dnsproxy: safely access server_list_sec for removing a list node
[platform/upstream/connman.git] / configure.ac
1 AC_PREREQ(2.60)
2 AC_INIT(connman, 1.41)
3
4 AC_CONFIG_MACRO_DIR([m4])
5
6 AM_INIT_AUTOMAKE([foreign subdir-objects color-tests])
7 AC_CONFIG_HEADERS([config.h])
8
9 m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
10
11 AM_MAINTAINER_MODE
12
13 AC_PREFIX_DEFAULT(/usr/local)
14
15 PKG_PROG_PKG_CONFIG
16
17 COMPILER_FLAGS
18
19 AC_SUBST(abs_top_srcdir)
20 AC_SUBST(abs_top_builddir)
21
22 AC_LANG_C
23 AC_USE_SYSTEM_EXTENSIONS
24
25 AC_PROG_CC
26 AM_PROG_CC_C_O
27 AC_PROG_CC_PIE
28 AC_PROG_INSTALL
29 AC_PROG_MKDIR_P
30
31 m4_define([_LT_AC_TAGCONFIG], [])
32 m4_ifdef([AC_LIBTOOL_TAGS], [AC_LIBTOOL_TAGS([])])
33
34 AC_DISABLE_STATIC
35 AC_PROG_LIBTOOL
36
37 gl_CONFIGMAKE_PREP
38
39 AC_ARG_ENABLE(optimization, AS_HELP_STRING([--disable-optimization],
40                         [disable code optimization through compiler]), [
41         if (test "${enableval}" = "no"); then
42                 CFLAGS="$CFLAGS -O0 -U_FORTIFY_SOURCE"
43         fi
44 ])
45
46 AC_ARG_ENABLE(debug, AS_HELP_STRING([--enable-debug],
47                         [enable compiling with debugging information]), [
48         if (test "${enableval}" = "yes" &&
49                                 test "${ac_cv_prog_cc_g}" = "yes"); then
50                 CFLAGS="$CFLAGS -g"
51         fi
52 ])
53
54 AC_ARG_ENABLE(pie, AS_HELP_STRING([--enable-pie],
55                         [enable position independent executables flag]), [
56         if (test "${enableval}" = "yes" &&
57                                 test "${ac_cv_prog_cc_pie}" = "yes"); then
58                 CFLAGS="$CFLAGS -fPIE"
59                 LDFLAGS="$LDFLAGS -pie"
60         fi
61 ])
62
63 AC_ARG_ENABLE(hh2serial-gps,
64         AS_HELP_STRING([--enable-hh2serial-gps], [enable hh2serial GPS support]),
65                         [enable_hh2serial_gps=${enableval}], [enable_hh2serial_gps="no"])
66 AM_CONDITIONAL(HH2SERIAL_GPS, test "${enable_hh2serial_gps}" != "no")
67 AM_CONDITIONAL(HH2SERIAL_GPS_BUILTIN, test "${enable_hh2serial_gps}" = "builtin")
68
69 AC_ARG_ENABLE(telephony,
70         AS_HELP_STRING([--enable-telephony], [enable Telephony support]),
71                         [enable_telephony=${enableval}], [enable_telephony="yes"])
72 AM_CONDITIONAL(TELEPHONY, test "${enable_telephony}" != "no")
73 AM_CONDITIONAL(TELEPHONY_BUILTIN, test "${enable_telephony}" = "builtin")
74
75 AC_ARG_ENABLE(tizen-ext,
76         AS_HELP_STRING([--enable-tizen-ext], [enable TIZEN extensions]),
77                         [if (test "${enableval}" = "yes"); then
78                                 CFLAGS="$CFLAGS -DTIZEN_EXT"
79                                 LIBS="$LIBS -lsmack"
80                         fi])
81 AM_CONDITIONAL(TIZEN_EXT, test "${enable-tizen-ext}" != "no")
82
83 AC_ARG_ENABLE(tizen-ext-wifi-mesh,
84         AS_HELP_STRING([--enable-tizen-ext-wifi-mesh], [enable TIZEN extensions for Wi-Fi Mesh]),
85                         [CFLAGS="$CFLAGS -DTIZEN_EXT_WIFI_MESH"], [enable_tizen_ext_wifi_mesh="no"])
86 AM_CONDITIONAL(TIZEN_EXT_WIFI_MESH, test "${enable_tizen_ext_wifi_mesh}" != "no")
87
88 AC_ARG_ENABLE(tizen-ext-eap-on-ethernet,
89         AS_HELP_STRING([--enable-tizen-ext-eap-on-ethernet], [enable TIZEN extensions for EAP on Ethernet]),
90                         [CFLAGS="$CFLAGS -DTIZEN_EXT_EAP_ON_ETHERNET"], [enable_tizen_ext_eap_on_ethernet="no"])
91 AM_CONDITIONAL(TIZEN_EXT_EAP_ON_ETHERNET, test "${enable_tizen_ext_eap_on_ethernet}" != "no")
92
93 AC_ARG_ENABLE(tizen-maintain-online,
94         AS_HELP_STRING([--enable-tizen-maintain-online], [enable TIZEN extensions]),
95                         [if (test "${enableval}" = "yes"); then
96                                 CFLAGS="$CFLAGS -DTIZEN_MAINTAIN_ONLINE"
97                                 LIBS="$LIBS -lsmack"
98                         fi])
99
100 AC_ARG_WITH(openconnect, AS_HELP_STRING([--with-openconnect=PROGRAM],
101         [specify location of openconnect binary]), [path_openconnect=${withval}])
102
103 AC_ARG_ENABLE(openconnect,
104         AS_HELP_STRING([--enable-openconnect], [enable openconnect support]),
105                         [enable_openconnect=${enableval}], [enable_openconnect="no"])
106 if (test "${enable_openconnect}" != "no"); then
107         if (test -z "${path_openconnect}"); then
108                 AC_PATH_PROG(OPENCONNECT, [openconnect], [], $PATH:/bin:/usr/bin)
109                 if (test -z "${OPENCONNECT}"); then
110                         AC_MSG_ERROR(openconnect binary not found)
111                 fi
112         else
113                 OPENCONNECT="${path_openconnect}"
114                 AC_SUBST(OPENCONNECT)
115         fi
116         PKG_CHECK_MODULES(LIBOPENCONNECT, openconnect >= 8, [],
117                 AC_MSG_ERROR(openconnect >= 8 is required))
118 fi
119 AM_CONDITIONAL(OPENCONNECT, test "${enable_openconnect}" != "no")
120 AM_CONDITIONAL(OPENCONNECT_BUILTIN, test "${enable_openconnect}" = "builtin")
121
122 AC_ARG_WITH(openvpn, AS_HELP_STRING([--with-openvpn=PROGRAM],
123         [specify location of openvpn binary]), [path_openvpn=${withval}])
124
125 AC_ARG_ENABLE(openvpn,
126         AS_HELP_STRING([--enable-openvpn], [enable openvpn support]),
127                         [enable_openvpn=${enableval}], [enable_openvpn="no"])
128 if (test "${enable_openvpn}" != "no"); then
129         if (test -z "${path_openvpn}"); then
130                 AC_PATH_PROG(OPENVPN, [openvpn], [/usr/bin/openvpn], $PATH:/bin:/usr/bin)
131                 if (test -z "${OPENVPN}"); then
132                         AC_MSG_ERROR(openvpn binary not found)
133                 fi
134         else
135                 OPENVPN="${path_openvpn}"
136                 AC_SUBST(OPENVPN)
137         fi
138 fi
139 AM_CONDITIONAL(OPENVPN, test "${enable_openvpn}" != "no")
140 AM_CONDITIONAL(OPENVPN_BUILTIN, test "${enable_openvpn}" = "builtin")
141
142 AC_ARG_WITH(ipsec, AS_HELP_STRING([--with-ipsec=PROGRAM],
143         [specify location of ipsec binary]), [path_ipsec=${withval}])
144
145 AC_ARG_ENABLE(ipsec,
146         AS_HELP_STRING([--enable-ipsec], [enable ipsec support]),
147                         [enable_ipsec=${enableval}], [enable_ipsec="no"])
148 if (test "${enable_ipsec}" != "no"); then
149         PKG_CHECK_MODULES(GIO, gio-2.0 >= 2.28, dummy=yes,
150                                         AC_MSG_ERROR(GIO >= 2.28 is required))
151         AC_SUBST(GIO_CFLAGS)
152         AC_SUBST(GIO_LIBS)
153         if (test -z "${path_ipsec}"); then
154                 AC_PATH_PROG(IPSEC, [charon], [/usr/bin/charon], $PATH:/usr/bin)
155                 if (test -z "${IPSEC}"); then
156                         AC_MSG_ERROR(ipsec binary not found)
157                 fi
158         else
159                 IPSEC="${path_ipsec}"
160                 AC_SUBST(IPSEC)
161         fi
162 fi
163 AM_CONDITIONAL(IPSEC, test "${enable_ipsec}" != "no")
164 AM_CONDITIONAL(IPSEC_BUILTIN, test "${enable_ipsec}" = "builtin")
165
166 AC_ARG_WITH(vpnc, AS_HELP_STRING([--with-vpnc=PROGRAM],
167         [specify location of vpnc binary]), [path_vpnc=${withval}])
168
169 AC_ARG_ENABLE(vpnc,
170         AS_HELP_STRING([--enable-vpnc], [enable vpnc support]),
171                 [enable_vpnc=${enableval}], [enable_vpnc="no"])
172 if (test "${enable_vpnc}" != "no"); then
173         if (test -z "${path_vpnc}"); then
174                 AC_PATH_PROG(VPNC, [vpnc], [], $PATH:/bin:/usr/bin)
175                 if (test -z "${VPNC}"); then
176                         AC_MSG_ERROR(vpnc binary not found)
177                 fi
178         else
179                 VPNC="${path_vpnc}"
180                 AC_SUBST(VPNC)
181         fi
182 fi
183 AM_CONDITIONAL(VPNC, test "${enable_vpnc}" != "no")
184 AM_CONDITIONAL(VPNC_BUILTIN, test "${enable_vpnc}" = "builtin")
185
186 AC_ARG_WITH(l2tp, AS_HELP_STRING([--with-l2tp=PROGRAM],
187         [specify location of l2tp binary]), [path_l2tp=${withval}])
188
189 AC_ARG_ENABLE(l2tp,
190         AS_HELP_STRING([--enable-l2tp], [enable l2tp support]),
191                         [enable_l2tp=${enableval}], [enable_l2tp="no"])
192 if (test "${enable_l2tp}" != "no"); then
193         if (test -z "${path_pppd}"); then
194                 AC_PATH_PROG(PPPD, [pppd], [/usr/bin/pppd], $PATH:/bin:/usr/bin)
195         else
196                 PPPD="${path_pppd}"
197                 AC_SUBST(PPPD)
198         fi
199         AC_CHECK_HEADERS(pppd/pppd.h, dummy=yes,
200                         AC_MSG_ERROR(ppp header files are required))
201         if (test -z "${path_l2tp}"); then
202                 AC_PATH_PROG(L2TP, [xl2tpd], [/usr/bin/xl2tpd], $PATH:/bin:/usr/bin)
203         else
204                 L2TP="${path_l2tp}"
205                 AC_SUBST(L2TP)
206         fi
207 fi
208 AM_CONDITIONAL(L2TP, test "${enable_l2tp}" != "no")
209 AM_CONDITIONAL(L2TP_BUILTIN, test "${enable_l2tp}" = "builtin")
210
211 AC_ARG_WITH(pptp, AS_HELP_STRING([--with-pptp=PROGRAM],
212         [specify location of pptp binary]), [path_pptp=${withval}])
213
214 AC_ARG_ENABLE(pptp,
215         AS_HELP_STRING([--enable-pptp], [enable pptp support]),
216                         [enable_pptp=${enableval}], [enable_pptp="no"])
217 if (test "${enable_pptp}" != "no"); then
218         if (test -z "${path_pppd}"); then
219                 AC_PATH_PROG(PPPD, [pppd], [/usr/bin/pppd], $PATH:/bin:/usr/bin)
220         else
221                 PPPD="${path_pppd}"
222                 AC_SUBST(PPPD)
223         fi
224         AC_CHECK_HEADERS(pppd/pppd.h, dummy=yes,
225                         AC_MSG_ERROR(ppp header files are required))
226         if (test -z "${path_pptp}"); then
227                 AC_PATH_PROG(PPTP, [pptp], [/usr/bin/pptp], $PATH:/bin:/usr/bin)
228         else
229                 PPTP="${path_pptp}"
230                 AC_SUBST(PPTP)
231         fi
232 fi
233 AM_CONDITIONAL(PPTP, test "${enable_pptp}" != "no")
234 AM_CONDITIONAL(PPTP_BUILTIN, test "${enable_pptp}" = "builtin")
235
236 AC_CHECK_HEADERS(resolv.h, dummy=yes,
237         AC_MSG_ERROR(resolver header files are required))
238 AC_CHECK_LIB(resolv, ns_initparse, dummy=yes, [
239         AC_CHECK_LIB(resolv, __ns_initparse, dummy=yes,
240                 AC_MSG_ERROR(resolver library support is required))
241 ])
242
243 AC_CHECK_HEADERS([execinfo.h])
244 AM_CONDITIONAL([BACKTRACE], [test "${ac_cv_header_execinfo_h}" = "yes"])
245
246 AC_CHECK_MEMBERS([struct in6_pktinfo.ipi6_addr], [], [], [[#include <netinet/in.h>]])
247
248 AC_CHECK_FUNC(signalfd, dummy=yes,
249                         AC_MSG_ERROR(signalfd support is required))
250
251 AC_CHECK_LIB(dl, dlopen, dummy=yes,
252                         AC_MSG_ERROR(dynamic linking loader is required))
253
254 AC_ARG_ENABLE(iospm, AS_HELP_STRING([--enable-iospm],
255                 [enable Intel OSPM support]), [enable_iospm=${enableval}])
256 AM_CONDITIONAL(IOSPM, test "${enable_iospm}" = "yes")
257
258 AC_ARG_ENABLE(tist,
259         AS_HELP_STRING([--enable-tist], [enable TI Shared Transport support]),
260                         [enable_tist=${enableval}], [enable_tist="no"])
261 AM_CONDITIONAL(TIST, test "${enable_tist}" != "no")
262 AM_CONDITIONAL(TIST_BUILTIN, test "${enable_tist}" = "builtin")
263
264 AC_ARG_ENABLE(session-policy-local,
265         AS_HELP_STRING([--enable-session-policy-local], [enable local file Session policy configuration support]),
266                         [enable_session_policy_local=${enableval}], [enable_session_policy_local="no"])
267 AM_CONDITIONAL(SESSION_POLICY_LOCAL, test "${enable_session_policy_local}" != "no")
268 AM_CONDITIONAL(SESSION_POLICY_LOCAL_BUILTIN, test "${enable_session_policy_local}" = "builtin")
269
270 AC_ARG_WITH(stats-max-file-size, AS_HELP_STRING([--with-stats-max-file-size=SIZE],
271                         [Maximal size of a statistics round robin file]),
272                         [stats_max_file_size=${withval}])
273
274 if (test -z "${stats_max_file_size}"); then
275    # default size is 16 kByte
276    stats_max_file_size="16 * 8 * 128"
277 fi
278
279 AC_DEFINE_UNQUOTED([STATS_MAX_FILE_SIZE], (${stats_max_file_size}), [Maximal size of a statistics round robin file])
280
281 PKG_CHECK_MODULES(GLIB, glib-2.0 >= 2.40, dummy=yes,
282                                 AC_MSG_ERROR(GLib >= 2.40 is required))
283 AC_SUBST(GLIB_CFLAGS)
284 AC_SUBST(GLIB_LIBS)
285
286 PKG_CHECK_MODULES(LIBNL, libnl-3.0, dummy=yes,
287                                 AC_MSG_ERROR(libnl-3.0 is required))
288 AC_SUBST(LIBNL_CFLAGS)
289 AC_SUBST(LIBNL_LIBS)
290
291 PKG_CHECK_MODULES(LIBNL_GENL, libnl-genl-3.0, dummy=yes,
292                                 AC_MSG_ERROR(libnl-genl-3.0 is required))
293 AC_SUBST(LIBNL_GENL_CFLAGS)
294 AC_SUBST(LIBNL_GENL_LIBS)
295
296 PKG_CHECK_MODULES(LIBSYSTEMD, libsystemd, dummy=yes,
297                                 AC_MSG_ERROR(libsystemd library is required))
298 AC_SUBST(LIBSYSTEMD_CFLAGS)
299 AC_SUBST(LIBSYSTEMD_LIBS)
300
301 PKG_CHECK_MODULES(DBUS, dbus-1 >= 1.4, dummy=yes,
302                                 AC_MSG_ERROR(D-Bus >= 1.4 is required))
303 AC_SUBST(DBUS_CFLAGS)
304 AC_SUBST(DBUS_LIBS)
305
306 PKG_CHECK_MODULES(DLOG, dlog, dummy=yes,
307                                 AC_MSG_ERROR(dlog is required))
308 AC_SUBST(DLOG_CFLAGS)
309 AC_SUBST(DLOG_LIBS)
310
311 AC_ARG_WITH(dbusconfdir, AS_HELP_STRING([--with-dbusconfdir=PATH],
312         [path to D-Bus config directory]), [path_dbusconf=${withval}],
313                 [path_dbusconf="`$PKG_CONFIG --variable=sysconfdir dbus-1`"])
314 if (test -z "${path_dbusconf}"); then
315         DBUS_CONFDIR="${sysconfdir}/dbus-1/system.d"
316 else
317         DBUS_CONFDIR="${path_dbusconf}/dbus-1/system.d"
318 fi
319 AC_SUBST(DBUS_CONFDIR)
320
321 AC_ARG_WITH(dbusdatadir, AS_HELP_STRING([--with-dbusdatadir=PATH],
322         [path to D-Bus data directory]), [path_dbusdata=${withval}],
323                 [path_dbusdata="`$PKG_CONFIG --variable=datadir dbus-1`"])
324 if (test -z "${path_dbusdata}"); then
325         DBUS_DATADIR="${datadir}/dbus-1/system-services"
326 else
327         DBUS_DATADIR="${path_dbusdata}/dbus-1/system-services"
328 fi
329 AC_SUBST(DBUS_DATADIR)
330
331 AC_ARG_WITH([systemdunitdir], AS_HELP_STRING([--with-systemdunitdir=DIR],
332         [path to systemd service directory]), [path_systemdunit=${withval}],
333                 [path_systemdunit="`$PKG_CONFIG --variable=systemdsystemunitdir systemd`"])
334 if (test -n "${path_systemdunit}"); then
335         SYSTEMD_UNITDIR="${path_systemdunit}"
336         AC_SUBST(SYSTEMD_UNITDIR)
337 fi
338 AM_CONDITIONAL(SYSTEMD, test -n "${path_systemdunit}")
339
340 AC_ARG_WITH([tmpfilesdir], AS_HELP_STRING([--with-tmpfilesdir=DIR],
341         [path to systemd tmpfiles.d directory]), [path_tmpfiles=${withval}],
342                 [path_tmpfiles="`$PKG_CONFIG --variable=tmpfilesdir systemd`"])
343 if (test -n "${path_tmpfiles}"); then
344         SYSTEMD_TMPFILESDIR="${path_tmpfiles}"
345         AC_SUBST(SYSTEMD_TMPFILESDIR)
346 fi
347
348 AC_ARG_WITH(firewall, AS_HELP_STRING([--with-firewall=TYPE],
349                         [specify which firewall type is used iptables or nftables [default=iptables]]),
350                 [firewall_type=${withval}],
351                 [firewall_type="iptables"])
352
353 if (test "${firewall_type}" != "iptables" -a \
354                 "${firewall_type}" != "nftables"); then
355         AC_MSG_ERROR(neither nftables nor iptables support enabled)
356 fi
357
358 found_iptables="no"
359 if (test "${firewall_type}" = "iptables"); then
360         PKG_CHECK_MODULES(XTABLES, xtables >= 1.4.11, [found_iptables="yes"],
361                         AC_MSG_ERROR(Xtables library is required))
362         AC_SUBST(XTABLES_CFLAGS)
363         AC_SUBST(XTABLES_LIBS)
364 fi
365 AM_CONDITIONAL(XTABLES, test "${found_iptables}" != "no")
366
367 found_libmnl="no"
368 if (test "${firewall_type}" = "nftables" -o \
369                 "${enable_wireguard}" != "no"); then
370         PKG_CHECK_MODULES(LIBMNL, [libmnl >= 1.0.0], [found_libmnl="yes"],
371                 AC_MSG_ERROR([libmnl >= 1.0.0 not found]))
372         AC_SUBST(LIBMNL_CFLAGS)
373         AC_SUBST(LIBMNL_LIBS)
374 fi
375 AM_CONDITIONAL(LIBMNL, test "${found_libmnl}" != "no")
376
377 found_nftables="no"
378 if (test "${firewall_type}" = "nftables"); then
379         PKG_CHECK_MODULES(NFTABLES, [libnftnl >= 1.0.4], [found_nftables="yes"],
380                 AC_MSG_ERROR([libnftnl >= 1.0.4]))
381         AC_SUBST(NFTABLES_CFLAGS)
382         AC_SUBST(NFTABLES_LIBS)
383 fi
384 AM_CONDITIONAL(NFTABLES, test "${found_nftables}" != "no")
385
386 AC_ARG_ENABLE(test, AS_HELP_STRING([--enable-test],
387                 [enable test/example scripts]), [enable_test=${enableval}])
388 AM_CONDITIONAL(TEST, test "${enable_test}" = "yes")
389
390 AC_ARG_ENABLE(nmcompat, AS_HELP_STRING([--enable-nmcompat],
391                                 [enable Network Manager support]),
392                         [enable_nmcompat=${enableval}], [enable_nmcompat="no"])
393 AM_CONDITIONAL(NMCOMPAT, test "${enable_nmcompat}" != "no")
394
395 AC_ARG_ENABLE(polkit, AS_HELP_STRING([--enable-polkit],
396                                 [enable PolicyKit support]),
397                         [enable_polkit=${enableval}], [enable_polkit="no"])
398 if (test "${enable_polkit}" != "no"); then
399         POLKIT_DATADIR="`$PKG_CONFIG --variable=actiondir polkit`"
400         POLKIT_DATADIR=""
401         if (test -z "${POLKIT_DATADIR}"); then
402                 POLKIT_DATADIR="${datadir}/polkit-1/actions"
403         fi
404         AC_SUBST(POLKIT_DATADIR)
405 fi
406 AM_CONDITIONAL(POLKIT, test "${enable_polkit}" != "no")
407
408 AC_ARG_ENABLE(selinux, AS_HELP_STRING([--enable-selinux],
409                                 [enable selinux support]),
410                         [enable_selinux=${enableval}], [enable_selinux="no"])
411 AM_CONDITIONAL(SELINUX, test "${enable_selinux}" != "no")
412
413 AC_ARG_ENABLE(loopback, AS_HELP_STRING([--disable-loopback],
414                                 [disable loopback support]),
415                                         [enable_loopback=${enableval}])
416 AM_CONDITIONAL(LOOPBACK, test "${enable_loopback}" != "no")
417
418 AC_ARG_ENABLE(ethernet, AS_HELP_STRING([--disable-ethernet],
419                                 [disable Ethernet support]),
420                                         [enable_ethernet=${enableval}])
421 AM_CONDITIONAL(ETHERNET, test "${enable_ethernet}" != "no")
422
423 AC_ARG_ENABLE(wireguard, AS_HELP_STRING([--disable-wireguard],
424                                 [disable Wireguard support]),
425                                         [enable_wireguard=${enableval}])
426 AM_CONDITIONAL(WIREGUARD, test "${enable_wireguard}" != "no")
427 AM_CONDITIONAL(WIREGUARD_BUILTIN, test "${enable_wireguard}" = "builtin")
428
429 AC_ARG_ENABLE(gadget, AS_HELP_STRING([--disable-gadget],
430                                 [disable USB Gadget support]),
431                                         [enable_gadget=${enableval}])
432 AM_CONDITIONAL(GADGET, test "${enable_gadget}" != "no")
433
434 AC_ARG_ENABLE(wifi, AS_HELP_STRING([--disable-wifi],
435                                 [disable WiFi support]),
436                                         [enable_wifi=${enableval}])
437 AM_CONDITIONAL(WIFI, test "${enable_wifi}" != "no")
438
439 AC_ARG_ENABLE(iwd, AS_HELP_STRING([--enable-iwd],
440                                 [enable iwd support]),
441                                         [enable_iwd=${enableval}])
442 AM_CONDITIONAL(IWD, test "${enable_iwd}" = "yes")
443
444 AC_ARG_ENABLE(bluetooth, AS_HELP_STRING([--disable-bluetooth],
445                                 [disable Bluetooth support]),
446                                         [enable_bluetooth=${enableval}])
447 AM_CONDITIONAL(BLUETOOTH, test "${enable_bluetooth}" != "no")
448
449 AC_ARG_ENABLE(ofono, AS_HELP_STRING([--disable-ofono],
450                                 [disable oFono support]),
451                                         [enable_ofono=${enableval}])
452 AM_CONDITIONAL(OFONO, test "${enable_ofono}" != "no")
453
454 AC_ARG_ENABLE(dundee, AS_HELP_STRING([--disable-dundee],
455                                 [disable dundee support (Bluetooth DUN)]),
456                                         [enable_dundee=${enableval}])
457 AM_CONDITIONAL(DUNDEE, test "${enable_dundee}" != "no")
458
459 AC_ARG_ENABLE(pacrunner, AS_HELP_STRING([--disable-pacrunner],
460                                 [disable PACrunner support]),
461                                         [enable_pacrunner=${enableval}])
462 AM_CONDITIONAL(PACRUNNER, test "${enable_pacrunner}" != "no")
463
464 AC_ARG_ENABLE(neard, AS_HELP_STRING([--disable-neard],
465                                 [disable Neard support]),
466                                         [enable_neard=${enableval}])
467 AM_CONDITIONAL(NEARD, test "${enable_neard}" != "no")
468
469 AC_ARG_ENABLE(wispr, AS_HELP_STRING([--disable-wispr],
470                                 [disable WISPr support]),
471                                         [enable_wispr=${enableval}])
472 AM_CONDITIONAL(WISPR, test "${enable_wispr}" != "no")
473
474 AC_ARG_ENABLE(backtrace, AS_HELP_STRING([--disable-backtrace],
475                                 [disable backtrace support]),
476                                         [enable_backtrace=${enableval}])
477 AM_CONDITIONAL(BACKTRACE, test "${enable_backtrace}" != "no")
478
479 AC_ARG_ENABLE(tools, AS_HELP_STRING([--disable-tools],
480                                 [disable testing tools]),
481                                         [enable_tools=${enableval}])
482 AM_CONDITIONAL(TOOLS, test "${enable_tools}" != "no")
483
484 AC_ARG_ENABLE(stats, AS_HELP_STRING([--disable-stats],
485                                 [disable statistics round robin file generation]),
486                                         [enable_stats=${enableval}])
487 AM_CONDITIONAL(STATS, test "${enable_stats}" != "no")
488
489 if (test "${enable_tools}" != "no"); then
490         AC_PATH_PROGS(IPTABLES_SAVE, [iptables-save], [],
491                                                 $PATH:/bin:/usr/bin)
492         AC_PATH_PROGS(IP6TABLES_SAVE, [ip6tables-save], [],
493                                                 $PATH:/bin:/usr/bin)
494         IPTABLES_SAVE=$ac_cv_path_IPTABLES_SAVE
495         IP6TABLES_SAVE=$ac_cv_path_IP6TABLES_SAVE
496 else
497         IPTABLES_SAVE=""
498         IP6TABLES_SAVE=""
499 fi
500 AC_SUBST(IPTABLES_SAVE)
501 AC_SUBST(IP6TABLES_SAVE)
502
503 AC_ARG_ENABLE(client, AS_HELP_STRING([--disable-client],
504                                 [disable command line client]),
505                                         [enable_client=${enableval}])
506 AM_CONDITIONAL(CLIENT, test "${enable_client}" != "no")
507
508 if (test "${enable_wispr}" != "no"); then
509         PKG_CHECK_MODULES(GNUTLS, gnutls, dummy=yes,
510                                 AC_MSG_ERROR(GnuTLS library is required))
511 else
512         GNUTLS_CFLAGS=""
513         GNUTLS_LIBS=""
514 fi
515 AC_SUBST(GNUTLS_CFLAGS)
516 AC_SUBST(GNUTLS_LIBS)
517
518 if (test "${enable_loopback}" != "no"); then
519         AC_CHECK_HEADERS(sys/inotify.h, dummy=yes,
520                         AC_MSG_ERROR(inotify header files are required))
521
522         AC_CHECK_LIB(c, inotify_init, dummy=yes,
523                         AC_MSG_ERROR(inotify library support is required))
524 fi
525
526 if (test "${enable_wifi}" != "no"); then
527         AC_PATH_PROG(WPASUPPLICANT, [wpa_supplicant], [],
528                                                 $PATH:/bin:/usr/bin)
529 fi
530
531 AC_ARG_ENABLE(datafiles, AS_HELP_STRING([--disable-datafiles],
532                         [don't install configuration and data files]),
533                                         [enable_datafiles=${enableval}])
534 AM_CONDITIONAL(DATAFILES, test "${enable_datafiles}" != "no")
535
536 if (test "${enable_client}" != "no"); then
537         AC_CHECK_HEADERS(readline/readline.h, dummy=yes,
538                 AC_MSG_ERROR(readline header files are required))
539 fi
540
541 AM_CONDITIONAL(VPN, test "${enable_openconnect}" != "no" -o \
542                         "${enable_openvpn}" != "no" -o \
543                         "${enable_ipsec}" != "no" -o \
544                         "${enable_vpnc}" != "no" -o \
545                         "${enable_l2tp}" != "no" -o \
546                         "${enable_pptp}" != "no" -o \
547                         "${enable_wireguard}" != "no")
548
549 AC_MSG_CHECKING(which DNS backend to use)
550 AC_ARG_WITH(dns-backend, AS_HELP_STRING([--with-dns-backend=TYPE],
551             [specify which DNS backend to use: internal or systemd-resolved [default=internal]]),
552                 [dns_backend=${withval}],
553                 [dns_backend="internal"])
554
555 if (test "${dns_backend}" != "internal" -a \
556                 "${dns_backend}" != "systemd-resolved"); then
557         AC_MSG_ERROR(no suitable DNS backend defined)
558 fi
559 AM_CONDITIONAL(INTERNAL_DNS_BACKEND, test "${dns_backend}" = "internal")
560 AM_CONDITIONAL(SYSTEMD_RESOLVED_DNS_BACKEND, test "${dns_backend}" = "systemd-resolved")
561 AC_MSG_RESULT(${dns_backend})
562
563 AC_OUTPUT(Makefile include/version.h connman.pc src/connman.service src/connman_tv.service vpn/connman-vpn.service)