Handle empty patches better
[ganeti-github.git] / configure.ac
1 # Configure script for Ganeti
2 m4_define([gnt_version_major], [2])
3 m4_define([gnt_version_minor], [8])
4 m4_define([gnt_version_revision], [4])
5 m4_define([gnt_version_suffix], [])
6 m4_define([gnt_version_full],
7           m4_format([%d.%d.%d%s],
8                     gnt_version_major, gnt_version_minor,
9                     gnt_version_revision, gnt_version_suffix))
10
11 AC_PREREQ(2.59)
12 AC_INIT(ganeti, gnt_version_full, ganeti@googlegroups.com)
13 AC_CONFIG_AUX_DIR(autotools)
14 AC_CONFIG_SRCDIR(configure)
15 AM_INIT_AUTOMAKE([1.9 foreign tar-ustar -Wall -Wno-portability])
16
17 AC_SUBST([VERSION_MAJOR], gnt_version_major)
18 AC_SUBST([VERSION_MINOR], gnt_version_minor)
19 AC_SUBST([VERSION_REVISION], gnt_version_revision)
20 AC_SUBST([VERSION_SUFFIX], gnt_version_suffix)
21 AC_SUBST([VERSION_FULL], gnt_version_full)
22
23 # --with-ssh-initscript=...
24 AC_ARG_WITH([ssh-initscript],
25   [AS_HELP_STRING([--with-ssh-initscript=SCRIPT],
26     [SSH init script to use (default is /etc/init.d/ssh)]
27   )],
28   [ssh_initd_script="$withval"],
29   [ssh_initd_script="/etc/init.d/ssh"])
30 AC_SUBST(SSH_INITD_SCRIPT, $ssh_initd_script)
31
32 # --with-export-dir=...
33 AC_ARG_WITH([export-dir],
34   [AS_HELP_STRING([--with-export-dir=DIR],
35     [directory to use by default for instance image]
36     [ exports (default is /srv/ganeti/export)]
37   )],
38   [export_dir="$withval"],
39   [export_dir="/srv/ganeti/export"])
40 AC_SUBST(EXPORT_DIR, $export_dir)
41
42 # --with-ssh-config-dir=...
43 AC_ARG_WITH([ssh-config-dir],
44   [AS_HELP_STRING([--with-ssh-config-dir=DIR],
45     [ directory with ssh host keys ]
46     [ (default is /etc/ssh)]
47   )],
48   [ssh_config_dir="$withval"],
49   [ssh_config_dir="/etc/ssh"])
50 AC_SUBST(SSH_CONFIG_DIR, $ssh_config_dir)
51
52 # --with-xen-config-dir=...
53 AC_ARG_WITH([xen-config-dir],
54   [AS_HELP_STRING([--with-xen-config-dir=DIR],
55                   m4_normalize([Xen configuration directory
56                                 (default: /etc/xen)]))],
57   [xen_config_dir="$withval"],
58   [xen_config_dir=/etc/xen])
59 AC_SUBST(XEN_CONFIG_DIR, $xen_config_dir)
60
61 # --with-os-search-path=...
62 # do a bit of black sed magic to for quoting of the strings in the list
63 AC_ARG_WITH([os-search-path],
64   [AS_HELP_STRING([--with-os-search-path=LIST],
65     [comma separated list of directories to]
66     [ search for OS images (default is /srv/ganeti/os)]
67   )],
68   [os_search_path=`echo -n "$withval" | sed -e "s/\([[^,]]*\)/'\1'/g"`],
69   [os_search_path="'/srv/ganeti/os'"])
70 AC_SUBST(OS_SEARCH_PATH, $os_search_path)
71
72 # --with-extstorage-search-path=...
73 # same black sed magic for quoting of the strings in the list
74 AC_ARG_WITH([extstorage-search-path],
75   [AS_HELP_STRING([--with-extstorage-search-path=LIST],
76     [comma separated list of directories to]
77     [ search for External Storage Providers]
78     [ (default is /srv/ganeti/extstorage)]
79   )],
80   [es_search_path=`echo -n "$withval" | sed -e "s/\([[^,]]*\)/'\1'/g"`],
81   [es_search_path="'/srv/ganeti/extstorage'"])
82 AC_SUBST(ES_SEARCH_PATH, $es_search_path)
83
84 # --with-iallocator-search-path=...
85 # do a bit of black sed magic to for quoting of the strings in the list
86 AC_ARG_WITH([iallocator-search-path],
87   [AS_HELP_STRING([--with-iallocator-search-path=LIST],
88     [comma separated list of directories to]
89     [ search for instance allocators (default is $libdir/ganeti/iallocators)]
90   )],
91   [iallocator_search_path=`echo -n "$withval" | sed -e "s/\([[^,]]*\)/'\1'/g"`],
92   [iallocator_search_path="'$libdir/$PACKAGE_NAME/iallocators'"])
93 AC_SUBST(IALLOCATOR_SEARCH_PATH, $iallocator_search_path)
94
95 # --with-xen-bootloader=...
96 AC_ARG_WITH([xen-bootloader],
97   [AS_HELP_STRING([--with-xen-bootloader=PATH],
98     [bootloader for Xen hypervisor (default is empty)]
99   )],
100   [xen_bootloader="$withval"],
101   [xen_bootloader=])
102 AC_SUBST(XEN_BOOTLOADER, $xen_bootloader)
103
104 # --with-xen-kernel=...
105 AC_ARG_WITH([xen-kernel],
106   [AS_HELP_STRING([--with-xen-kernel=PATH],
107     [DomU kernel image for Xen hypervisor (default is /boot/vmlinuz-3-xenU)]
108   )],
109   [xen_kernel="$withval"],
110   [xen_kernel="/boot/vmlinuz-3-xenU"])
111 AC_SUBST(XEN_KERNEL, $xen_kernel)
112
113 # --with-xen-initrd=...
114 AC_ARG_WITH([xen-initrd],
115   [AS_HELP_STRING([--with-xen-initrd=PATH],
116     [DomU initrd image for Xen hypervisor (default is /boot/initrd-3-xenU)]
117   )],
118   [xen_initrd="$withval"],
119   [xen_initrd="/boot/initrd-3-xenU"])
120 AC_SUBST(XEN_INITRD, $xen_initrd)
121
122 # --with-xen-cmd=...
123 AC_ARG_WITH([xen-cmd],
124   [AS_HELP_STRING([--with-xen-cmd=CMD],
125     [Sets the xen cli interface command (default is xm)]
126   )],
127   [xen_cmd="$withval"],
128   [xen_cmd=xm])
129 AC_SUBST(XEN_CMD, $xen_cmd)
130
131 if ! test "$XEN_CMD" = xl -o "$XEN_CMD" = xm; then
132   AC_MSG_ERROR([Unsupported xen command specified])
133 fi
134
135 # --with-kvm-kernel=...
136 AC_ARG_WITH([kvm-kernel],
137   [AS_HELP_STRING([--with-kvm-kernel=PATH],
138     [Guest kernel image for KVM hypervisor (default is /boot/vmlinuz-3-kvmU)]
139   )],
140   [kvm_kernel="$withval"],
141   [kvm_kernel="/boot/vmlinuz-3-kvmU"])
142 AC_SUBST(KVM_KERNEL, $kvm_kernel)
143
144 # --with-file-storage-dir=...
145 AC_ARG_WITH([file-storage-dir],
146   [AS_HELP_STRING([--with-file-storage-dir=PATH],
147     [directory to store files for file-based backend]
148     [ (default is /srv/ganeti/file-storage)]
149   )],
150   [[file_storage_dir="$withval";
151     if test "$withval" != no; then
152       enable_file_storage=True
153     else
154       enable_file_storage=False
155     fi
156   ]],
157   [[file_storage_dir="/srv/ganeti/file-storage";
158     enable_file_storage=True]])
159 AC_SUBST(FILE_STORAGE_DIR, $file_storage_dir)
160 AC_SUBST(ENABLE_FILE_STORAGE, $enable_file_storage)
161
162 # --with-shared-file-storage-dir=...
163 AC_ARG_WITH([shared-file-storage-dir],
164   [AS_HELP_STRING([--with-shared-file-storage-dir=PATH],
165     [directory to store files for shared file-based backend]
166     [ (default is /srv/ganeti/shared-file-storage)]
167   )],
168   [[shared_file_storage_dir="$withval";
169     if test "$withval" != no; then
170       enable_shared_file_storage=True
171     else
172       enable_shared_file_storage=False
173     fi
174   ]],
175   [[shared_file_storage_dir="/srv/ganeti/shared-file-storage";
176     enable_shared_file_storage=True]])
177 AC_SUBST(SHARED_FILE_STORAGE_DIR, $shared_file_storage_dir)
178 AC_SUBST(ENABLE_SHARED_FILE_STORAGE, $enable_shared_file_storage)
179
180 # --with-kvm-path=...
181 AC_ARG_WITH([kvm-path],
182   [AS_HELP_STRING([--with-kvm-path=PATH],
183     [absolute path to the kvm binary]
184     [ (default is /usr/bin/kvm)]
185   )],
186   [kvm_path="$withval"],
187   [kvm_path="/usr/bin/kvm"])
188 AC_SUBST(KVM_PATH, $kvm_path)
189
190 # --with-lvm-stripecount=...
191 AC_ARG_WITH([lvm-stripecount],
192   [AS_HELP_STRING([--with-lvm-stripecount=NUM],
193     [the default number of stripes to use for LVM volumes]
194     [ (default is 1)]
195   )],
196   [lvm_stripecount="$withval"],
197   [lvm_stripecount=1])
198 AC_SUBST(LVM_STRIPECOUNT, $lvm_stripecount)
199
200 # --with-ssh-login-user=...
201 AC_ARG_WITH([ssh-login-user],
202   [AS_HELP_STRING([--with-ssh-login-user=USERNAME],
203     [user to use for SSH logins within the cluster (default is root)]
204   )],
205   [ssh_login_user="$withval"],
206   [ssh_login_user=root])
207 AC_SUBST(SSH_LOGIN_USER, $ssh_login_user)
208
209 # --with-ssh-console-user=...
210 AC_ARG_WITH([ssh-console-user],
211   [AS_HELP_STRING([--with-ssh-console-user=USERNAME],
212     [user to use for SSH logins to access instance consoles (default is root)]
213   )],
214   [ssh_console_user="$withval"],
215   [ssh_console_user=root])
216 AC_SUBST(SSH_CONSOLE_USER, $ssh_console_user)
217
218 # --with-default-user=...
219 AC_ARG_WITH([default-user],
220   [AS_HELP_STRING([--with-default-user=USERNAME],
221     [default user for daemons]
222     [ (default is to run all daemons as root)]
223   )],
224   [user_default="$withval"],
225   [user_default=root])
226
227 # --with-default-group=...
228 AC_ARG_WITH([default-group],
229   [AS_HELP_STRING([--with-default-group=GROUPNAME],
230     [default group for daemons]
231     [ (default is to run all daemons under group root)]
232   )],
233   [group_default="$withval"],
234   [group_default=root])
235
236 # --with-user-prefix=...
237 AC_ARG_WITH([user-prefix],
238   [AS_HELP_STRING([--with-user-prefix=PREFIX],
239     [prefix for daemon users]
240     [ (default is to run all daemons as root; use --with-default-user]
241     [ to change the default)]
242   )],
243   [user_masterd="${withval}masterd";
244    user_rapi="${withval}rapi";
245    user_confd="${withval}confd";
246    user_luxid="${withval}luxid";
247    user_noded="$user_default";
248    user_mond="${withval}mond"],
249   [user_masterd="$user_default";
250    user_rapi="$user_default";
251    user_confd="$user_default";
252    user_luxid="$user_default";
253    user_noded="$user_default";
254    user_mond="$user_default"])
255 AC_SUBST(MASTERD_USER, $user_masterd)
256 AC_SUBST(RAPI_USER, $user_rapi)
257 AC_SUBST(CONFD_USER, $user_confd)
258 AC_SUBST(LUXID_USER, $user_luxid)
259 AC_SUBST(NODED_USER, $user_noded)
260 AC_SUBST(MOND_USER, $user_mond)
261
262 # --with-group-prefix=...
263 AC_ARG_WITH([group-prefix],
264   [AS_HELP_STRING([--with-group-prefix=PREFIX],
265     [prefix for daemon POSIX groups]
266     [ (default is to run all daemons under group root; use]
267     [ --with-default-group to change the default)]
268   )],
269   [group_rapi="${withval}rapi";
270    group_admin="${withval}admin";
271    group_confd="${withval}confd";
272    group_luxid="${withval}luxid";
273    group_masterd="${withval}masterd";
274    group_noded="$group_default";
275    group_daemons="${withval}daemons";
276    group_mond="${withval}mond"],
277   [group_rapi="$group_default";
278    group_admin="$group_default";
279    group_confd="$group_default";
280    group_luxid="$group_default";
281    group_masterd="$group_default";
282    group_noded="$group_default";
283    group_daemons="$group_default";
284    group_mond="$group_default"])
285 AC_SUBST(RAPI_GROUP, $group_rapi)
286 AC_SUBST(ADMIN_GROUP, $group_admin)
287 AC_SUBST(CONFD_GROUP, $group_confd)
288 AC_SUBST(LUXID_GROUP, $group_luxid)
289 AC_SUBST(MASTERD_GROUP, $group_masterd)
290 AC_SUBST(NODED_GROUP, $group_noded)
291 AC_SUBST(DAEMONS_GROUP, $group_daemons)
292 AC_SUBST(MOND_GROUP, $group_mond)
293
294 # Print the config to the user
295 AC_MSG_NOTICE([Running ganeti-masterd as $group_masterd:$group_masterd])
296 AC_MSG_NOTICE([Running ganeti-rapi as $user_rapi:$group_rapi])
297 AC_MSG_NOTICE([Running ganeti-confd as $user_confd:$group_confd])
298 AC_MSG_NOTICE([Running ganeti-luxid as $user_luxid:$group_luxid])
299 AC_MSG_NOTICE([Group for daemons is $group_daemons])
300 AC_MSG_NOTICE([Group for clients is $group_admin])
301
302 # --enable-drbd-barriers
303 AC_ARG_ENABLE([drbd-barriers],
304   [AS_HELP_STRING([--enable-drbd-barriers],
305                   m4_normalize([enable the DRBD barriers functionality by
306                                 default (>= 8.0.12) (default: enabled)]))],
307   [[if test "$enableval" != no; then
308       DRBD_BARRIERS=n
309       DRBD_NO_META_FLUSH=False
310     else
311       DRBD_BARRIERS=bf
312       DRBD_NO_META_FLUSH=True
313     fi
314   ]],
315   [DRBD_BARRIERS=n
316    DRBD_NO_META_FLUSH=False
317   ])
318 AC_SUBST(DRBD_BARRIERS, $DRBD_BARRIERS)
319 AC_SUBST(DRBD_NO_META_FLUSH, $DRBD_NO_META_FLUSH)
320
321 # --enable-syslog[=no/yes/only]
322 AC_ARG_ENABLE([syslog],
323   [AS_HELP_STRING([--enable-syslog],
324     [enable use of syslog (default: disabled), one of no/yes/only])],
325   [[case "$enableval" in
326       no)
327         SYSLOG=no
328         ;;
329       yes)
330         SYSLOG=yes
331         ;;
332       only)
333         SYSLOG=only
334         ;;
335       *)
336         SYSLOG=
337         ;;
338     esac
339   ]],
340   [SYSLOG=no])
341
342 if test -z "$SYSLOG"
343 then
344   AC_MSG_ERROR([invalid value for syslog, choose one of no/yes/only])
345 fi
346 AC_SUBST(SYSLOG_USAGE, $SYSLOG)
347
348 AC_ARG_ENABLE([restricted-commands],
349   [AS_HELP_STRING([--enable-restricted-commands],
350                   m4_normalize([enable restricted commands in the node daemon
351                                 (default: disabled)]))],
352   [[if test "$enableval" = no; then
353       enable_restricted_commands=False
354     else
355       enable_restricted_commands=True
356     fi
357   ]],
358   [enable_restricted_commands=False])
359 AC_SUBST(ENABLE_RESTRICTED_COMMANDS, $enable_restricted_commands)
360
361 # --with-disk-separator=...
362 AC_ARG_WITH([disk-separator],
363   [AS_HELP_STRING([--with-disk-separator=STRING],
364     [Disk index separator, useful if the default of ':' is handled]
365     [ specially by the hypervisor]
366   )],
367   [disk_separator="$withval"],
368   [disk_separator=":"])
369 AC_SUBST(DISK_SEPARATOR, $disk_separator)
370
371 # Check common programs
372 AC_PROG_INSTALL
373 AC_PROG_LN_S
374
375 # Check for the ip command
376 AC_ARG_VAR(IP_PATH, [ip path])
377 AC_PATH_PROG(IP_PATH, [ip], [])
378 if test -z "$IP_PATH"
379 then
380   AC_MSG_ERROR([ip command not found])
381 fi
382
383 # Check for pandoc
384 AC_ARG_VAR(PANDOC, [pandoc path])
385 AC_PATH_PROG(PANDOC, [pandoc], [])
386 if test -z "$PANDOC"
387 then
388   AC_MSG_WARN([pandoc not found, man pages rebuild will not be possible])
389 fi
390
391 # Check for python-sphinx
392 AC_ARG_VAR(SPHINX, [sphinx-build path])
393 AC_PATH_PROG(SPHINX, [sphinx-build], [])
394 if test -z "$SPHINX"
395 then
396   AC_MSG_WARN(m4_normalize([sphinx-build not found, documentation rebuild will
397                             not be possible]))
398 else
399   # Sphinx exits with code 1 when it prints its usage
400   sphinxver=`{ $SPHINX --version 2>&1 || :; } | head -n 3`
401
402   if ! echo "$sphinxver" | grep -q -w -e '^Sphinx' -e '^Usage:'; then
403     AC_MSG_ERROR([Unable to determine Sphinx version])
404
405   # Note: Character classes ([...]) need to be double quoted due to autoconf
406   # using m4
407   elif ! echo "$sphinxver" | grep -q -E '^Sphinx[[[:space:]]]+v[[1-9]]\>'; then
408     AC_MSG_ERROR([Sphinx 1.0 or higher is required])
409   fi
410 fi
411 AM_CONDITIONAL([HAS_SPHINX], [test -n "$SPHINX"])
412
413 AC_ARG_ENABLE([manpages-in-doc],
414   [AS_HELP_STRING([--enable-manpages-in-doc],
415                   m4_normalize([include man pages in HTML documentation
416                                 (requires sphinx; default disabled)]))],
417   [case "$enableval" in
418       yes) manpages_in_doc=yes ;;
419       no) manpages_in_doc= ;;
420       *)
421         AC_MSG_ERROR([Bad value $enableval for --enable-manpages-in-doc])
422         ;;
423     esac
424   ],
425   [manpages_in_doc=])
426 AM_CONDITIONAL([MANPAGES_IN_DOC], [test -n "$manpages_in_doc"])
427 AC_SUBST(MANPAGES_IN_DOC, $manpages_in_doc)
428
429 if test -z "$SPHINX" -a -n "$manpages_in_doc"; then
430   AC_MSG_ERROR([Including man pages in HTML documentation requires sphinx])
431 fi
432
433 # Check for graphviz (dot)
434 AC_ARG_VAR(DOT, [dot path])
435 AC_PATH_PROG(DOT, [dot], [])
436 if test -z "$DOT"
437 then
438   AC_MSG_WARN(m4_normalize([dot (from the graphviz suite) not found,
439                             documentation rebuild not possible]))
440 fi
441
442 # Check for pylint
443 AC_ARG_VAR(PYLINT, [pylint path])
444 AC_PATH_PROG(PYLINT, [pylint], [])
445 if test -z "$PYLINT"
446 then
447   AC_MSG_WARN([pylint not found, checking code will not be possible])
448 fi
449
450 # Check for pep8
451 AC_ARG_VAR(PEP8, [pep8 path])
452 AC_PATH_PROG(PEP8, [pep8], [])
453 if test -z "$PEP8"
454 then
455   AC_MSG_WARN([pep8 not found, checking code will not be complete])
456 fi
457 AM_CONDITIONAL([HAS_PEP8], [test -n "$PEP8"])
458
459 # Check for python-coverage
460 AC_ARG_VAR(PYCOVERAGE, [python-coverage path])
461 AC_PATH_PROGS(PYCOVERAGE, [python-coverage coverage], [])
462 if test -z "$PYCOVERAGE"
463 then
464   AC_MSG_WARN(m4_normalize([python-coverage or coverage not found, evaluating
465                             Python test coverage will not be possible]))
466 fi
467
468 # Check for socat
469 AC_ARG_VAR(SOCAT, [socat path])
470 AC_PATH_PROG(SOCAT, [socat], [])
471 if test -z "$SOCAT"
472 then
473   AC_MSG_ERROR([socat not found])
474 fi
475
476 # Check for qemu-img
477 AC_ARG_VAR(QEMUIMG_PATH, [qemu-img path])
478 AC_PATH_PROG(QEMUIMG_PATH, [qemu-img], [])
479 if test -z "$QEMUIMG_PATH"
480 then
481   AC_MSG_WARN([qemu-img not found, using ovfconverter will not be possible])
482 fi
483
484 # --enable-confd
485 ENABLE_CONFD=
486 AC_ARG_ENABLE([confd],
487   [AS_HELP_STRING([--enable-confd],
488   [enable the ganeti-confd daemon (default: check)])],
489   [],
490   [enable_confd=check])
491
492 ENABLE_MOND=
493 AC_ARG_ENABLE([monitoring],
494   [AS_HELP_STRING([--enable-monitoring],
495   [enable the ganeti monitoring daemon (default: check)])],
496   [],
497   [enable_monitoring=check])
498
499 # Check for ghc
500 AC_ARG_VAR(GHC, [ghc path])
501 AC_PATH_PROG(GHC, [ghc], [])
502 if test -z "$GHC"; then
503   AC_MSG_FAILURE([ghc not found, compilation will not possible])
504 fi
505
506 AC_MSG_CHECKING([checking for extra GHC flags])
507 GHC_BYVERSION_FLAGS=
508 # check for GHC supported flags that vary accross versions
509 for flag in -fwarn-incomplete-uni-patterns; do
510   if $GHC -e '0' $flag >/dev/null 2>/dev/null; then
511    GHC_BYVERSION_FLAGS="$GHC_BYVERSION_FLAGS $flag"
512   fi
513 done
514 AC_MSG_RESULT($GHC_BYVERSION_FLAGS)
515 AC_SUBST(GHC_BYVERSION_FLAGS)
516
517 # Check for ghc-pkg
518 AC_ARG_VAR(GHC_PKG, [ghc-pkg path])
519 AC_PATH_PROG(GHC_PKG, [ghc-pkg], [])
520 if test -z "$GHC_PKG"; then
521   AC_MSG_FAILURE([ghc-pkg not found, compilation will not be possible])
522 fi
523
524 # check for modules, first custom/special checks
525 AC_MSG_NOTICE([checking for required haskell modules])
526 HS_PARALLEL3=
527 AC_GHC_PKG_CHECK([parallel-3.*], [HS_PARALLEL3=-DPARALLEL3],
528                  [AC_GHC_PKG_REQUIRE(parallel)], t)
529 AC_SUBST(HS_PARALLEL3)
530
531 # and now standard modules
532 AC_GHC_PKG_REQUIRE(curl)
533 AC_GHC_PKG_REQUIRE(json)
534 AC_GHC_PKG_REQUIRE(network)
535 AC_GHC_PKG_REQUIRE(mtl)
536 AC_GHC_PKG_REQUIRE(bytestring)
537 AC_GHC_PKG_REQUIRE(utf8-string)
538
539 # extra modules for confd functionality
540 HS_REGEX_PCRE=-DNO_REGEX_PCRE
541 has_confd=False
542 if test "$enable_confd" != no; then
543   CONFD_PKG=
544   AC_GHC_PKG_CHECK([regex-pcre], [HS_REGEX_PCRE=],
545                    [CONFD_PKG="$CONFD_PKG regex-pcre"])
546   AC_GHC_PKG_CHECK([hslogger], [], [CONFD_PKG="$CONFD_PKG hslogger"])
547   AC_GHC_PKG_CHECK([Crypto], [], [CONFD_PKG="$CONFD_PKG Crypto"])
548   AC_GHC_PKG_CHECK([text], [], [CONFD_PKG="$CONFD_PKG text"])
549   AC_GHC_PKG_CHECK([hinotify], [], [CONFD_PKG="$CONFD_PKG hinotify"])
550   AC_GHC_PKG_CHECK([vector], [], [CONFD_PKG="$CONFD_PKG vector"])
551   if test -z "$CONFD_PKG"; then
552     has_confd=True
553   elif test "$enable_confd" = check; then
554     AC_MSG_WARN(m4_normalize([The required extra libraries for confd were
555                               not found ($CONFD_PKG), confd disabled]))
556   else
557     AC_MSG_FAILURE(m4_normalize([The confd functionality was requested, but
558                                  required libraries were not found:
559                                  $CONFD_PKG]))
560   fi
561 fi
562 AC_SUBST(HS_REGEX_PCRE)
563 if test "$has_confd" = True; then
564   AC_MSG_NOTICE([Enabling confd usage])
565 fi
566 AC_SUBST(ENABLE_CONFD, $has_confd)
567 AM_CONDITIONAL([ENABLE_CONFD], [test x$has_confd = xTrue])
568
569 #extra modules for monitoring daemon functionality
570 has_monitoring=False
571 if test "$enable_monitoring" != no; then
572   MONITORING_PKG=
573   AC_GHC_PKG_CHECK([attoparsec], [],
574                    [MONITORING_PKG="$MONITORING_PKG attoparsec"])
575   AC_GHC_PKG_CHECK([snap-server], [],
576                    [MONITORING_PKG="$MONITORING_PKG snap-server"])
577   MONITORING_DEP=
578   if test "$has_confd" = False; then
579     MONITORING_DEP="$MONITORING_DEP confd"
580   fi
581   has_monitoring_pkg=False
582   if test -z "$MONITORING_PKG"; then
583     has_monitoring_pkg=True
584   elif test "$enable_monitoring" = check; then
585     AC_MSG_WARN(m4_normalize([The required extra libraries for the monitoring
586                               daemon were not found ($MONITORING_PKG),
587                               monitoring disabled]))
588   else
589     AC_MSG_FAILURE(m4_normalize([The monitoring functionality was requested, but
590                                  required libraries were not found:
591                                  $MONITORING_PKG]))
592   fi
593   has_monitoring_dep=False
594   if test -z "$MONITORING_DEP"; then
595     has_monitoring_dep=True
596   elif test "$enable_monitoring" = check; then
597     AC_MSG_WARN(m4_normalize([The optional Ganeti components required for the
598                               monitoring agent were not enabled
599                               ($MONITORING_DEP), monitoring disabled]))
600   else
601     AC_MSG_FAILURE(m4_normalize([The monitoring functionality was requested, but
602                                  required optional Ganeti components were not
603                                  found: $MONITORING_DEP]))
604   fi
605
606 fi
607 if test "$has_monitoring_pkg" = True -a "$has_monitoring_dep" = True; then
608   has_monitoring=True
609   AC_MSG_NOTICE([Enabling the monitoring agent usage])
610 fi
611 AC_SUBST(ENABLE_MOND, $has_monitoring)
612 AM_CONDITIONAL([ENABLE_MOND], [test "$has_monitoring" = True])
613
614 # development modules
615 HS_NODEV=
616 AC_GHC_PKG_CHECK([QuickCheck-2.*], [], [HS_NODEV=1], t)
617 AC_GHC_PKG_CHECK([test-framework-0.6*], [], [HS_NODEV=1], t)
618 AC_GHC_PKG_CHECK([test-framework-hunit], [], [HS_NODEV=1])
619 AC_GHC_PKG_CHECK([test-framework-quickcheck2], [], [HS_NODEV=1])
620 AC_GHC_PKG_CHECK([temporary], [], [HS_NODEV=1])
621 # FIXME: unify checks for non-test libraries (attoparsec, hinotify, ...)
622 #        that are needed to execute the tests, avoiding the duplication
623 #        of the checks.
624 AC_GHC_PKG_CHECK([attoparsec], [], [HS_NODEV=1])
625 AC_GHC_PKG_CHECK([vector], [], [HS_NODEV=1])
626 AC_GHC_PKG_CHECK([snap-server], [], [HS_NODEV=1])
627 AC_GHC_PKG_CHECK([regex-pcre], [], [HS_NODEV=1])
628 AC_GHC_PKG_CHECK([Crypto], [], [HS_NODEV=1])
629 AC_GHC_PKG_CHECK([text], [], [HS_NODEV=1])
630 AC_GHC_PKG_CHECK([hinotify], [], [HS_NODEV=1])
631 if test -n "$HS_NODEV"; then
632    AC_MSG_WARN(m4_normalize([Required development modules were not found,
633                              you won't be able to run Haskell unittests]))
634 else
635    AC_MSG_NOTICE([Haskell development modules found, unittests enabled])
636 fi
637 AC_SUBST(HS_NODEV)
638
639 HTOOLS=yes
640 AC_SUBST(HTOOLS)
641
642 # --enable-split-query
643 ENABLE_SPLIT_QUERY=
644 AC_ARG_ENABLE([split-query],
645   [AS_HELP_STRING([--enable-split-query],
646   [enable use of custom query daemon via confd])],
647   [[case "$enableval" in
648       no)
649         enable_split_query=False
650         ;;
651       yes)
652         enable_split_query=True
653         ;;
654       *)
655         echo "Invalid value for enable-confd '$enableval'"
656         exit 1
657         ;;
658     esac
659   ]],
660   [[case "x${has_confd}x" in
661      xTruex)
662        enable_split_query=True
663        ;;
664      *)
665        enable_split_query=False
666        ;;
667    esac]])
668 AC_SUBST(ENABLE_SPLIT_QUERY, $enable_split_query)
669
670 if test x$enable_split_query = xTrue -a x$has_confd != xTrue; then
671   AC_MSG_ERROR([Split queries require the confd daemon])
672 fi
673
674 if test x$enable_split_query = xTrue; then
675   AC_MSG_NOTICE([Split query functionality enabled])
676 fi
677
678 # Check for HsColour
679 HS_APIDOC=no
680 AC_ARG_VAR(HSCOLOUR, [HsColour path])
681 AC_PATH_PROG(HSCOLOUR, [HsColour], [])
682 if test -z "$HSCOLOUR"; then
683   AC_MSG_WARN(m4_normalize([HsColour not found, htools API documentation will
684                             not be generated]))
685 fi
686
687 # Check for haddock
688 AC_ARG_VAR(HADDOCK, [haddock path])
689 AC_PATH_PROG(HADDOCK, [haddock], [])
690 if test -z "$HADDOCK"; then
691   AC_MSG_WARN(m4_normalize([haddock not found, htools API documentation will
692                             not be generated]))
693 fi
694 if test -n "$HADDOCK" && test -n "$HSCOLOUR"; then
695   HS_APIDOC=yes
696 fi
697 AC_SUBST(HS_APIDOC)
698
699 # Check for hlint
700 AC_ARG_VAR(HLINT, [hlint path])
701 AC_PATH_PROG(HLINT, [hlint], [])
702 if test -z "$HLINT"; then
703   AC_MSG_WARN([hlint not found, checking code will not be possible])
704 fi
705
706 if test "$HTOOLS" != yes && test "$ENABLE_CONFD" = True; then
707   AC_MSG_ERROR(m4_normalize([cannot enable ganeti-confd if
708                              htools support is not enabled]))
709 fi
710
711 AM_CONDITIONAL([WANT_HTOOLS], [test "$HTOOLS" = yes])
712 AM_CONDITIONAL([WANT_HSTESTS], [test "x$HS_NODEV" = x])
713 AM_CONDITIONAL([WANT_HSAPIDOC], [test "$HS_APIDOC" = yes])
714 AM_CONDITIONAL([HAS_HLINT], [test "$HLINT"])
715
716 # Check for fakeroot
717 AC_ARG_VAR(FAKEROOT_PATH, [fakeroot path])
718 AC_PATH_PROG(FAKEROOT_PATH, [fakeroot], [])
719 if test -z "$FAKEROOT_PATH"; then
720   AC_MSG_WARN(m4_normalize([fakeroot not found, tests that must run as root
721                             will not be executed]))
722 fi
723 AM_CONDITIONAL([HAS_FAKEROOT], [test "x$FAKEROOT_PATH" != x])
724
725 SOCAT_USE_ESCAPE=
726 AC_ARG_ENABLE([socat-escape],
727   [AS_HELP_STRING([--enable-socat-escape],
728     [use escape functionality available in socat >= 1.7 (default: detect
729      automatically)])],
730   [[if test "$enableval" = yes; then
731       SOCAT_USE_ESCAPE=True
732     else
733       SOCAT_USE_ESCAPE=False
734     fi
735   ]])
736
737 if test -z "$SOCAT_USE_ESCAPE"
738 then
739   if $SOCAT -hh | grep -w -q escape; then
740     SOCAT_USE_ESCAPE=True
741   else
742     SOCAT_USE_ESCAPE=False
743   fi
744 fi
745
746 AC_SUBST(SOCAT_USE_ESCAPE)
747
748 SOCAT_USE_COMPRESS=
749 AC_ARG_ENABLE([socat-compress],
750   [AS_HELP_STRING([--enable-socat-compress],
751     [use OpenSSL compression option available in patched socat builds
752      (see INSTALL for details; default: detect automatically)])],
753   [[if test "$enableval" = yes; then
754       SOCAT_USE_COMPRESS=True
755     else
756       SOCAT_USE_COMPRESS=False
757     fi
758   ]])
759
760 if test -z "$SOCAT_USE_COMPRESS"
761 then
762   if $SOCAT -hhh | grep -w -q openssl-compress; then
763     SOCAT_USE_COMPRESS=True
764   else
765     SOCAT_USE_COMPRESS=False
766   fi
767 fi
768
769 AC_SUBST(SOCAT_USE_COMPRESS)
770
771 if man --help | grep -q -e --warnings
772 then
773   MAN_HAS_WARNINGS=1
774 else
775   MAN_HAS_WARNINGS=
776   AC_MSG_WARN(m4_normalize([man does not support --warnings, man page checks
777                             will not be possible]))
778 fi
779
780 AC_SUBST(MAN_HAS_WARNINGS)
781
782 # Check for Python
783 AM_PATH_PYTHON(2.6)
784
785 AC_PYTHON_MODULE(OpenSSL, t)
786 AC_PYTHON_MODULE(simplejson, t)
787 AC_PYTHON_MODULE(pyparsing, t)
788 AC_PYTHON_MODULE(pyinotify, t)
789 AC_PYTHON_MODULE(pycurl, t)
790 AC_PYTHON_MODULE(bitarray, t)
791 AC_PYTHON_MODULE(ipaddr, t)
792 AC_PYTHON_MODULE(affinity)
793 AC_PYTHON_MODULE(paramiko)
794
795 # Development-only Python modules
796 PY_NODEV=
797 AC_PYTHON_MODULE(yaml)
798 if test $HAVE_PYMOD_YAML == "no"; then
799   PY_NODEV="$PY_NODEV yaml"
800 fi
801
802 if test -n "$PY_NODEV"; then
803   AC_MSG_WARN(m4_normalize([Required development modules ($PY_NODEV) were not
804                             found, you won't be able to run Python unittests]))
805 else
806   AC_MSG_NOTICE([Python development modules found, unittests enabled])
807 fi
808 AC_SUBST(PY_NODEV)
809 AM_CONDITIONAL([PY_UNIT], [test -n $PY_NODEV])
810
811 AC_CONFIG_FILES([ Makefile ])
812
813 AC_OUTPUT