X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=configure;h=bcc8e5d4ac356d23f6b97381fa92e2c344b9bffb;hb=2004088404325c5b238860c67c7ee4e1babed7e3;hp=2b6461799a3ef49cb4c5c853cd9a8d2bf78917ce;hpb=30c7aff241814c9e99ff3c1521ac40b3d5c721d3;p=moe.git diff --git a/configure b/configure index 2b64617..bcc8e5d 100755 --- a/configure +++ b/configure @@ -1,5 +1,5 @@ #!/usr/bin/perl -# Configure script for MO-Eval +# Configure script for Moe # (c) 2008--2009 Martin Mares use warnings; @@ -25,11 +25,50 @@ use UCW::Configure::Pkg; Init($srcdir, "default.cfg"); Include "ucw/default.cfg"; -Log "### Configuring MO-Eval ###\n\n"; +Log "### Configuring Moe ###\n\n"; Include Get("CONFIG"); require UCW::Configure::Paths; require UCW::Configure::C; require UCW::Configure::LibUCW; +require UCW::Configure::Doc; + +Test("KERNEL_ARCH", "Checking for kernel architecture", sub { + my $u = `uname -m`; + chomp $u; + if ($u =~ m{^i[3-6]86$}) { + return 'i386'; + } elsif ($u eq 'x86_64') { + return 'amd64'; + } else { + return $u; + } +}); + +Log "Selecting sandbox kernel architecture ... "; +my $karch = Get("CONFIG_BOX_KERNEL_ARCH") // "auto"; +if ($karch eq 'i386' || $karch eq 'amd64') { + Log "$karch (set manually)\n"; +} elsif ($karch eq 'auto') { + $karch = Get('KERNEL_ARCH'); + Set('CONFIG_BOX_KERNEL_ARCH', $karch); + Log "$karch\n"; +} else { + Fail "Unrecognized architecture $karch"; +} +Set('CONFIG_BOX_KERNEL_AMD64') if $karch eq 'amd64'; + +Log "Selecting sandbox user-space architecture ... "; +my $uarch = Get("CONFIG_BOX_USER_ARCH") // "auto"; +if ($uarch eq 'i386' || $uarch eq 'amd64') { + Log "$uarch (set manually)\n"; +} elsif ($uarch eq 'auto') { + $uarch = Get('ARCH'); + Set('CONFIG_BOX_USER_ARCH', $karch); + Log "$uarch\n"; +} else { + Fail "Unrecognized architecture $uarch"; +} +Set('CONFIG_BOX_USER_AMD64') if $uarch eq 'amd64'; if (Get("CONFIG_SUBMIT") || Get("CONFIG_MOP")) { # Build libucw only if it is needed @@ -38,7 +77,7 @@ if (Get("CONFIG_SUBMIT") || Get("CONFIG_MOP")) { if (Get("CONFIG_SUBMIT")) { # Submit server needs crypto libraries - if (!TrivConfig("libgnutls", script => "libgnutls-config") || + if (!PkgConfig("gnutls") && !TrivConfig("libgnutls", script => "libgnutls-config") || !TrivConfig("libgcrypt", script => "libgcrypt-config")) { Fail "The libgnutls and libgcrypt libraries are required to build the submit server."; }