X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=cscript;h=b65723af13e483594229113be70574fff36bbde0;hb=d8f1f9b395f3ea8dcd8b33f90ffd47e3469b83c6;hp=183f908c6075e793691a67ac53089db24b75cba6;hpb=fea74301948e42bb5fd2853ed84a68a4fb86bbc7;p=libcxml.git diff --git a/cscript b/cscript index 183f908..b65723a 100644 --- a/cscript +++ b/cscript @@ -1,8 +1,63 @@ -def build(target): - cmd = './waf configure --prefix=%s' % target.work_dir_cscript() +# -*- mode: python -*- +# +# Copyright (C) 2016-2020 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 + +option_defaults = { 'force-cpp11', False } + +def build(target, options): + cmd = './waf configure --prefix=%s' % target.directory if target.platform == 'linux': cmd += ' --static' + if target.distro == 'centos': + # Centos builds using static boost, which means tests don't + # build as test/tests.cc defines BOOST_TEST_DYN_LINK + cmd += ' --disable-tests' elif target.platform == 'windows': cmd += ' --target-windows' + + # 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. Mageia 6 pulls the same stunt except it's + # libxml++ that requires C++11 + force_cpp11 = False + if target.platform == 'linux': + if target.distro == 'centos' and target.version == '7': + force_cpp11 = True + if target.distro == 'mageia' and target.version == '6': + force_cpp11 = True + if target.platform == 'windows': + force_cpp11 = True + if force_cpp11 or options['force-cpp11']: + cmd += ' --force-cpp11' + target.command(cmd) target.command('./waf build install') + +def test(target, test): + if target.platform != 'windows': + target.set('LC_ALL', 'C') + target.command('./run-tests.sh') + +def make_doxygen(target): + os.makedirs('build/doc') + target.command('doxygen') + return os.path.abspath('build/doc/html')