[scons] explicit fails when wanted features are missing

This commit is contained in:
Stefan Bühler 2017-10-24 16:14:25 +02:00 committed by Glenn Strauss
parent 505cc7856d
commit 66e0cd16b2
1 changed files with 51 additions and 36 deletions

View File

@ -8,6 +8,10 @@ from stat import *
package = 'lighttpd'
version = '1.4.48'
def fail(*args, **kwargs):
print(*args, file=sys.stderr, **kwargs)
env.Exit(-1)
def checkCHeaders(autoconf, hdrs):
p = re.compile('[^A-Z0-9]')
for hdr in hdrs:
@ -94,15 +98,12 @@ def checkProgram(env, withname, progname):
if binpath:
mode = os.stat(binpath)[ST_MODE]
if S_ISDIR(mode):
print >> sys.stderr, "* error: path `%s' is a directory" % (binpath)
env.Exit(-1)
fail("* error: path `%s' is a directory" % (binpath))
if not S_ISREG(mode):
print >> sys.stderr, "* error: path `%s' is not a file or not exists" % (binpath)
env.Exit(-1)
fail("* error: path `%s' is not a file or not exists" % (binpath))
if not binpath:
print >> sys.stderr, "* error: can't find program `%s'" % (progname)
env.Exit(-1)
fail("* error: can't find program `%s'" % (progname))
return binpath
@ -290,37 +291,46 @@ if 1:
autoconf.env.Append(LIBFCGI = 'fcgi')
if env['with_bzip2']:
if autoconf.CheckLibWithHeader('bz2', 'bzlib.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_BZLIB_H', '-DHAVE_LIBBZ2' ], LIBBZ2 = 'bz2')
if not autoconf.CheckLibWithHeader('bz2', 'bzlib.h', 'C', autoadd = 0):
fail("Couldn't find bz2")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_BZLIB_H', '-DHAVE_LIBBZ2' ], LIBBZ2 = 'bz2')
if env['with_dbi']:
if autoconf.CheckLibWithHeader('dbi', 'dbi/dbi.h', 'C', autoadd = 0):
env.Append(CPPFLAGS = [ '-DHAVE_DBI_H', '-DHAVE_LIBDBI' ], LIBDBI = 'dbi')
if not autoconf.CheckLibWithHeader('dbi', 'dbi/dbi.h', 'C', autoadd = 0):
fail("Couldn't find dbi")
env.Append(CPPFLAGS = [ '-DHAVE_DBI_H', '-DHAVE_LIBDBI' ], LIBDBI = 'dbi')
if env['with_fam']:
if autoconf.CheckLibWithHeader('fam', 'fam.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_FAM_H', '-DHAVE_LIBFAM' ], LIBS = [ 'fam' ])
checkFuncs(autoconf, ['FAMNoExists']);
if not autoconf.CheckLibWithHeader('fam', 'fam.h', 'C', autoadd = 0):
fail("Couldn't find fam")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_FAM_H', '-DHAVE_LIBFAM' ], LIBS = [ 'fam' ])
checkFuncs(autoconf, ['FAMNoExists']);
if env['with_gdbm']:
if autoconf.CheckLibWithHeader('gdbm', 'gdbm.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_GDBM_H', '-DHAVE_GDBM' ], LIBGDBM = 'gdbm')
if not autoconf.CheckLibWithHeader('gdbm', 'gdbm.h', 'C', autoadd = 0):
fail("Couldn't find gdbm")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_GDBM_H', '-DHAVE_GDBM' ], LIBGDBM = 'gdbm')
if env['with_geoip']:
if autoconf.CheckLibWithHeader('GeoIP', 'GeoIP.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_GEOIP' ], LIBGEOIP = 'GeoIP')
if not autoconf.CheckLibWithHeader('GeoIP', 'GeoIP.h', 'C', autoadd = 0):
fail("Couldn't find geoip")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_GEOIP' ], LIBGEOIP = 'GeoIP')
if env['with_krb5']:
if autoconf.CheckLibWithHeader('krb5', 'krb5.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_KRB5' ], LIBKRB5 = 'krb5')
if autoconf.CheckLibWithHeader('gssapi_krb5', 'gssapi/gssapi_krb5.h', 'C', autoadd = 0):
autoconf.env.Append(LIBGSSAPI_KRB5 = 'gssapi_krb5')
if not autoconf.CheckLibWithHeader('krb5', 'krb5.h', 'C', autoadd = 0):
fail("Couldn't find krb5")
if not autoconf.CheckLibWithHeader('gssapi_krb5', 'gssapi/gssapi_krb5.h', 'C', autoadd = 0):
fail("Couldn't find gssapi_krb5")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_KRB5' ], LIBKRB5 = 'krb5')
autoconf.env.Append(LIBGSSAPI_KRB5 = 'gssapi_krb5')
if env['with_ldap']:
if autoconf.CheckLibWithHeader('ldap', 'ldap.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_LDAP_H', '-DHAVE_LIBLDAP' ], LIBLDAP = 'ldap')
if autoconf.CheckLibWithHeader('lber', 'lber.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_LBER_H', '-DHAVE_LIBLBER' ], LIBLBER = 'lber')
if not autoconf.CheckLibWithHeader('ldap', 'ldap.h', 'C', autoadd = 0):
fail("Couldn't find ldap")
if not autoconf.CheckLibWithHeader('lber', 'lber.h', 'C', autoadd = 0):
fail("Couldn't find lber")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_LDAP_H', '-DHAVE_LIBLDAP' ], LIBLDAP = 'ldap')
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_LBER_H', '-DHAVE_LIBLBER' ], LIBLBER = 'lber')
if env['with_lua']:
def TryLua(env, name):
@ -343,11 +353,12 @@ if 1:
found_lua = True
break
if not found_lua:
raise RuntimeError("Couldn't find any lua implementation")
fail("Couldn't find any lua implementation")
if env['with_memcached']:
if autoconf.CheckLibWithHeader('memcached', 'libmemcached/memcached.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DUSE_MEMCACHED' ], LIBMEMCACHED = 'memcached')
if not autoconf.CheckLibWithHeader('memcached', 'libmemcached/memcached.h', 'C', autoadd = 0):
fail("Couldn't find memcached")
autoconf.env.Append(CPPFLAGS = [ '-DUSE_MEMCACHED' ], LIBMEMCACHED = 'memcached')
if env['with_mysql']:
mysql_config = checkProgram(env, 'mysql', 'mysql_config')
@ -358,8 +369,9 @@ if 1:
env['LIBS'] = oldlib
if env['with_openssl']:
if autoconf.CheckLibWithHeader('ssl', 'openssl/ssl.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_OPENSSL_SSL_H', '-DHAVE_LIBSSL'] , LIBSSL = 'ssl', LIBCRYPTO = 'crypto')
if not autoconf.CheckLibWithHeader('ssl', 'openssl/ssl.h', 'C', autoadd = 0):
fail("Couldn't find openssl")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_OPENSSL_SSL_H', '-DHAVE_LIBSSL'] , LIBSSL = 'ssl', LIBCRYPTO = 'crypto')
if env['with_pcre']:
pcre_config = checkProgram(env, 'pcre', 'pcre-config')
@ -377,12 +389,14 @@ if 1:
env['LIBS'] = oldlib
if env['with_sqlite3']:
if autoconf.CheckLibWithHeader('sqlite3', 'sqlite3.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_SQLITE3_H', '-DHAVE_LIBSQLITE3' ], LIBSQLITE3 = 'sqlite3')
if not autoconf.CheckLibWithHeader('sqlite3', 'sqlite3.h', 'C', autoadd = 0):
fail("Couldn't find sqlite3")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_SQLITE3_H', '-DHAVE_LIBSQLITE3' ], LIBSQLITE3 = 'sqlite3')
if env['with_uuid']:
if autoconf.CheckLibWithHeader('uuid', 'uuid/uuid.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_UUID_UUID_H', '-DHAVE_LIBUUID' ], LIBUUID = 'uuid')
if not autoconf.CheckLibWithHeader('uuid', 'uuid/uuid.h', 'C', autoadd = 0):
fail("Couldn't find uuid")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_UUID_UUID_H', '-DHAVE_LIBUUID' ], LIBUUID = 'uuid')
if env['with_xml']:
xml2_config = checkProgram(env, 'xml', 'xml2-config')
@ -393,8 +407,9 @@ if 1:
env['LIBS'] = oldlib
if env['with_zlib']:
if autoconf.CheckLibWithHeader('z', 'zlib.h', 'C', autoadd = 0):
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_ZLIB_H', '-DHAVE_LIBZ' ], LIBZ = 'z')
if not autoconf.CheckLibWithHeader('z', 'zlib.h', 'C', autoadd = 0):
fail("Couldn't find zlib")
autoconf.env.Append(CPPFLAGS = [ '-DHAVE_ZLIB_H', '-DHAVE_LIBZ' ], LIBZ = 'z')
env = autoconf.Finish()