Fix crash on failing to open a frame info file.
[dcpomatic.git] / cscript
diff --git a/cscript b/cscript
index f3d532d578f649dc13bae6d9eb4c913a6de22c66..b7f2d191be9ad00098181504b9b519117684c4d9 100644 (file)
--- a/cscript
+++ b/cscript
@@ -2,36 +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 <carl@dcpomatic.com>'
+    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),
-                ('ffmpeg-cdist', '7a23ec9c771184ab563cfe24ad9b427f38368961'),
-                ('libdcp', 'v0.53'))
+        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', '0b7ef017aca8b572914518c759db1e234d8fc505'),
+            ('libdcp', 'v0.85'))
 
-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:
@@ -39,22 +146,22 @@ 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,'dvdomatic_%s-1_%s.deb video extra' % (version, cpu)
+        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)
-        env.command('tar xjf dvdomatic_%s.orig.tar.bz2' % version)
-        os.chdir('dvdomatic-%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')
+        shutil.move('../../dcpomatic-%s.tar.bz2' % version, 'dcpomatic_%s.orig.tar.bz2' % version)
+        target.command('tar xjf dcpomatic_%s.orig.tar.bz2' % version)
+        os.chdir('dcpomatic-%s' % version)
+        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'):
@@ -62,16 +169,17 @@ 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')
-    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_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')]