diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-02-23 19:23:18 +1100 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-04-06 20:26:37 +1000 |
commit | bb1e36a86baa10be9241d22ce34b8eb9b5784577 (patch) | |
tree | c1b832036ee8862203f553c72c3eca2ec002cd94 /lib/replace | |
parent | 2998ea91ec0ac30545d3e7027b638d167ca32ea6 (diff) | |
download | samba-bb1e36a86baa10be9241d22ce34b8eb9b5784577.tar.gz samba-bb1e36a86baa10be9241d22ce34b8eb9b5784577.tar.bz2 samba-bb1e36a86baa10be9241d22ce34b8eb9b5784577.zip |
build: make CHECK_FUNCS_IN() smarter about mandatory libraries
Diffstat (limited to 'lib/replace')
-rw-r--r-- | lib/replace/wafsamba.py | 56 |
1 files changed, 38 insertions, 18 deletions
diff --git a/lib/replace/wafsamba.py b/lib/replace/wafsamba.py index b0aa3b5fc6..60a43ae989 100644 --- a/lib/replace/wafsamba.py +++ b/lib/replace/wafsamba.py @@ -67,12 +67,30 @@ def CHECK_FUNCS(conf, list): for f in list.split(): CHECK_FUNC(conf, f) + +########################################################### +# check that the functions in 'list' are available in 'library' +# if they are, then make that library available as a dependency +# +# if the library is not available and mandatory==True, then +# raise an error. +# +# If the library is not available and mandatory==False, then +# add the library to the list of dependencies to remove from +# build rules @conf -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 +def CHECK_FUNCS_IN(conf, list, library, mandatory=False): + if not conf.check(lib=library, uselib_store=library): + conf.ASSERT(not mandatory, + "Mandatory library '%s' not found for functions '%s'" % (library, list)) + # if it isn't a mandatory library, then remove it from dependency lists + cache = LOCAL_CACHE(conf, 'EMPTY_LIBS') + cache[library.upper()] = True + return + 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 @@ -122,15 +140,17 @@ Build.BuildContext.set_rpath = set_rpath ############################################################# # return a named build cache dictionary, used to store # state inside the following functions -def BUILD_CACHE(bld, name): - if name in bld.env: - return bld.env[name] - bld.env[name] = {} - return bld.env[name] +@conf +def LOCAL_CACHE(ctx, name): + if name in ctx.env: + return ctx.env[name] + ctx.env[name] = {} + return ctx.env[name] ############################################################# # a build assert call +@conf def ASSERT(ctx, expression, msg): if not expression: sys.stderr.write("ERROR: %s\n" % msg) @@ -166,7 +186,7 @@ def ADD_INIT_FUNCTION(bld, subsystem, init_function): if init_function is None: return bld.ASSERT(subsystem is not None, "You must specify a subsystem for init_function '%s'" % init_function) - cache = BUILD_CACHE(bld, 'INIT_FUNCTIONS') + cache = LOCAL_CACHE(bld, 'INIT_FUNCTIONS') if not subsystem in cache: cache[subsystem] = '' cache[subsystem] += '%s,' % init_function @@ -195,7 +215,7 @@ def FULL_DEPENDENCIES(bld, cache, target, chain, path): ############################################################ # check our build dependencies for circular dependencies def CHECK_TARGET_DEPENDENCY(bld, target): - cache = BUILD_CACHE(bld, 'LIB_DEPS') + cache = LOCAL_CACHE(bld, 'LIB_DEPS') FULL_DEPENDENCIES(bld, cache, target, { target:True }, target) ################################################################ @@ -203,7 +223,7 @@ def CHECK_TARGET_DEPENDENCY(bld, target): # any circular dependencies removed # returns a tuple containing (systemdeps, localdeps) def ADD_DEPENDENCIES(bld, name, deps): - cache = BUILD_CACHE(bld, 'LIB_DEPS') + cache = LOCAL_CACHE(bld, 'LIB_DEPS') if not name in cache: cache[name] = {} list = deps.split() @@ -220,7 +240,7 @@ def ADD_DEPENDENCIES(bld, name, deps): # extract out the system dependencies sysdeps = [] localdeps = [] - cache = BUILD_CACHE(bld, 'EMPTY_LIBS') + cache = LOCAL_CACHE(bld, 'EMPTY_LIBS') for d in list2: # strip out any dependencies on empty libraries if d in cache: @@ -238,7 +258,7 @@ def ADD_DEPENDENCIES(bld, name, deps): # return a include list for a set of library dependencies def SAMBA_LIBRARY_INCLUDE_LIST(bld, deps): ret = bld.curdir + ' ' - cache = BUILD_CACHE(bld, 'INCLUDE_LIST') + cache = LOCAL_CACHE(bld, 'INCLUDE_LIST') for l in deps.split(): if l in cache: ret = ret + cache[l] + ' ' @@ -260,7 +280,7 @@ def SAMBA_LIBRARY(bld, libname, source_list, # remember empty libraries, so we can strip the dependencies if (source_list == '') or (source_list == []): - cache = BUILD_CACHE(bld, 'EMPTY_LIBS') + cache = LOCAL_CACHE(bld, 'EMPTY_LIBS') cache[libname] = True return @@ -290,7 +310,7 @@ def SAMBA_LIBRARY(bld, libname, source_list, (soext, LIB_PATH, libname, soext), shell = True ) - cache = BUILD_CACHE(bld, 'INCLUDE_LIST') + cache = LOCAL_CACHE(bld, 'INCLUDE_LIST') cache[libname] = ilist Build.BuildContext.SAMBA_LIBRARY = SAMBA_LIBRARY @@ -320,7 +340,7 @@ def SAMBA_BINARY(bld, binname, source_list, #print "SAMBA_BINARY: sysdeps='%s' deps='%s'" % (sysdeps, deps) - cache = BUILD_CACHE(bld, 'INIT_FUNCTIONS') + cache = LOCAL_CACHE(bld, 'INIT_FUNCTIONS') if modules is not None: for m in modules.split(): bld.ASSERT(m in cache, |