srcdir = '..'
blddir = 'bin'
-import sys
+APPNAME='samba'
+VERSION=None
+
+import sys, os
sys.path.insert(0, srcdir+"/buildtools/wafsamba")
-import wafsamba, Options
+import wafsamba, Options, samba_dist, Scripting, Utils
+
+
+def load_version(env=None):
+ '''load samba versions either from ./VERSION or git
+ return a version object for detailed breakdown'''
+ import samba_utils, Utils
+ if not env:
+ env = samba_utils.LOAD_ENVIRONMENT()
+
+ version = wafsamba.samba_version_file("./VERSION", "..", env)
+ Utils.g_module.VERSION = version.STRING
+ return version
+
+
+samba_dist.DIST_DIRS('.')
+
+#This is a list of files that we don't want in the package, for
+#whatever reason. Directories should be listed with a trailing / to
+#avoid over-exclusion.
+
+#This list includes files that would confuse the recipient of a
+#samba-4.0.0 branded tarball (until the merge is complete) and the
+#core elements of the autotools build system (which is known to
+#produce buggy binaries).
+samba_dist.DIST_BLACKLIST('README Manifest Read-Manifest-Now Roadmap source3/ ' +
+ 'packaging/ docs-xml/ examples/ swat/ WHATSNEW.txt MAINTAINERS ' +
+ 'source4/autogen-autotools.sh source4/Makefile.in source4/configure.ac')
+# install in /usr/local/samba by default
+Options.default_prefix = '/usr/local/samba'
+
def set_options(opt):
- opt.recurse('../lib/replace')
- opt.recurse('dynconfig')
- opt.recurse('scripting/python')
- opt.recurse('lib/ldb')
- opt.recurse('selftest')
- opt.recurse('lib/tls')
- opt.recurse('../lib/nss_wrapper')
- opt.recurse('../lib/socket_wrapper')
- opt.recurse('../lib/uid_wrapper')
+ opt.BUILTIN_DEFAULT('NONE')
+ opt.PRIVATE_EXTENSION_DEFAULT('samba4')
+ opt.RECURSE('../lib/replace')
+ opt.RECURSE('dynconfig')
+ opt.RECURSE('scripting/python')
+ opt.RECURSE('lib/ldb')
+ opt.RECURSE('selftest')
+ opt.RECURSE('lib/tls')
+ opt.RECURSE('../lib/nss_wrapper')
+ opt.RECURSE('../lib/socket_wrapper')
+ opt.RECURSE('../lib/uid_wrapper')
+ opt.RECURSE('../pidl')
+
+ gr = opt.option_group('developer options')
+ gr.add_option('--enable-build-farm',
+ help='enable special build farm options',
+ action='store_true', dest='BUILD_FARM')
+
def configure(conf):
- conf.define('PACKAGE_NAME', 'samba')
- conf.define('PACKAGE_STRING', 'samba 4')
- conf.define('PACKAGE_TARNAME', 'samba')
- conf.define('PACKAGE_URL', "")
- conf.define('PACKAGE_VERSION', "4")
- conf.define('PACKAGE_BUGREPORT', 'samba-technical@samba.org')
+ version = load_version(env=conf.env)
conf.DEFINE('CONFIG_H_IS_FROM_SAMBA', 1)
- conf.DEFINE('_SAMBA_BUILD_', 4, add_to_cflags=True)
+ conf.DEFINE('_SAMBA_BUILD_', version.MAJOR, add_to_cflags=True)
conf.DEFINE('HAVE_CONFIG_H', 1, add_to_cflags=True)
+
if Options.options.developer:
conf.ADD_CFLAGS('-DDEVELOPER -DDEBUG_PASSWORD')
- # set a lower limit on recursing in waf preprocessor
- conf.env.preprocessor_recursion_limit = 10
+ # this enables smbtorture.static for s3 in the build farm
+ conf.env.BUILD_FARM = Options.options.BUILD_FARM or os.environ.get('RUN_FROM_BUILD_FARM')
- conf.ADD_EXTRA_INCLUDES('#source4 #lib #source4/lib #source4/include #lib/replace #lib/talloc #lib/tevent')
+ conf.ADD_EXTRA_INCLUDES('#source4 #lib #source4/lib #source4/include')
- conf.sub_config('../lib/replace')
+ conf.RECURSE('../lib/replace')
conf.find_program('python', var='PYTHON', mandatory=True)
conf.find_program('perl', var='PERL', mandatory=True)
+ conf.find_program('xsltproc', var='XSLTPROC')
# enable tool to build python extensions
conf.check_tool('python')
conf.check_python_version((2,4,2))
- conf.check_python_headers()
-
- conf.sub_config('dynconfig')
- conf.sub_config('scripting/python')
- conf.sub_config('lib/ldb')
- conf.sub_config('heimdal_build')
- conf.sub_config('lib/tls')
- conf.sub_config('ntvfs/sysdep')
- conf.sub_config('../lib/util')
- conf.sub_config('../lib/zlib')
- conf.sub_config('../lib/util/charset')
- conf.sub_config('auth')
- conf.sub_config('../lib/nss_wrapper')
- conf.sub_config('../lib/socket_wrapper')
- conf.sub_config('../lib/uid_wrapper')
- conf.sub_config('lib/smbreadline')
-
+ conf.check_python_headers(mandatory=True)
+
+ if sys.platform == 'darwin' and not conf.env['HAVE_ENVIRON_DECL']:
+ if not conf.CHECK_SHLIB_W_PYTHON("Checking if -single_module is not needed"):
+ conf.env.append_value('shlib_LINKFLAGS', ['-single_module'])
+ if not conf.CHECK_SHLIB_W_PYTHON("Checking if -undefined dynamic_lookup is not need"):
+ conf.env.append_value('shlib_LINKFLAGS', ['-undefined', 'dynamic_lookup'])
+ if int(conf.env['PYTHON_VERSION'][0]) >= 3:
+ raise Utils.WafError('Python version 3.x is not supported by Samba yet')
+
+ conf.RECURSE('dynconfig')
+ conf.RECURSE('scripting/python')
+ conf.RECURSE('lib/ldb')
+ conf.RECURSE('heimdal_build')
+ conf.RECURSE('lib/tls')
+ conf.RECURSE('ntvfs/sysdep')
+ conf.RECURSE('../lib/util')
+ conf.RECURSE('../lib/zlib')
+ conf.RECURSE('../lib/util/charset')
+ conf.RECURSE('auth')
+ conf.RECURSE('../lib/nss_wrapper')
+ conf.RECURSE('../nsswitch')
+ conf.RECURSE('../lib/socket_wrapper')
+ conf.RECURSE('../lib/uid_wrapper')
+ conf.RECURSE('../lib/popt')
+ conf.RECURSE('../lib/subunit/c')
+ conf.RECURSE('../libcli/smbreadline')
+ conf.RECURSE('../pidl')
+ conf.RECURSE('selftest')
+
+ # we don't want any libraries or modules to rely on runtime
+ # resolution of symbols
+ conf.ADD_LDFLAGS('-Wl,-no-undefined', testflags=True)
+
+ # gentoo always adds this. We want our normal build to be as
+ # strict as the strictest OS we support, so adding this here
+ # allows us to find problems on our development hosts faster.
+ # It also results in faster load time.
+ conf.ADD_LDFLAGS('-Wl,--as-needed', testflags=True)
+
+ # we don't want PYTHONDIR in config.h, as otherwise changing
+ # --prefix causes a complete rebuild
+ del(conf.env.defines['PYTHONDIR'])
conf.SAMBA_CONFIG_H('include/config.h')
-
-from TaskGen import feature, before, after
-
-kak = {}
-@feature('cc', 'cxx')
-@after('apply_type_vars', 'apply_lib_vars', 'apply_core')
-def apply_incpaths(self):
- """used by the scanner
- after processing the uselib for CPPPATH
- after apply_core because some processing may add include paths
- """
- lst = []
- # TODO move the uselib processing out of here
- for lib in self.to_list(self.uselib):
- for path in self.env['CPPPATH_' + lib]:
- if not path in lst:
- lst.append(path)
- if preproc.go_absolute:
- for path in preproc.standard_includes:
- if not path in lst:
- lst.append(path)
-
- for path in self.to_list(self.includes):
- if not path in lst:
- if preproc.go_absolute or not os.path.isabs(path):
- lst.append(path)
- else:
- self.env.prepend_value('CPPPATH', path)
-
- for path in lst:
- try:
- #print len(kak.items())
- node = kak[(self.path.id, path)]
- except KeyError:
-
- node = None
- if os.path.isabs(path):
- if preproc.go_absolute:
- node = self.bld.root.find_dir(path)
- elif path[0] == '#':
- node = self.bld.srcnode
- if len(path) > 1:
- node = node.find_dir(path[1:])
- else:
- node = self.path.find_dir(path)
-
- kak[(self.path.id, path)] = node
- if node:
- self.env.append_value('INC_PATHS', node)
- # TODO WAF 1.6
- if USE_TOP_LEVEL:
- self.env.append_value('INC_PATHS', self.bld.srcnode)
-
-
-
-cac = {}
-@feature('cc')
-@after('apply_incpaths')
-def apply_obj_vars_cc(self):
- """after apply_incpaths for INC_PATHS"""
- env = self.env
- app = env.append_unique
- cpppath_st = env['CPPPATH_ST']
-
- global cac
-
- # local flags come first
- # set the user-defined includes paths
- for i in env['INC_PATHS']:
-
- try:
- app('_CCINCFLAGS', cac[i.id])
- except KeyError:
- cac[i.id] = [cpppath_st % i.bldpath(env), cpppath_st % i.srcpath(env)]
- app('_CCINCFLAGS', cac[i.id])
-
- # set the library include paths
- for i in env['CPPPATH']:
- app('_CCINCFLAGS', cpppath_st % i)
+def etags(ctx):
+ '''build TAGS file using etags'''
+ import Utils
+ source_root = os.path.dirname(Utils.g_module.root_path)
+ cmd = 'etags $(find %s/.. -name "*.[ch]" | egrep -v \.inst\.)' % source_root
+ print("Running: %s" % cmd)
+ os.system(cmd)
+
+def ctags(ctx):
+ "build 'tags' file using ctags"
+ import Utils
+ source_root = os.path.dirname(Utils.g_module.root_path)
+ cmd = 'ctags $(find %s/.. -name "*.[ch]" | grep -v "*_proto\.h" | egrep -v \.inst\.)' % source_root
+ print("Running: %s" % cmd)
+ os.system(cmd)
+
+# putting this here enabled build in the list
+# of commands in --help
+def build(bld):
+ '''build all targets'''
+ load_version(env=bld.env)
+ pass
+
+
+def pydoctor(ctx):
+ '''build python apidocs'''
+ cmd='PYTHONPATH=bin/python pydoctor --project-name=Samba --project-url=http://www.samba.org --make-html --docformat=restructuredtext --add-package bin/python/samba'
+ print("Running: %s" % cmd)
+ os.system(cmd)
+
+def wafdocs(ctx):
+ '''build wafsamba apidocs'''
+ from samba_utils import recursive_dirlist
+ os.system('pwd')
+ list = recursive_dirlist('../buildtools/wafsamba', '.', pattern='*.py')
+
+ cmd='PYTHONPATH=bin/python pydoctor --project-name=wafsamba --project-url=http://www.samba.org --make-html --docformat=restructuredtext'
+ print(list)
+ for f in list:
+ cmd += ' --add-module %s' % f
+ print("Running: %s" % cmd)
+ os.system(cmd)
+
+
+def dist():
+ '''makes a tarball for distribution'''
+ load_version(env=None)
+ samba_dist.dist()
+
+def distcheck():
+ '''test that distribution tarball builds and installs'''
+ load_version(env=None)
+ import Scripting
+ d = Scripting.distcheck
+ d(subdir='source4')
+
+def wildcard_cmd(cmd):
+ '''called on a unknown command'''
+ from samba_wildcard import run_named_build_task
+ run_named_build_task(cmd)
+
+def main():
+ from samba_wildcard import wildcard_main
+ wildcard_main(wildcard_cmd)
+Scripting.main = main
+
+def reconfigure(ctx):
+ '''reconfigure if config scripts have changed'''
+ import samba_utils
+ samba_utils.reconfigure(ctx)