mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
ccan: Only build ccan-failtest when we are in developer mode
From: Andrew Bartlett <abartlet@samba.org> This code is incredibly useful, but is only needed in test code and may not be perfectly portable. It has compiled on all systems bar Solaris so far, but rather than make it a requirement to build Samba, just keep it for development. Andrew Bartlett Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Autobuild-User(master): Rusty Russell <rusty@rustcorp.com.au> Autobuild-Date(master): Thu Jun 7 18:53:12 CEST 2012 on sn-devel-104
This commit is contained in:
parent
4c9126daa9
commit
35a2d020a0
@ -1,6 +1,6 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
import Logs, sys
|
||||
import Logs, sys, Options
|
||||
|
||||
def configure(conf):
|
||||
conf.DEFINE('HAVE_CCAN', 1)
|
||||
@ -121,8 +121,18 @@ def configure(conf):
|
||||
conf.CHECK_FUNCS_IN('backtrace backtrace_symbols', 'execinfo', checklibc=True, headers='execinfo.h')
|
||||
|
||||
def build(bld):
|
||||
bld.SAMBA_LIBRARY('ccan',
|
||||
vnum="0.1-init-1161-g661d41f",
|
||||
source=bld.path.ant_glob('*/*.c'),
|
||||
deps='execinfo',
|
||||
|
||||
for ccan_dir in ["hash", "htable", "ilog", "likely", "list", "read_write_all", "str", "tally", "time"]:
|
||||
bld.SAMBA_SUBSYSTEM('ccan-%s' % ccan_dir,
|
||||
source=bld.path.ant_glob('%s/*.c' % ccan_dir))
|
||||
|
||||
if bld.env.DEVELOPER_MODE:
|
||||
bld.SAMBA_LIBRARY('ccan-failtest',
|
||||
source=bld.path.ant_glob('failtest/*.c'),
|
||||
deps='execinfo ccan ccan-failtest ccan-htable ccan-list ccan-read_write_all ccan-time',
|
||||
private_library=True)
|
||||
|
||||
bld.SAMBA_LIBRARY('ccan',
|
||||
source='',
|
||||
deps='ccan-hash ccan-ilog ccan-likely ccan-tally',
|
||||
private_library=True)
|
||||
|
@ -21,6 +21,9 @@ def set_options(opt):
|
||||
opt.BUILTIN_DEFAULT('replace,ccan')
|
||||
opt.PRIVATE_EXTENSION_DEFAULT('tdb2', noextension='tdb2')
|
||||
opt.RECURSE('lib/replace')
|
||||
opt.add_option('--enable-developer',
|
||||
help=("Turn on developer warnings and debugging"),
|
||||
action="store_true", dest='developer', default=False)
|
||||
opt.add_option('--enable-tdb2',
|
||||
help=("Use tdb2 API instead of tdb1 [True]"),
|
||||
action="store_true", dest='BUILD_TDB2', default=True)
|
||||
@ -39,6 +42,9 @@ def set_options(opt):
|
||||
action="store_true", dest='disable_python', default=False)
|
||||
|
||||
def configure(conf):
|
||||
if Options.options.developer:
|
||||
conf.env.DEVELOPER_MODE = True
|
||||
|
||||
conf.env.TEST_RUN_SRC=['test/run-001-encode.c',
|
||||
'test/run-001-fls.c',
|
||||
'test/run-01-new_database.c',
|
||||
@ -205,6 +211,15 @@ def build(bld):
|
||||
'tools/tdb2backup.c',
|
||||
deps='tdb')
|
||||
|
||||
if not bld.CONFIG_SET('USING_SYSTEM_PYTDB'):
|
||||
bld.SAMBA_PYTHON('pytdb',
|
||||
source='pytdb.c',
|
||||
deps='tdb',
|
||||
enabled=not bld.env.disable_python,
|
||||
realname='tdb.so',
|
||||
cflags='-DPACKAGE_VERSION=\"%s\"' % VERSION)
|
||||
|
||||
if bld.env.DEVELOPER_MODE:
|
||||
# FIXME: We need CCAN for some API tests, but waf thinks it's
|
||||
# already available via tdb2. It is, but not publicly.
|
||||
# Workaround is to build a private, non-hiding version.
|
||||
@ -223,7 +238,7 @@ def build(bld):
|
||||
for f in bld.env.TEST_RUN_SRC:
|
||||
base = os.path.splitext(os.path.basename(f))[0]
|
||||
bld.SAMBA_BINARY('tdb2-' + base, f,
|
||||
deps='ccan replace tdb2-test-helpers tdb2-run-helpers',
|
||||
deps='ccan replace tdb2-test-helpers tdb2-run-helpers ccan-failtest',
|
||||
install=False)
|
||||
|
||||
for f in bld.env.TEST_API_SRC:
|
||||
@ -232,14 +247,6 @@ def build(bld):
|
||||
deps='ccan replace tdb2-test-helpers tdb2-api-helpers',
|
||||
install=False)
|
||||
|
||||
if not bld.CONFIG_SET('USING_SYSTEM_PYTDB'):
|
||||
bld.SAMBA_PYTHON('pytdb',
|
||||
source='pytdb.c',
|
||||
deps='tdb',
|
||||
enabled=not bld.env.disable_python,
|
||||
realname='tdb.so',
|
||||
cflags='-DPACKAGE_VERSION=\"%s\"' % VERSION)
|
||||
|
||||
def testonly(ctx):
|
||||
'''run tdb2 testsuite'''
|
||||
import Utils, samba_utils, shutil
|
||||
@ -247,7 +254,8 @@ def testonly(ctx):
|
||||
|
||||
env = samba_utils.LOAD_ENVIRONMENT()
|
||||
|
||||
if env.BUILD_TDB2 and env.standalone_tdb2:
|
||||
if env.BUILD_TDB2 and env.standalone_tdb2 and env.DEVELOPER_MODE:
|
||||
|
||||
# FIXME: This is horrible :(
|
||||
test_prefix = "%s/st" % (Utils.g_module.blddir)
|
||||
shutil.rmtree(test_prefix, ignore_errors=True)
|
||||
|
Loading…
Reference in New Issue
Block a user