X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=7ab2773e7c958d88f2bc65b51fb1e48e1773f59d;hb=d27d0f88a526cfe55e6018f9f32d54d5b61fc634;hp=3a7c380fd55bdf4781a207d15402637956082456;hpb=74b6739ea1710b8b26ca17d9096ba5f6baa5858d;p=libdcp.git diff --git a/cscript b/cscript index 3a7c380f..7ab2773e 100644 --- a/cscript +++ b/cscript @@ -1,5 +1,5 @@ # -# Copyright (C) 2012-2019 Carl Hetherington +# Copyright (C) 2012-2022 Carl Hetherington # # This file is part of libdcp. # @@ -35,36 +35,24 @@ import os import shutil def dependencies(target, options): - if (target.platform == 'windows' and target.version == 'xp') or (options is not None and 'jpeg' in options and options['jpeg'] == 'oj1'): - return (('libcxml', '0d18df4'), ('openjpeg-cdist', '4233dd7'), ('asdcplib-cth', 'd8490c6')) - else: - return (('libcxml', '0d18df4'), ('openjpeg2-cdist', '8b2ffc5'), ('asdcplib-cth', 'd8490c6')) + return ( + ('libcxml', 'v0.17.8', options), + ('openjpeg', 'ad8edaacd54a862940d0a77c41ecda5858b54d6e'), + ('asdcplib', '8a4a2f25cac0c58aac1d4267facab20e5ec3b57f') + ) def build(target, options): - cmd = './waf configure --disable-examples --prefix=%s' % target.directory - if options is not None and 'jpeg' in options: - cmd += ' --jpeg=%s' % options['jpeg'] + cmd = './waf configure --disable-examples --disable-dumpimage --disable-benchmarks --prefix=%s' % target.directory if target.platform == 'linux': cmd += ' --static' - if not (target.distro == 'ubuntu' and target.version == '18.04'): - # We only build tests on Ubuntu 18.04 + if target.distro != 'ubuntu' or not target.version in ('16.04', '22.04'): + # We only build tests on Ubuntu 16.04 and 22.04 cmd += ' --disable-tests' - if target.distro == 'centos' and target.version == '7': - # Centos 7 ships with glibmm 2.50.0 which requires C++11 - # but its compiler (gcc 4.8.5) defaults to C++97. Go figure. - # I worry that this will cause ABI problems but I don't have - # a better solution. - cmd += ' --force-cpp11' - if target.distro == 'mageia' and target.version == '6': - # Mageia 6 pulls the same stunt except it's libxml++ that requires C++11 - cmd += ' --force-cpp11' elif target.platform == 'windows': - cmd += ' --target-windows --disable-gcov --disable-tests' - if target.version == 'xp': - # OpenJPEG 1.x is inexplicably faster on Windows XP; see DCP-o-matic bug #771 - cmd += ' --jpeg=oj1' - elif target.platform == 'osx': - cmd += ' --disable-tests' + cmd += f' --target-windows-{target.bits}' + + if 'c++17' in options and options['c++17']: + cmd += ' --c++17' if target.debug: cmd += ' --enable-debug' @@ -76,7 +64,7 @@ def package(target, version): if target.platform == 'windows': d = 'build/libdcp-%s' % version os.mkdir(d) - for f in ['asdcp-cth.dll', 'cxml-0.dll', 'dcp-1.0.dll', 'kumu-cth.dll', 'libopenjp2.dll', 'dcpinfo.exe']: + for f in ['asdcp-carl.dll', 'cxml-0.dll', 'dcp-1.0.dll', 'kumu-carl.dll', 'libopenjp2.dll', 'dcpinfo.exe']: shutil.copyfile('%s/bin/%s' % (target.directory, f), os.path.join(d, f)) if target.bits == 32: @@ -97,10 +85,10 @@ def make_doxygen(target): target.command('doxygen') return os.path.abspath('build/doc/html') -def test(target, test): - if target.platform != 'windows': - target.set('LC_ALL', 'C') - if test is None: - target.command('run/tests') - else: - target.command('run/tests --run_test=%s' % test) +def test(target, options, test): + target.set('LC_ALL', 'C') + cmd = 'run\\tests ' if target.platform == 'windows' else 'run/tests ' + if test is not None: + cmd += '-t %s' % test + target.command(cmd) +