diff --git a/.travis.yml b/.travis.yml index 63cf3a3..51dc9df 100644 --- a/.travis.yml +++ b/.travis.yml @@ -2,13 +2,13 @@ # subject to the Boost Software License, Version 1.0. (See accompanying # file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) # -# Copyright Antony Polukhin 2014-2015. +# Copyright Antony Polukhin 2014-2016. # # See https://svn.boost.org/trac/boost/wiki/TravisCoverals for description of this file # and how it can be used with Boost libraries. # -# File revision #5 +# File revision #7 sudo: false language: cpp @@ -23,8 +23,7 @@ env: global: # Autodetect Boost branch by using the following code: - BRANCH_TO_TEST=$TRAVIS_BRANCH # or just directly specify it - #- BRANCH_TO_TEST=$TRAVIS_BRANCH - - BRANCH_TO_TEST=develop + - BRANCH_TO_TEST=$TRAVIS_BRANCH # Files, which coverage results must be ignored (files from other projects). # Example: - IGNORE_COVERAGE='*/boost/progress.hpp */filesystem/src/*' @@ -38,11 +37,12 @@ env: - BOOST_REMOVE=$(basename $TRAVIS_BUILD_DIR) matrix: - - CXX_FLAGS="--coverage -DBOOST_TRAVISCI_BUILD -std=c++98" LINK_FLAGS=--coverage TOOLSET=gcc - - CXX_FLAGS="--coverage -DBOOST_TRAVISCI_BUILD -std=c++11" LINK_FLAGS=--coverage TOOLSET=gcc-5 - - CXX_FLAGS="--coverage -DBOOST_TRAVISCI_BUILD -std=c++1y" LINK_FLAGS=--coverage TOOLSET=gcc-5 - #- CXX_FLAGS="--coverage -DBOOST_TRAVISCI_BUILD -std=c++11 -stdlib=libc++" LINK_FLAGS="--coverage -stdlib=libc++" TOOLSET=clang - #- CXX_FLAGS="--coverage -DBOOST_TRAVISCI_BUILD -std=c++1y -stdlib=libc++" LINK_FLAGS="--coverage -stdlib=libc++" TOOLSET=clang + # Note that "--coverage -fsanitize=address,leak,undefined -DBOOST_TRAVISCI_BUILD" are added automatically lower in code + - CXX_FLAGS="-std=c++98" LINK_FLAGS="" TOOLSET=gcc-6 + - CXX_FLAGS="-std=c++11" LINK_FLAGS="" TOOLSET=gcc-6 + - CXX_FLAGS="-std=c++1y" LINK_FLAGS="" TOOLSET=gcc-6 + #- CXX_FLAGS="-std=c++11 -stdlib=libc++" LINK_FLAGS="-stdlib=libc++" TOOLSET=clang + #- CXX_FLAGS="-std=c++1y -stdlib=libc++" LINK_FLAGS="-stdlib=libc++" TOOLSET=clang ############################################################################################################### # From this point and below code is same for all the Boost libs @@ -54,12 +54,12 @@ addons: apt: sources: - ubuntu-toolchain-r-test + - git-core packages: - - valgrind + - git - python-yaml - - gcc-5 - - g++-5 - - lcov + - gcc-6 + - g++-6 - clang - libc++-dev @@ -74,13 +74,9 @@ before_install: - git remote add --no-tags -t $BRANCH_TO_TEST origin https://github.com/boostorg/boost.git - git fetch --depth=1 - git checkout $BRANCH_TO_TEST - - git submodule update --init --merge + - git submodule update --jobs=3 --init --merge - git remote set-branches --add origin $BRANCH_TO_TEST - git pull --recurse-submodules - - git submodule update --init - - git checkout $BRANCH_TO_TEST - - git submodule foreach "git reset --quiet --hard; git clean -fxd" - - git reset --hard; git clean -fxd - git status - rm -rf $BOOST/libs/$BOOST_REMOVE - mv $TRAVIS_BUILD_DIR $BOOST/libs/$PROJECT_TO_TEST @@ -91,25 +87,31 @@ before_install: script: # `--coverage` flags required to generate coverage info for Coveralls - - ../../../b2 testing.launcher=valgrind address-model=64 architecture=x86 toolset=$TOOLSET cxxflags="$CXX_FLAGS" linkflags="$LINK_FLAGS" + - ../../../b2 "testing.launcher=LD_PRELOAD=/usr/lib/x86_64-linux-gnu/libasan.so.3 " address-model=64 architecture=x86 toolset=$TOOLSET cxxflags="--coverage -fsanitize=address,leak,undefined -DBOOST_TRAVISCI_BUILD $CXX_FLAGS" linkflags="$LINK_FLAGS --coverage -lasan -lubsan" after_success: # Copying Coveralls data to a separate folder - mkdir -p $TRAVIS_BUILD_DIR/coverals - find ../../../bin.v2/ -name "*.gcda" -exec cp "{}" $TRAVIS_BUILD_DIR/coverals/ \; - find ../../../bin.v2/ -name "*.gcno" -exec cp "{}" $TRAVIS_BUILD_DIR/coverals/ \; + - find ../../../bin.v2/ -name "*.da" -exec cp "{}" $TRAVIS_BUILD_DIR/coverals/ \; + - find ../../../bin.v2/ -name "*.no" -exec cp "{}" $TRAVIS_BUILD_DIR/coverals/ \; + - wget https://github.com/linux-test-project/lcov/archive/v1.12.zip + - unzip v1.12.zip + - LCOV="`pwd`/lcov-1.12/bin/lcov --gcov-tool gcov-6" # Preparing Coveralls data by changind data format to a readable one - - lcov --directory $TRAVIS_BUILD_DIR/coverals --base-directory ./ --capture --output-file $TRAVIS_BUILD_DIR/coverals/coverage.info + - echo "$LCOV --directory $TRAVIS_BUILD_DIR/coverals --base-directory `pwd` --capture --output-file $TRAVIS_BUILD_DIR/coverals/coverage.info" + - $LCOV --directory $TRAVIS_BUILD_DIR/coverals --base-directory `pwd` --capture --output-file $TRAVIS_BUILD_DIR/coverals/coverage.info # ... erasing /test/ /example/ folder data - cd $BOOST - - lcov --remove $TRAVIS_BUILD_DIR/coverals/coverage.info "/usr*" "*/$PROJECT_TO_TEST/test/*" $IGNORE_COVERAGE "*/$PROJECT_TO_TEST/tests/*" "*/$PROJECT_TO_TEST/examples/*" "*/$PROJECT_TO_TEST/example/*" -o $TRAVIS_BUILD_DIR/coverals/coverage.info + - $LCOV --remove $TRAVIS_BUILD_DIR/coverals/coverage.info "/usr*" "*/$PROJECT_TO_TEST/test/*" $IGNORE_COVERAGE "*/$PROJECT_TO_TEST/tests/*" "*/$PROJECT_TO_TEST/examples/*" "*/$PROJECT_TO_TEST/example/*" -o $TRAVIS_BUILD_DIR/coverals/coverage.info # ... erasing data that is not related to this project directly - OTHER_LIBS=`grep "submodule .*" .gitmodules | sed 's/\[submodule\ "\(.*\)"\]/"\*\/boost\/\1\.hpp" "\*\/boost\/\1\/\*"/g'| sed "/\"\*\/boost\/$PROJECT_TO_TEST\/\*\"/d" | sed ':a;N;$!ba;s/\n/ /g'` - echo $OTHER_LIBS - - eval "lcov --remove $TRAVIS_BUILD_DIR/coverals/coverage.info $OTHER_LIBS -o $TRAVIS_BUILD_DIR/coverals/coverage.info" + - eval "$LCOV --remove $TRAVIS_BUILD_DIR/coverals/coverage.info $OTHER_LIBS -o $TRAVIS_BUILD_DIR/coverals/coverage.info" # Sending data to Coveralls - cd $TRAVIS_BUILD_DIR diff --git a/include/boost/type_index/stl_type_index.hpp b/include/boost/type_index/stl_type_index.hpp index a5add88..be28889 100644 --- a/include/boost/type_index/stl_type_index.hpp +++ b/include/boost/type_index/stl_type_index.hpp @@ -1,5 +1,5 @@ // -// Copyright (c) Antony Polukhin, 2013-2015. +// Copyright (c) Antony Polukhin, 2013-2017. // // // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -174,7 +174,7 @@ inline std::string stl_type_index::pretty_name() const { inline std::size_t stl_type_index::hash_code() const BOOST_NOEXCEPT { -#if _MSC_VER > 1600 || (__GNUC__ == 4 && __GNUC_MINOR__ > 5 && defined(__GXX_EXPERIMENTAL_CXX0X__)) +#if (defined(_MSC_VER) && _MSC_VER > 1600) || (__GNUC__ == 4 && __GNUC_MINOR__ > 5 && defined(__GXX_EXPERIMENTAL_CXX0X__)) return data_->hash_code(); #else return boost::hash_range(raw_name(), raw_name() + std::strlen(raw_name())); diff --git a/test/appveyor.yml b/test/appveyor.yml index 6e33f4d..200e730 100644 --- a/test/appveyor.yml +++ b/test/appveyor.yml @@ -2,27 +2,23 @@ # subject to the Boost Software License, Version 1.0. (See accompanying # file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) # -# Copyright Antony Polukhin 2016. +# Copyright Antony Polukhin 2016-2017. # # See https://svn.boost.org/trac/boost/wiki/TravisCoverals for description of this file # and how it can be used with Boost libraries. # -# File revision #1 +# File revision #3 init: - - set BRANCH_TO_TEST=%APPVEYOR_REPO_BRANCH% - - set BOOST_REMOVE=type_index - -os: Visual Studio 2015 -configuration: Debug -platform: x64 + - set BRANCH_TO_TEST=%APPVEYOR_REPO_BRANCH% # Change to branch you wish to test. Use %APPVEYOR_REPO_BRANCH% for current branch. + - set BOOST_REMOVE=type_index # Remove this folder from lib from full clone of Boost. If you are testing `any` repo, write here `any`. ############################################################################################################### # From this point and below code is same for all the Boost libs ############################################################################################################### -version: 1.61.{build}-{branch} +version: 1.64.{build}-{branch} # branches to build branches: @@ -32,6 +28,7 @@ branches: skip_tags: true before_build: + - set PATH=%PATH%;C:\\MinGW\\bin # Set this to the name of the library - set PROJECT_TO_TEST=%APPVEYOR_PROJECT_NAME% - echo "Testing %PROJECT_TO_TEST%" @@ -45,12 +42,6 @@ before_build: - git submodule update --init --merge - git remote set-branches --add origin %BRANCH_TO_TEST% - git pull --recurse-submodules - - git submodule update --init - - git checkout %BRANCH_TO_TEST% - #- git submodule foreach "git reset --quiet --hard" - #- git submodule foreach "git clean -fxd" - - git reset --hard - - git clean -fxd - git status - rm -rf %BOOST%/libs/%BOOST_REMOVE% - mv %APPVEYOR_BUILD_FOLDER% %BOOST%/libs/%PROJECT_TO_TEST% @@ -65,7 +56,7 @@ build_script: after_build: before_test: test_script: - - ..\..\..\b2.exe address-model=64 architecture=x86 cxxflags="-DBOOST_TRAVISCI_BUILD" -sBOOST_BUILD_PATH=. + - ..\..\..\b2.exe address-model=32 architecture=x86 toolset=msvc,gcc cxxflags="-DBOOST_TRAVISCI_BUILD" -sBOOST_BUILD_PATH=. after_test: on_success: