X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=566afe1aef13ef7cf96a2504310e0efe247ad212;hb=6dd54f65498875549279abd2c48f2a3ed1bc56b8;hp=2d2d2f2516c5b0d6e9a19afac719893acf5dd265;hpb=cf4e397af82350bf4aed2ddf4fb2e8a890ce5ea9;p=libcxml.git diff --git a/cscript b/cscript index 2d2d2f2..566afe1 100644 --- a/cscript +++ b/cscript @@ -1,5 +1,28 @@ +# -*- mode: python -*- +# +# Copyright (C) 2016 Carl Hetherington +# +# This file is part of libcxml. +# +# libcxml is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# libcxml is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with libcxml. If not, see . +# + import os +def dependencies(target): + return (('locked_sstream', '7ab4a63'),) + def build(target, options): cmd = './waf configure --prefix=%s' % target.directory if target.platform == 'linux': @@ -8,14 +31,22 @@ def build(target, options): # Centos builds using static boost, which means tests don't # build as test/tests.cc defines BOOST_TEST_DYN_LINK cmd += ' --disable-tests' - if target.distro == 'debian' and target.version == 'unstable': - cmd += ' --check-cxx-compiler=g++-4.9' + 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' + # Similarly with Windows + cmd += ' --force-cpp11 --target-windows' target.command(cmd) target.command('./waf build install') -def test(target): +def test(target, test): if target.platform != 'windows': target.set('LC_ALL', 'C') target.command('./run-tests.sh')