waf: Rename some BUNDLED_ functios to PRIVATE_.
[nivanova/samba-autobuild/.git] / source4 / lib / ldb / wscript
index a540ce11fa56834e143e85ee7639b8816e0623d8..1fe3547eafdaf9fc69a5e3be2832e3298664ce73 100644 (file)
@@ -1,7 +1,7 @@
 #!/usr/bin/env python
 
 APPNAME = 'ldb'
-VERSION = '0.9.11'
+VERSION = '0.9.17'
 
 blddir = 'bin'
 
@@ -13,7 +13,7 @@ while not os.path.exists(srcdir+'/buildtools') and len(srcdir.split('/')) < 5:
     srcdir = '../' + srcdir
 sys.path.insert(0, srcdir + '/buildtools/wafsamba')
 
-import wafsamba, samba_dist
+import wafsamba, samba_dist, Options
 
 samba_dist.DIST_DIRS('''source4/lib/ldb:. lib/replace:lib/replace lib/talloc:lib/talloc
                         lib/tdb:lib/tdb lib/tevent:lib/tevent lib/popt:lib/popt
@@ -22,14 +22,16 @@ samba_dist.DIST_DIRS('''source4/lib/ldb:. lib/replace:lib/replace lib/talloc:lib
 
 def set_options(opt):
     opt.BUILTIN_DEFAULT('replace')
-    opt.BUNDLED_EXTENSION_DEFAULT('ldb', noextenion='ldb')
+    opt.PRIVATE_EXTENSION_DEFAULT('ldb', noextension='ldb')
     opt.RECURSE('lib/tdb')
     opt.RECURSE('lib/tevent')
+    opt.RECURSE('lib/replace')
 
 def configure(conf):
     conf.RECURSE('lib/tdb')
     conf.RECURSE('lib/tevent')
     conf.RECURSE('lib/popt')
+    conf.RECURSE('lib/replace')
 
     # where does the default LIBDIR end up? in conf.env somewhere?
     #
@@ -44,9 +46,13 @@ def configure(conf):
                                      onlyif='talloc tdb tevent',
                                      implied_deps='replace talloc tdb tevent'):
             conf.define('USING_SYSTEM_LDB', 1)
+        if conf.CHECK_BUNDLED_SYSTEM('pyldb', minversion=VERSION,
+                                     onlyif='talloc tdb tevent ldb',
+                                     implied_deps='replace talloc tdb tevent ldb'):
+            conf.define('USING_SYSTEM_PYLDB', 1)
 
     if conf.env.standalone_ldb:
-        conf.find_program('xsltproc', var='XSLTPROC')
+        conf.CHECK_XSLTPROC_MANPAGES()
 
         # we need this for the ldap backend
         if conf.CHECK_FUNCS_IN('ber_flush ldap_open ldap_initialize', 'lber ldap', headers='lber.h ldap.h'):
@@ -60,6 +66,7 @@ def build(bld):
     bld.RECURSE('lib/tdb')
     bld.RECURSE('lib/tevent')
     bld.RECURSE('lib/popt')
+    bld.RECURSE('lib/replace')
 
     # in Samba4 we build some extra modules, and add extra
     # capabilities to the ldb cmdline tools
@@ -69,17 +76,17 @@ def build(bld):
                              'ldb_map.c ldb_map_inbound.c ldb_map_outbound.c')
 
     COMMON_SRC = bld.SUBDIR('common',
-                            '''ldb.c ldb_ldif.c ldb_parse.c ldb_msg.c ldb_utf8.c
-                            ldb_debug.c ldb_dn.c ldb_match.c common/ldb_modules.c
+                            '''ldb_modules.c ldb_ldif.c ldb_parse.c ldb_msg.c ldb_utf8.c
+                            ldb_debug.c ldb_dn.c ldb_match.c ldb_options.c
                             ldb_attributes.c attrib_handlers.c ldb_controls.c qsort.c''')
 
     if s4_build:
         # this is only in the s4 build
         bld.SAMBA_MODULE('ldb_ildap', 'ldb_ildap/ldb_ildap.c',
                          init_function='LDB_BACKEND(ldapi),LDB_BACKEND(ldaps),LDB_BACKEND(ldap)',
-                         deps='talloc LIBCLI_LDAP CREDENTIALS',
-                         internal_module=not bld.CONFIG_SET('USING_SYSTEM_LDB'),
-                         includes='include',
+                         deps='talloc LIBCLI_LDAP CREDENTIALS auth_system_session',
+                         aliases='ldb_ldaps ldb_ldapi ldb_ldap',
+                         internal_module=False,
                          subsystem='ldb')
     else:
         # this is not included in the s4 build
@@ -87,6 +94,7 @@ def build(bld):
                          init_function='LDB_BACKEND(ldapi),LDB_BACKEND(ldaps),LDB_BACKEND(ldap)',
                          deps='talloc lber ldap',
                          enabled=bld.env.ENABLE_LDAP_BACKEND,
+                         internal_module=False,
                          subsystem='ldb')
 
     # we're not currently linking against the ldap libs, but ldb.pc.in
@@ -97,32 +105,47 @@ def build(bld):
         bld.env.PACKAGE_VERSION = VERSION
         bld.env.PKGCONFIGDIR = '${LIBDIR}/pkgconfig'
 
-    if s4_build:
-        abi_file='ABI/ldb-samba4-%s.sigs' % VERSION
-    else:
-        abi_file='ABI/ldb-%s.sigs' % VERSION
-
-    bld.SAMBA_PYTHON('pyldb_util', deps='ldb',
-            source='pyldb_util.c')
+    if not bld.CONFIG_SET('USING_SYSTEM_PYLDB'):
+        bld.SAMBA_LIBRARY('pyldb_util',
+                          deps='ldb',
+                          source='pyldb_util.c',
+                          public_headers='pyldb.h',
+                          vnum=VERSION,
+                          pc_files='pyldb.pc',
+                          pyext=True)
 
     if not bld.CONFIG_SET('USING_SYSTEM_LDB'):
-        modules_dir = bld.EXPAND_VARIABLES('${LDB_MODULESDIR}')
+        if Options.is_install:
+            modules_dir = bld.EXPAND_VARIABLES('${LDB_MODULESDIR}')
+        else:
+            # when we run from the source directory, we want to use
+            # the current modules, not the installed ones
+            modules_dir = os.path.join(os.getcwd(), 'bin/modules/ldb')
+
+        if bld.env.standalone_ldb:
+            # do ABI checking on the standalone ldb
+            abi_file = 'ABI/ldb-%s.sigs' % VERSION
+            abi_match = '!ldb_*module_ops !ldb_*backend_ops ldb_*'
+        else:
+            abi_file = None
+            abi_match = None
+
         bld.SAMBA_LIBRARY('ldb',
                           COMMON_SRC + ' ' + LDB_MAP_SRC,
-                          deps='tevent ldb',
+                          deps='tevent LIBLDB_MAIN',
                           includes='include',
                           public_headers='include/ldb.h include/ldb_errors.h '\
-                              'include/ldb_module.h include/ldb_handlers.h',
+                          'include/ldb_module.h include/ldb_handlers.h',
                           pc_files='ldb.pc',
-                          cflags='-DLDB_MODULESDIR=\"%s\"' % modules_dir,
-                          abi_file=abi_file,
-                          abi_match='!ldb_*module_ops !ldb_*backend_ops ldb_*',
                           vnum=VERSION, manpages='man/ldb.3',
-                          is_bundled=not bld.env.standalone_ldb)
+                          abi_file = abi_file,
+                          abi_match = abi_match,
+                          private_library=not bld.env.standalone_ldb)
 
         bld.SAMBA_PYTHON('pyldb', 'pyldb.c',
                          deps='ldb pyldb_util',
-                         realname='ldb.so')
+                         realname='ldb.so',
+                         cflags='-DPACKAGE_VERSION=\"%s\"' % VERSION)
 
         bld.SAMBA_MODULE('ldb_paged_results',
                          'modules/paged_results.c',
@@ -174,6 +197,14 @@ def build(bld):
                          deps='tdb',
                          subsystem='ldb')
 
+        # have a separate subsystem for common/ldb.c, so it can rebuild
+        # for install with a different -DLDB_MODULESDIR=
+        bld.SAMBA_SUBSYSTEM('LIBLDB_MAIN',
+                            'common/ldb.c',
+                            deps='tevent',
+                            includes='include',
+                            cflags='-DLDB_MODULESDIR=\"%s\"' % modules_dir)
+
     if s4_build:
         extra_cmdline_deps = ' LDBSAMBA POPT_SAMBA POPT_CREDENTIALS ' \
                 'LIBCMDLINE_CREDENTIALS gensec'
@@ -196,9 +227,11 @@ def build(bld):
 
 def test(ctx):
     '''run ldb testsuite'''
-    import Utils
+    import Utils, samba_utils
     cmd = 'tests/test-tdb.sh'
-    os.system(cmd)
+    ret = samba_utils.RUN_COMMAND(cmd)
+    print("testsuite returned %d" % ret)
+    sys.exit(ret)
 
 def dist():
     '''makes a tarball for distribution'''