X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=17f267628c3e1550698d6b174400028e77dda8d4;hb=237a0052c60af768f4d62b00321932918b7ba4d9;hp=8f3fc6cee87ca16100977258b25a7c72a7bc39dd;hpb=861ca2da59c20b86add17ed5540042e983e04461;p=dcpomatic.git diff --git a/cscript b/cscript index 8f3fc6cee..17f267628 100644 --- a/cscript +++ b/cscript @@ -1,59 +1,75 @@ import glob +import shutil +import os -release_targets = ['ubuntu-12.04-32', 'ubuntu-12.10-32', 'ubuntu-12.04-64', 'ubuntu-12.10-64', 'source', 'windows-32', 'windows-64'] - -def build_release(environment, variant, version): - if environment == 'windows': - command('./waf configure --target-windows') - command('./waf clean') - command('./waf') - shutil.copyfile('build/windows/installer.%s.nsi' % variant, 'build/windows/installer2.%s.nsi' % variant) - command('sed -i "s~%%resources%%~%s/windows~g" build/windows/installer2.%s.nsi' % (os.getcwd(), variant)) - command('sed -i "s~%%deps%%~$WINDOWS_PREFIX~g" build/windows/installer2.%s.nsi' % variant) - command('sed -i "s~%%binaries%%~%s/build~g" build/windows/installer2.%s.nsi' % (os.getcwd(), variant)) - command('sed -i "s~%%bits%%~32~g" build/windows/installer2.%s.nsi' % variant) - command('makensis build/windows/installer2.%s.nsi' % variant) - return glob.glob('build/windows/*%s*.exe' % variant)[0] - elif environment == 'ubuntu': - v = variant.split('-') - bits = v[1] - if bits == '32': +def dependencies(target): + if target.platform == 'windows': + return () + else: + return (('openjpeg-cdist', None), + ('libcxml', None), + ('ffmpeg-cdist', '488d5d4496af5e3a3b9d31d6b221e8eeada6b77e'), + ('libdcp', None)) + +def build(env, target): + cmd = './waf configure --prefix=%s' % env.work_dir_cscript() + if target.platform == 'windows': + cmd += ' --target-windows' + else: + cmd += ' --static' + env.command(cmd) + + env.command('./waf') + + if target.platform == 'linux': + env.command('./waf install') + + +def package(env, target, version): + if target.platform == 'windows': + shutil.copyfile('build/windows/installer.%s.nsi' % target.bits, 'build/windows/installer2.%s.nsi' % target.bits) + env.command('sed -i "s~%%resources%%~%s/windows~g" build/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) + env.command('sed -i "s~%%deps%%~%s~g" build/windows/installer2.%s.nsi' % (env.windows_prefix, target.bits)) + env.command('sed -i "s~%%binaries%%~%s/build~g" build/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) + env.command('sed -i "s~%%bits%%~32~g" build/windows/installer2.%s.nsi' % target.bits) + env.command('makensis build/windows/installer2.%s.nsi' % target.bits) + return os.path.abspath(glob.glob('build/windows/*%s*.exe' % target.bits)[0]) + elif target.platform == 'linux': + if target.bits == 32: cpu = 'i386' else: cpu = 'amd64' - shutil.copyfile(os.path.join('builds', 'control-%s' % variant), os.path.join('debian', 'control')) - command('./waf dist') - f = open(os.path.join('debian', 'files'), 'w') - print >>f,'dvdomatic_%s-1_%s.deb video extra' % (version, cpu) + shutil.copyfile('builds/control-%s-%d' % (target.version, target.bits), 'debian/control') + env.command('./waf dist') + f = open('debian/files', 'w') + print >>f,'dcpomatic_%s-1_%s.deb video extra' % (version, cpu) shutil.rmtree('build/deb', ignore_errors=True) + os.makedirs('build/deb') os.chdir('build/deb') - shutil.move('../../dvdomatic-%s.tar.bz2' % version, 'dvdomatic_%s.orig.tar.bz2' % version) - command('tar xjf dvdomatic_%s.orig.tar.bz2' % version) - os.chdir('dvdomatic-%s' % version) - command('dch -b -v %s-1 "New upstream release."' % version) - command('dpkg-source -b .') - command('dpkg-buildpackage') - return os.path.abspath(glob.glob('../*.deb')[0]) - -def make_pot(): - command('./waf pot') - return [os.path.abspath('build/src/lib/libdvdomatic.pot'), - os.path.abspath('build/src/wx/libdvdomatic-wx.pot'), - os.path.abspath('build/src/tools/dvdomatic.pot')] - -def make_manual(): - os.chdir('doc/manual') - command('make') - return [os.path.abspath('pdf'), os.path.abspath('html')] + shutil.move('../../dcpomatic-%s.tar.bz2' % version, 'dcpomatic_%s.orig.tar.bz2' % version) + env.command('tar xjf dcpomatic_%s.orig.tar.bz2' % version) + os.chdir('dcpomatic-%s' % version) + env.command('dch -b -v %s-1 "New upstream release."' % version) + env.set('CDIST_LINKFLAGS', env.get('LINKFLAGS')) + env.set('CDIST_CXXFLAGS', env.get('CXXFLAGS')) + env.set('CDIST_PKG_CONFIG_PATH', env.get('PKG_CONFIG_PATH')) + env.command('dpkg-buildpackage') + + debs = [] + for p in glob.glob('../*.deb'): + debs.append(os.path.abspath(p)) + + return debs -def dependencies(): - return (('libdcp', 'v0.43'), - ('ffmpeg', '8d0757e1079f588ed69f629e2d1a4d5f232dc298'), - ('openjpeg', '')) +def make_pot(env): + env.command('./waf pot') + return [os.path.abspath('build/src/lib/libdcpomatic.pot'), + os.path.abspath('build/src/wx/libdcpomatic-wx.pot'), + os.path.abspath('build/src/tools/dcpomatic.pot')] -def build(prefix): - depends('libdcp', 'v0.43') - depends('ffmpeg', ' - depends('openjpeg') +def make_manual(env): + os.chdir('doc/manual') + env.command('make') + return [os.path.abspath('pdf'), os.path.abspath('html')]