X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=d2ce1996c1a63f87f97aed20ecf5fe19b776d3e3;hb=5858b80d5957831f82b9650008be2ed4ab6f7c1f;hp=2f5f6f76bb2c13f99aa53ae8a21eabaabdde8858;hpb=f45f70f4a07bbf8bd794334c44126c6cfff6dac2;p=libdcp.git diff --git a/cscript b/cscript index 2f5f6f76..d2ce1996 100644 --- a/cscript +++ b/cscript @@ -1,5 +1,5 @@ # -# Copyright (C) 2012-2016 Carl Hetherington +# Copyright (C) 2012-2017 Carl Hetherington # # This file is part of libdcp. # @@ -32,21 +32,31 @@ # import os +import shutil -def dependencies(target): - if target.platform == 'windows' and target.version == 'xp': - return (('libcxml', 'v0.15.4'), ('openjpeg-cdist', '5d8bffd'), ('asdcplib-cth', 'v0.1.3')) +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', 'v0.15.5'), ('openjpeg-cdist', '4233dd7'), ('asdcplib-cth', 'f3b0fb8')) else: - return (('libcxml', 'v0.15.4'), ('openjpeg2-cdist', '94bdab1'), ('asdcplib-cth', 'v0.1.3')) + return (('libcxml', 'v0.15.5'), ('openjpeg2-cdist', 'c40a3b8'), ('asdcplib-cth', 'f3b0fb8')) 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'] if target.platform == 'linux': cmd += ' --static' if target.distro == 'centos': cmd += ' --disable-tests' - if (target.distro == 'debian' and target.version == 'unstable' or target.distro == 'fedora' and target.version == '23'): - target.append_with_space('CXXFLAGS', '-std=c++11') + if 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': @@ -61,6 +71,15 @@ def build(target, options): target.command(cmd) target.command('./waf build install') +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']: + shutil.copyfile('%s/bin/%s' % (target.directory, f), d) + os.system('zip -9 -r build/libdcp-%s.zip d' % version) + return os.path.abspath('build/libdcp-%s.zip' % version) + def make_doxygen(target): os.makedirs('build/doc') target.command('doxygen')