X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=773d7cda22c963d3f3ed2d6e8e5ecb688a30096a;hb=6c8c6b5d2f95b8e8fd7f72e34e3a7fded6762794;hp=97e8dbd9239583517ead27d8e1806dbaf10e50c7;hpb=883d885dc8690519d205c8baa275385af8a39f4b;p=dcpomatic.git diff --git a/cscript b/cscript index 97e8dbd92..773d7cda2 100644 --- a/cscript +++ b/cscript @@ -2,37 +2,143 @@ import glob import shutil import os -def dependencies(target): - if target.platform == 'windows': - return () +build_depends = {'debhelper': '8.0.0', + 'python': '2.7.3', + 'g++': '4:4.6.3', + 'pkg-config': '0.26', + 'libssh-dev': '0.5.2', + 'libboost-filesystem-dev': '1.46.0', + 'libboost-thread-dev': '1.46.0', + 'libsndfile1-dev': '1.0.25', + 'libmagick++-dev': '8:6.6.9.7', + 'libgtk2.0-dev': '2.24.10'} + +depends = dict() + +depends['12.04'] = {'libc6': '2.15', + 'libssh-4': '0.5.2', + 'libboost-filesystem1.46.1': '1.46.1', + 'libboost-thread1.46.1': '1.46.1', + 'libsndfile1': '1.0.25', + 'libmagick++4': '8:6.6.9.7', + 'libxml++2.6-2': '2.34.1', + 'libgtk2.0-0': '2.24.10', + 'libxmlsec1': '1.2.14-1.2build1', + 'libxmlsec1-openssl': '1.2.14-1.2build1', + 'libboost-date-time1.46.1': '1.46.1', + 'libcurl3': '7.22.0-3ubuntu4', + 'libzip2': '0.10-1ubuntu1'} + +depends['12.10'] = {'libc6': '2.15', + 'libssh-4': '0.5.2', + 'libboost-filesystem1.49.0': '1.49.0', + 'libboost-thread1.49.0': '1.49.0', + 'libsndfile1': '1.0.25', + 'libmagick++5': '8:6.7.7.10', + 'libxml++2.6-2': '2.34.2', + 'libgtk2.0-0': '2.24.13', + 'libxmlsec1': '1.2.18-2', + 'libxmlsec1-openssl': '1.2.18-2', + 'libboost-date-time1.49.0': '1.49.0', + 'libcurl3': '7.27.0-1ubuntu1', + 'libzip2': '0.10.1-1.1'} + +depends['13.04'] = {'libc6': '2.15', + 'libssh-4': '0.5.2', + 'libboost-filesystem1.49.0': '1.49.0', + 'libboost-thread1.49.0': '1.49.0', + 'libsndfile1': '1.0.25', + 'libmagick++5': '8:6.7.7.10', + 'libxml++2.6-2': '2.34.2', + 'libgtk2.0-0': '2.24.13', + 'libxmlsec1': '1.2.18-2', + 'libxmlsec1-openssl': '1.2.18-2', + 'libboost-date-time1.49.0': '1.49.0', + 'libcurl3': '7.29.0-1ubuntu3', + 'libzip2': '0.10.1-1.1'} + +depends['13.10'] = {'libc6': '2.17-93', + 'libssh-4': '0.5.4', + 'libboost-filesystem1.53.0': '1.53.0', + 'libboost-thread1.53.0': '1.53.0', + 'libsndfile1': '1.0.25', + 'libmagick++5': '8:6.7.7.10', + 'libxml++2.6-2': '2.36.0', + 'libgtk2.0-0': '2.24.20', + 'libxmlsec1': '1.2.18-2', + 'libxmlsec1-openssl': '1.2.18-2', + 'libboost-date-time1.49.0': '1.49.0', + 'libcurl3': '7.29.0-1ubuntu3', + 'libzip2': '0.10.1-1.1'} + +depends['7'] = {'libc6': '2.13', + 'libssh-4': '0.5.4', + 'libboost-filesystem1.49.0': '1.49.0', + 'libboost-thread1.49.0': '1.49.0', + 'libsndfile1': '1.0.25', + 'libmagick++5': '8:6.7.7.10', + 'libxml++2.6-2': '2.34.2', + 'libgtk2.0-0': '2.24.10', + 'libxmlsec1': '1.2.18', + 'libboost-date-time1.49.0': '1.49.0', + 'libxmlsec1-openssl': '1.2.18', + 'libcurl3': '7.26.0', + 'libzip2': '0.10.1'} + +def packages(name, packages, f): + s = '%s: ' % name + for p in packages: + s += str(p) + ', ' + print >>f,s[:-2] + +def make_control(version, bits, filename): + f = open(filename, 'w') + print >>f,'Source: dcpomatic' + print >>f,'Section: video' + print >>f,'Priority: extra' + print >>f,'Maintainer: Carl Hetherington ' + packages('Build-Depends', build_depends, f) + print >>f,'Standards-Version: 3.9.3' + print >>f,'Homepage: http://dcpomatic.com/' + print >>f,'' + print >>f,'Package: dcpomatic' + if bits == 32: + print >>f,'Architecture: i386' else: - return (('openjpeg-cdist', None), - ('libcxml', None), - ('ffmpeg-cdist', '7a23ec9c771184ab563cfe24ad9b427f38368961'), - ('libdcp', None)) + print >>f,'Architecture: amd64' + + packages('Depends', depends[version], f) + print >>f,'Description: Generator of Digital Cinema Packages (DCPs)' + print >>f,' DCP-o-matic generates Digital Cinema Packages (DCPs) from video and audio' + print >>f,' files (such as those from DVDs or Blu-Rays) for presentation on DCI-compliant' + print >>f,' digital projectors.' + +def dependencies(target): + return (('ffmpeg-cdist', 'a629ea68a20d990b4e61c16067e91563d8d08f50'), + ('libdcp', 'v0.91')) -def build(env, target): - cmd = './waf configure --prefix=%s' % env.work_dir_cscript() +def build(target): + cmd = './waf configure --prefix=%s' % target.work_dir_cscript() if target.platform == 'windows': cmd += ' --target-windows' - else: + elif target.platform == 'linux': cmd += ' --static' - env.command(cmd) + target.command(cmd) - env.command('./waf') + target.command('./waf') if target.platform == 'linux' or target.platform == 'osx': - env.command('./waf install') + target.command('./waf install') - -def package(env, target, version): +def package(target, version): if target.platform == 'windows': shutil.copyfile('build/platform/windows/installer.%s.nsi' % target.bits, 'build/platform/windows/installer2.%s.nsi' % target.bits) - env.command('sed -i "s~%%resources%%~%s/platform/windows~g" build/platform/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) - env.command('sed -i "s~%%deps%%~%s~g" build/platform/windows/installer2.%s.nsi' % (env.windows_prefix, target.bits)) - env.command('sed -i "s~%%binaries%%~%s/build~g" build/platform/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) - env.command('sed -i "s~%%bits%%~32~g" build/platform/windows/installer2.%s.nsi' % target.bits) - env.command('makensis build/platform/windows/installer2.%s.nsi' % target.bits) + target.command('sed -i "s~%%resources%%~%s/platform/windows~g" build/platform/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) + target.command('sed -i "s~%%static_deps%%~%s~g" build/platform/windows/installer2.%s.nsi' % (target.windows_prefix, target.bits)) + target.command('sed -i "s~%%cdist_deps%%~%s~g" build/platform/windows/installer2.%s.nsi' % (target.work_dir_cscript(), target.bits)) + target.command('sed -i "s~%%binaries%%~%s/build~g" build/platform/windows/installer2.%s.nsi' % (os.getcwd(), target.bits)) + target.command('sed -i "s~%%bits%%~32~g" build/platform/windows/installer2.%s.nsi' % target.bits) + target.command('makensis build/platform/windows/installer2.%s.nsi' % target.bits) return os.path.abspath(glob.glob('build/platform/windows/*%s*.exe' % target.bits)[0]) elif target.platform == 'linux': if target.bits == 32: @@ -40,8 +146,8 @@ def package(env, target, version): else: cpu = 'amd64' - shutil.copyfile('platform/linux/control-%s-%d' % (target.version, target.bits), 'debian/control') - env.command('./waf dist') + make_control(target.version, target.bits, 'debian/control') + target.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) @@ -49,13 +155,13 @@ def package(env, target, version): os.makedirs('build/deb') os.chdir('build/deb') shutil.move('../../dcpomatic-%s.tar.bz2' % version, 'dcpomatic_%s.orig.tar.bz2' % version) - env.command('tar xjf dcpomatic_%s.orig.tar.bz2' % version) + target.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') + target.command('dch -b -v %s-1 "New upstream release."' % version) + target.set('CDIST_LINKFLAGS', target.get('LINKFLAGS')) + target.set('CDIST_CXXFLAGS', target.get('CXXFLAGS')) + target.set('CDIST_PKG_CONFIG_PATH', target.get('PKG_CONFIG_PATH')) + target.command('dpkg-buildpackage') debs = [] for p in glob.glob('../*.deb'): @@ -63,16 +169,22 @@ def package(env, target, version): return debs elif target.platform == 'osx': - env.command('bash platform/osx/make_dmg.sh') - return os.path.abspath(glob.glob('build/platform/osx/DVD-o-matic*.dmg')[0]) + target.command('bash platform/osx/make_dmg.sh %s' % target.work_dir_cscript()) + return os.path.abspath(glob.glob('build/platform/osx/DCP-o-matic*.dmg')[0]) -def make_pot(env): - env.command('./waf pot') +def make_pot(target): + target.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 make_manual(env): +def make_manual(target): os.chdir('doc/manual') - env.command('make') - return [os.path.abspath('pdf'), os.path.abspath('html')] + target.command('make') + target.command('pdflatex colour.tex') + return [os.path.abspath('pdf'), os.path.abspath('html'), os.path.abspath('colour.pdf')] + +def test(target): + if target.platform != 'windows': + target.set('LC_ALL', 'C') + target.command('run/tests')