diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-04-04 09:57:33 +1000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-04-06 20:27:24 +1000 |
commit | c8062fb65ee108fa948fd8d8ed4055ffa3af7027 (patch) | |
tree | 51aa3a475537d4cc89dc5b54965b5efdc35b6867 /buildtools | |
parent | 735934bfede08f37707a070f977837a9f76e3242 (diff) | |
download | samba-c8062fb65ee108fa948fd8d8ed4055ffa3af7027.tar.gz samba-c8062fb65ee108fa948fd8d8ed4055ffa3af7027.tar.bz2 samba-c8062fb65ee108fa948fd8d8ed4055ffa3af7027.zip |
s4-waf: added 'waf dist' to build the tarball
Diffstat (limited to 'buildtools')
-rw-r--r-- | buildtools/wafsamba/samba_dist.py | 67 | ||||
-rw-r--r-- | buildtools/wafsamba/wscript | 3 |
2 files changed, 70 insertions, 0 deletions
diff --git a/buildtools/wafsamba/samba_dist.py b/buildtools/wafsamba/samba_dist.py new file mode 100644 index 0000000000..88268b53ce --- /dev/null +++ b/buildtools/wafsamba/samba_dist.py @@ -0,0 +1,67 @@ +# customised version of 'waf dist' for Samba tools +# uses git ls-files to get file lists + +import Utils, os, sys, tarfile, stat +from samba_utils import * + +def add_tarfile(tar, fname, abspath): + '''add a file to the tarball''' + tinfo = tar.gettarinfo(name=abspath, arcname=fname) + tinfo.uid = 0 + tinfo.gid = 0 + tinfo.uname = 'root' + tinfo.gname = 'root' + fh = open(abspath) + tar.addfile(tinfo, fileobj=fh) + fh.close() + + +def dist(appname='', version=''): + + if not appname: appname = Utils.g_module.APPNAME + if not version: version = Utils.g_module.VERSION + + env = LOAD_ENVIRONMENT() + srcdir = os.path.normpath(os.path.join(os.path.dirname(Utils.g_module.root_path), Utils.g_module.srcdir)) + + if not env.DIST_DIRS: + print('You must use conf.DIST_DIRS() to set which directories to package') + sys.exit(1) + + if not env.GIT: + print('You need git installed to run waf dist') + sys.exit(1) + + dist_base = '%s-%s' % (appname, version) + dist_name = '%s.tar.gz' % (dist_base) + + tar = tarfile.open(dist_name, 'w:gz') + + for dir in env.DIST_DIRS.split(): + if dir.find(':') != -1: + destdir=dir.split(':')[1] + dir=dir.split(':')[0] + else: + destdir = '.' + absdir = os.path.join(srcdir, dir) + git_cmd = [ env.GIT, 'ls-files', '--full-name', absdir ] + files = Utils.cmd_output(git_cmd).split() + for f in files: + abspath = os.path.join(srcdir, f) + if dir != '.': + f = f[len(dir)+1:] + if destdir != '.': + f = destdir + '/' + f + fname = dist_base + '/' + f + add_tarfile(tar, fname, abspath) + + tar.close() + + print('Created %s' % dist_name) + + +@conf +def DIST_DIRS(conf, dirs): + '''set the directories to package, relative to top srcdir''' + if not conf.env.DIST_DIRS: + conf.env.DIST_DIRS = dirs diff --git a/buildtools/wafsamba/wscript b/buildtools/wafsamba/wscript index 89046f578f..9bef9b63b0 100644 --- a/buildtools/wafsamba/wscript +++ b/buildtools/wafsamba/wscript @@ -76,6 +76,9 @@ def configure(conf): conf.check_tool('compiler_cc') + # we need git for 'waf dist' + conf.find_program('git', var='GIT') + if Options.options.enable_gccdeps: # don't enable gccdeps by default as it needs a very recent version gcc conf.check_tool('gccdeps', tooldir=conf.srcdir + "/buildtools/wafsamba") |