diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-03-17 20:32:15 +1100 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-04-06 20:26:34 +1000 |
commit | 2b5a1cc70cbc5bafe6183300b131d95505c03b36 (patch) | |
tree | fdcb0321be5cfd39d13b0a03cfdbf4394e7ac7bc /lib/replace | |
parent | 635a7ce6c1dfbfa2fd9ccefa0253a0a846a29f94 (diff) | |
download | samba-2b5a1cc70cbc5bafe6183300b131d95505c03b36.tar.gz samba-2b5a1cc70cbc5bafe6183300b131d95505c03b36.tar.bz2 samba-2b5a1cc70cbc5bafe6183300b131d95505c03b36.zip |
build: added waf build rules for ldb
Diffstat (limited to 'lib/replace')
-rw-r--r-- | lib/replace/wafsamba.py | 45 | ||||
-rw-r--r-- | lib/replace/wscript | 7 |
2 files changed, 42 insertions, 10 deletions
diff --git a/lib/replace/wafsamba.py b/lib/replace/wafsamba.py index f57ce28417..7c05aeaf9c 100644 --- a/lib/replace/wafsamba.py +++ b/lib/replace/wafsamba.py @@ -1,7 +1,7 @@ # a waf tool to add autoconf-like macros to the configure section # and for SAMBA_ macros for building libraries, binaries etc -import Build +import Build, os, Logs from Configure import conf @@ -45,14 +45,14 @@ def CHECK_FUNCS_IN(conf, list, library): if conf.check(lib=library, uselib_store=library): for f in list.split(): conf.check(function_name=f, lib=library, header_name=conf.env.hlist) + conf.env['LIB_' + library.upper()] = library ################################################# # write out config.h in the right directory @conf def SAMBA_CONFIG_H(conf): - import os - if os.path.normpath(conf.curdir) == os.path.normpath(conf.srcdir): - conf.write_config_header('config.h') + if os.path.normpath(conf.curdir) == os.path.normpath(os.environ.get('PWD')): + conf.write_config_header('config.h', top=True) ############################################################## @@ -75,7 +75,7 @@ def set_rpath(bld): if Options.is_install: bld.env['RPATH'] = ['-Wl,-rpath=' + bld.env.PREFIX + '/lib'] else: - bld.env.append_value('RPATH', '-Wl,-rpath=build/default') + bld.env.append_value('RPATH', '-Wl,-rpath=bin/lib') Build.BuildContext.set_rpath = set_rpath @@ -88,6 +88,16 @@ def SUBDIR(bld, subdir, list): return ret Build.BuildContext.SUBDIR = SUBDIR +################################################################# +# create the samba build environment +def SAMBA_BUILD_ENV(bld): + bld( + target = 'binlib', + rule = 'test -d lib || mkdir -p lib && touch ${TGT}', + shell = True + ) +Build.BuildContext.SAMBA_BUILD_ENV = SAMBA_BUILD_ENV + ################################################################ # this will contain the set of includes needed per Samba library @@ -127,21 +137,40 @@ def SAMBA_LIBRARY(bld, libname, source_list, features = 'cc cshlib', source = source_list, target=libname, - includes='. ' + ilist, + includes='. ' + os.environ.get('PWD') + '/bin/default ' + ilist, vnum=vnum) + + # put a link to the library in bin/lib + soext="" + if vnum is not None: + soext = '.' + vnum.split('.')[0] + bld( + source = 'lib%s.so' % libname, + rule = 'ln -sf ../${SRC}%s lib' % soext, + after = 'binlib' + ) bld.SAMBA_LIBRARY_INCLUDES[libname] = ilist bld.SAMBA_LIBRARY_DEPS[libname] = libdeps Build.BuildContext.SAMBA_LIBRARY = SAMBA_LIBRARY ################################################################# # define a Samba binary -def SAMBA_BINARY(bld, binname, source_list, libdeps='', include_list=''): +def SAMBA_BINARY(bld, binname, source_list, libdeps='', syslibs='', include_list=''): + #print('binname=%s libs=%s' % (binname, bld.SAMBA_LIBRARY_LIB_LIST(libdeps))) bld( features = 'cc cprogram', source = source_list, target = binname, uselib_local = bld.SAMBA_LIBRARY_LIB_LIST(libdeps), - includes = '. ' + bld.SAMBA_LIBRARY_INCLUDE_LIST(libdeps) + include_list) + uselib = syslibs, + includes = '. ' + os.environ.get('PWD') + '/bin/default ' + bld.SAMBA_LIBRARY_INCLUDE_LIST(libdeps) + include_list, + top=True) + # put a link to the binary in bin/ + bld( + source = binname, + rule = 'ln -sf ${SRC} .', + ) + Build.BuildContext.SAMBA_BINARY = SAMBA_BINARY ############################################################ diff --git a/lib/replace/wscript b/lib/replace/wscript index c2e545f882..5c1975bf5f 100644 --- a/lib/replace/wscript +++ b/lib/replace/wscript @@ -1,5 +1,5 @@ -srcdir = '.' -blddir = 'build' +srcdir = '../..' +blddir = 'bin' import Options, os, wafsamba @@ -89,6 +89,7 @@ def configure(conf): conf.CHECK_FUNCS('timegm getifaddrs freeifaddrs') conf.CHECK_FUNCS_IN('dlopen dlsym dlerror dlclose', 'dl') + conf.CHECK_FUNCS_IN('poptGetContext', 'popt') conf.check_cc(fragment=''' #include <stdarg.h> @@ -153,6 +154,8 @@ def build(bld): REPLACE_SOURCE = 'replace.c snprintf.c' + bld.SAMBA_BUILD_ENV() + bld.SAMBA_LIBRARY('replace', REPLACE_SOURCE) |