- Explicitly static_assert if raw pointers are used when calling "gro… #129
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
pull_request: | |
push: | |
branches: | |
- master | |
- develop | |
- feature/** | |
env: | |
GIT_FETCH_JOBS: 8 | |
NET_RETRY_COUNT: 5 | |
DEFAULT_BUILD_VARIANT: debug,release | |
jobs: | |
posix: | |
defaults: | |
run: | |
shell: bash | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
#------------------ | |
# Linux, gcc | |
#------------------ | |
# Linux, gcc-4.6 | |
- toolset: gcc-4.6 | |
cxxstd: "03,0x" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- g++-4.6-multilib | |
sources: | |
- "ppa:ubuntu-toolchain-r/test" | |
# Linux, gcc-4.7 | |
- toolset: gcc-4.7 | |
cxxstd: "03,11" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- g++-4.7-multilib | |
# Linux, gcc-4.8 | |
- toolset: gcc-4.8 | |
cxxstd: "03,11" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- g++-4.8-multilib | |
# Linux, gcc-4.9 | |
- toolset: gcc-4.9 | |
cxxstd: "03,11" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- g++-4.9-multilib | |
# Linux, gcc-5 | |
- toolset: gcc-5 | |
cxxflags: -pipe | |
cxxstd: "03,11,14,1z" | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- g++-5-multilib | |
# Linux, gcc-6 | |
- toolset: gcc-6 | |
cxxstd: "03,11,14,1z" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- g++-6-multilib | |
# Linux, gcc-7 | |
- toolset: gcc-7 | |
cxxstd: "03,11,14,17" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- g++-7-multilib | |
# Linux, gcc-8 | |
- toolset: gcc-8 | |
cxxstd: "03,11,14,17,2a" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- g++-8-multilib | |
# Linux, gcc-9 | |
- toolset: gcc-9 | |
cxxstd: "03,11,14,17,2a" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:20.04 | |
install: | |
- g++-9-multilib | |
# Linux, gcc-10 | |
- toolset: gcc-10 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:20.04 | |
install: | |
- g++-10-multilib | |
# Linux, gcc-11 | |
- toolset: gcc-11 | |
cxxstd: "03,11,14,17,20,23" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- g++-11-multilib | |
# Linux, gcc-12 | |
- toolset: gcc-12 | |
cxxstd: "03,11,14,17,20,23" | |
cxxflags: -pipe | |
address-model: 32,64 | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- g++-12-multilib | |
# Linux, gcc-13 | |
- toolset: gcc-13 | |
cxxstd: "11,14,17,20,2b" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:24.04 | |
install: g++-13-multilib | |
address-model: 32,64 | |
# Linux, gcc-14 | |
- toolset: gcc-14 | |
cxxstd: "11,14,17,20,2b" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:24.04 | |
install: g++-14-multilib | |
address-model: 32,64 | |
# Linux, gcc-12 UBSAN | |
- name: UBSAN | |
toolset: gcc-12 | |
cxxstd: "03,11,14,17,20,23" | |
cxxflags: -pipe | |
ubsan: 1 | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- g++-12 | |
#------------------ | |
# Linux, clang | |
#------------------ | |
# Linux, clang-3.5 | |
- toolset: clang | |
compiler: clang++-3.5 | |
cxxstd: "03,11" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- clang-3.5 | |
# Linux, clang-3.6 | |
- toolset: clang | |
compiler: clang++-3.6 | |
cxxstd: "03,11,14" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- clang-3.6 | |
# Linux, clang-3.7 | |
- toolset: clang | |
compiler: clang++-3.7 | |
cxxstd: "03,11,14" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- clang-3.7 | |
# Linux, clang-3.8 | |
- toolset: clang | |
compiler: clang++-3.8 | |
cxxstd: "03,11,14" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:16.04 | |
install: | |
- clang-3.8 | |
# Linux, clang-3.9 | |
- toolset: clang | |
compiler: clang++-3.9 | |
cxxstd: "03,11,14" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-3.9 | |
# Linux, clang-4.0 | |
- toolset: clang | |
compiler: clang++-4.0 | |
cxxstd: "03,11,14" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-4.0 | |
# Linux, clang-5.0 | |
- toolset: clang | |
compiler: clang++-5.0 | |
cxxstd: "03,11,14,1z" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-5.0 | |
# Linux, clang-6.0 | |
- toolset: clang | |
compiler: clang++-6.0 | |
cxxstd: "03,11,14,17" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-6.0 | |
# Linux, clang-7 | |
- toolset: clang | |
compiler: clang++-7 | |
cxxstd: "03,11,14,17" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-7 | |
# Linux, clang-8 | |
# Note: clang-8 does not fully support C++20, so it is not compatible with libstdc++-8 in this mode | |
- toolset: clang | |
compiler: clang++-8 | |
cxxstd: "03,11,14,17,2a" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:18.04 | |
install: | |
- clang-8 | |
- g++-7 | |
gcc_toolchain: 7 | |
# Linux, clang-9 | |
- toolset: clang | |
compiler: clang++-9 | |
cxxstd: "03,11,14,17,2a" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:20.04 | |
install: | |
- clang-9 | |
# Linux, clang-10 | |
- toolset: clang | |
compiler: clang++-10 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:20.04 | |
install: | |
- clang-10 | |
# Linux, clang-11 | |
- toolset: clang | |
compiler: clang++-11 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- clang-11 | |
# Linux, clang-12 | |
- toolset: clang | |
compiler: clang++-12 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- clang-12 | |
# Linux, clang-13 | |
- toolset: clang | |
compiler: clang++-13 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- clang-13 | |
# Linux, clang-14 | |
- toolset: clang | |
compiler: clang++-14 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
os: ubuntu-latest | |
container: ubuntu:22.04 | |
install: | |
- clang-14 | |
# Linux, clang-15 | |
- toolset: clang | |
compiler: clang++-15 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe | |
container: ubuntu:22.04 | |
os: ubuntu-latest | |
install: clang-15 | |
# Linux, clang-16 | |
- toolset: clang | |
compiler: clang++-16 | |
cxxflags: -pipe | |
cxxstd: "03,11,14,17,20,2b" | |
container: ubuntu:24.04 | |
os: ubuntu-latest | |
install: clang-16 | |
# Linux, clang-17 | |
- toolset: clang | |
compiler: clang++-17 | |
cxxstd: "03,11,14,17,20,2b" | |
cxxflags: -pipe | |
container: ubuntu:24.04 | |
os: ubuntu-latest | |
install: clang-17 | |
# Linux, clang-18 | |
- toolset: clang | |
compiler: clang++-18 | |
cxxstd: "03,11,14,17,20,2b" | |
cxxflags: -pipe | |
container: ubuntu:24.04 | |
os: ubuntu-latest | |
install: clang-18 | |
# Linux, clang-15 libc++ | |
- toolset: clang | |
compiler: clang++-15 | |
cxxstd: "03,11,14,17,20,2b" | |
os: ubuntu-22.04 | |
install: | |
- clang-15 | |
- libc++-15-dev | |
- libc++abi-15-dev | |
cxxflags: -pipe -stdlib=libc++ | |
linkflags: -stdlib=libc++ | |
# Linux, clang-18 libc++ | |
- toolset: clang | |
compiler: clang++-18 | |
cxxstd: "11,14,17,20,2b" | |
os: ubuntu-24.04 | |
install: | |
- clang-18 | |
- libc++-18-dev | |
- libc++abi-18-dev | |
cxxflags: -pipe -stdlib=libc++ | |
linkflags: -stdlib=libc++ | |
# Linux, clang-14 libc++, ubsan | |
- name: UBSAN | |
toolset: clang | |
compiler: clang++-14 | |
cxxstd: "03,11,14,17,20" | |
cxxflags: -pipe -stdlib=libc++ | |
linkflags: -stdlib=libc++ | |
ubsan: 1 | |
os: ubuntu-22.04 | |
install: | |
- clang-14 | |
- libc++-14-dev | |
- libc++abi-14-dev | |
# Linux, clang-18 libc++, ubsan | |
- name: UBSAN | |
toolset: clang | |
compiler: clang++-18 | |
cxxstd: "11,14,17,20" | |
cxxflags: -pipe -stdlib=libc++ | |
linkflags: -stdlib=libc++ | |
ubsan: 1 | |
os: ubuntu-24.04 | |
install: | |
- clang-18 | |
- libc++-18-dev | |
- libc++abi-18-dev | |
#------------------ | |
# MacOS, clang | |
#------------------ | |
# Macos 12, clang | |
- toolset: clang | |
cxxstd: "11,14,17,20,2b" | |
cxxflags: -pipe | |
os: macos-12 | |
# Macos 13, clang | |
- toolset: clang | |
cxxstd: "11,14,17,20,2b" | |
cxxflags: -pipe | |
os: macos-13 | |
# Macos 17, clang | |
- toolset: clang | |
cxxstd: "11,14,17,20,2b" | |
cxxflags: -pipe | |
os: macos-14 | |
timeout-minutes: 180 | |
runs-on: ${{matrix.os}} | |
container: ${{matrix.container}} | |
steps: | |
- name: Setup environment | |
run: | | |
if [ -f "/etc/debian_version" ] | |
then | |
echo "DEBIAN_FRONTEND=noninteractive" >> $GITHUB_ENV | |
export DEBIAN_FRONTEND=noninteractive | |
fi | |
if [ -n "${{matrix.container}}" ] | |
then | |
echo "GHA_CONTAINER=${{matrix.container}}" >> $GITHUB_ENV | |
if [ -f "/etc/debian_version" ] | |
then | |
apt-get -o Acquire::Retries=$NET_RETRY_COUNT update | |
if [ "$(apt-cache search "^python-is-python3$" | wc -l)" -ne 0 ] | |
then | |
PYTHON_PACKAGE="python-is-python3" | |
else | |
PYTHON_PACKAGE="python" | |
fi | |
apt-get -o Acquire::Retries=$NET_RETRY_COUNT install -y sudo software-properties-common tzdata wget curl apt-transport-https ca-certificates make build-essential g++ $PYTHON_PACKAGE python3 perl git cmake | |
fi | |
fi | |
git config --global pack.threads 0 | |
- name: Install packages | |
if: matrix.install | |
run: | | |
declare -a SOURCE_KEYS SOURCES | |
if [ -n "${{join(matrix.source_keys, ' ')}}" ] | |
then | |
SOURCE_KEYS=("${{join(matrix.source_keys, '" "')}}") | |
fi | |
if [ -n "${{join(matrix.sources, ' ')}}" ] | |
then | |
SOURCES=("${{join(matrix.sources, '" "')}}") | |
fi | |
for key in "${SOURCE_KEYS[@]}" | |
do | |
for i in {1..$NET_RETRY_COUNT} | |
do | |
echo "Adding key: $key" | |
wget -O - "$key" | sudo apt-key add - && break || sleep 2 | |
done | |
done | |
if [ ${#SOURCES[@]} -gt 0 ] | |
then | |
APT_ADD_REPO_COMMON_ARGS=("-y") | |
APT_ADD_REPO_SUPPORTED_ARGS="$(apt-add-repository --help | perl -ne 'if (/^\s*-n/) { print "n"; } elsif (/^\s*-P/) { print "P"; } elsif (/^\s*-S/) { print "S"; } elsif (/^\s*-U/) { print "U"; }')" | |
if [ -n "$APT_ADD_REPO_SUPPORTED_ARGS" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*n*}" ] | |
then | |
APT_ADD_REPO_COMMON_ARGS+=("-n") | |
fi | |
APT_ADD_REPO_HAS_SOURCE_ARGS="$([ -n "$APT_ADD_REPO_SUPPORTED_ARGS" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*P*}" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*S*}" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*U*}" ] && echo 1 || echo 0)" | |
for source in "${SOURCES[@]}" | |
do | |
for i in {1..$NET_RETRY_COUNT} | |
do | |
APT_ADD_REPO_ARGS=("${APT_ADD_REPO_COMMON_ARGS[@]}") | |
if [ $APT_ADD_REPO_HAS_SOURCE_ARGS -ne 0 ] | |
then | |
case "$source" in | |
"ppa:"*) | |
APT_ADD_REPO_ARGS+=("-P") | |
;; | |
"deb "*) | |
APT_ADD_REPO_ARGS+=("-S") | |
;; | |
*) | |
APT_ADD_REPO_ARGS+=("-U") | |
;; | |
esac | |
fi | |
APT_ADD_REPO_ARGS+=("$source") | |
echo "apt-add-repository ${APT_ADD_REPO_ARGS[@]}" | |
sudo -E apt-add-repository "${APT_ADD_REPO_ARGS[@]}" && break || sleep 2 | |
done | |
done | |
fi | |
sudo apt-get -o Acquire::Retries=$NET_RETRY_COUNT update | |
sudo apt-get -o Acquire::Retries=$NET_RETRY_COUNT install -y ${{join(matrix.install, ' ')}} | |
- name: Setup GCC Toolchain | |
if: matrix.gcc_toolchain | |
run: | | |
GCC_TOOLCHAIN_ROOT="$HOME/gcc-toolchain" | |
echo "GCC_TOOLCHAIN_ROOT=\"$GCC_TOOLCHAIN_ROOT\"" >> $GITHUB_ENV | |
MULTIARCH_TRIPLET="$(dpkg-architecture -qDEB_HOST_MULTIARCH)" | |
mkdir -p "$GCC_TOOLCHAIN_ROOT" | |
ln -s /usr/include "$GCC_TOOLCHAIN_ROOT/include" | |
ln -s /usr/bin "$GCC_TOOLCHAIN_ROOT/bin" | |
mkdir -p "$GCC_TOOLCHAIN_ROOT/lib/gcc/$MULTIARCH_TRIPLET" | |
ln -s "/usr/lib/gcc/$MULTIARCH_TRIPLET/${{matrix.gcc_toolchain}}" "$GCC_TOOLCHAIN_ROOT/lib/gcc/$MULTIARCH_TRIPLET/${{matrix.gcc_toolchain}}" | |
- name: Setup Boost | |
run: | | |
echo GITHUB_REPOSITORY: $GITHUB_REPOSITORY | |
LIBRARY=${GITHUB_REPOSITORY#*/} | |
echo LIBRARY: $LIBRARY | |
echo "LIBRARY=$LIBRARY" >> $GITHUB_ENV | |
echo GITHUB_BASE_REF: $GITHUB_BASE_REF | |
echo GITHUB_REF: $GITHUB_REF | |
REF=${GITHUB_BASE_REF:-$GITHUB_REF} | |
REF=${REF#refs/heads/} | |
echo REF: $REF | |
BOOST_BRANCH=develop && [ "$REF" = "master" ] && BOOST_BRANCH=master || true | |
echo BOOST_BRANCH: $BOOST_BRANCH | |
BUILD_JOBS=$((nproc || sysctl -n hw.ncpu) 2> /dev/null) | |
echo "BUILD_JOBS=$BUILD_JOBS" >> $GITHUB_ENV | |
echo "CMAKE_BUILD_PARALLEL_LEVEL=$BUILD_JOBS" >> $GITHUB_ENV | |
DEPINST_ARGS=() | |
GIT_VERSION="$(git --version | sed -e 's/git version //')" | |
GIT_HAS_JOBS=1 | |
if [ -f "/etc/debian_version" ] | |
then | |
if $(dpkg --compare-versions "$GIT_VERSION" lt 2.8.0) | |
then | |
GIT_HAS_JOBS=0 | |
fi | |
else | |
declare -a GIT_VER=(${GIT_VERSION//./ }) | |
declare -a GIT_MIN_VER=(2 8 0) | |
for ((i=0; i<${#GIT_VER[@]}; i++)) | |
do | |
if [ -z "${GIT_MIN_VER[i]}" ] | |
then | |
GIT_MIN_VER[i]=0 | |
fi | |
if [ "${GIT_VER[i]}" -lt "${GIT_MIN_VER[i]}" ] | |
then | |
GIT_HAS_JOBS=0 | |
break | |
fi | |
done | |
fi | |
if [ "$GIT_HAS_JOBS" -ne 0 ] | |
then | |
DEPINST_ARGS+=("--git_args" "--jobs $GIT_FETCH_JOBS") | |
fi | |
mkdir -p snapshot | |
cd snapshot | |
echo "Downloading library snapshot: https://github.com/${GITHUB_REPOSITORY}/archive/${GITHUB_SHA}.tar.gz" | |
curl -L --retry "$NET_RETRY_COUNT" -o "${LIBRARY}-${GITHUB_SHA}.tar.gz" "https://github.com/${GITHUB_REPOSITORY}/archive/${GITHUB_SHA}.tar.gz" | |
tar -xf "${LIBRARY}-${GITHUB_SHA}.tar.gz" | |
if [ ! -d "${LIBRARY}-${GITHUB_SHA}" ] | |
then | |
echo "Library snapshot does not contain the library directory ${LIBRARY}-${GITHUB_SHA}:" | |
ls -la | |
exit 1 | |
fi | |
rm -f "${LIBRARY}-${GITHUB_SHA}.tar.gz" | |
cd .. | |
git clone -b "$BOOST_BRANCH" --depth 1 "https://github.com/boostorg/boost.git" "boost-root" | |
cd boost-root | |
mkdir -p libs | |
rm -rf "libs/$LIBRARY" | |
mv -f "../snapshot/${LIBRARY}-${GITHUB_SHA}" "libs/$LIBRARY" | |
rm -rf "../snapshot" | |
git submodule update --init tools/boostdep | |
DEPINST_ARGS+=("$LIBRARY") | |
python tools/boostdep/depinst/depinst.py "${DEPINST_ARGS[@]}" | |
./bootstrap.sh | |
./b2 headers | |
if [ -n "${{matrix.compiler}}" -o -n "$GCC_TOOLCHAIN_ROOT" ] | |
then | |
echo -n "using ${{matrix.toolset}} : : ${{matrix.compiler}}" > ~/user-config.jam | |
if [ -n "$GCC_TOOLCHAIN_ROOT" ] | |
then | |
echo -n " : <compileflags>\"--gcc-toolchain=$GCC_TOOLCHAIN_ROOT\" <linkflags>\"--gcc-toolchain=$GCC_TOOLCHAIN_ROOT\"" >> ~/user-config.jam | |
fi | |
echo " ;" >> ~/user-config.jam | |
fi | |
- name: Run tests | |
if: matrix.cmake_tests == '' | |
run: | | |
cd boost-root | |
B2_ARGS=("-j" "$BUILD_JOBS" "toolset=${{matrix.toolset}}" "cxxstd=${{matrix.cxxstd}}") | |
if [ -n "${{matrix.build_variant}}" ] | |
then | |
B2_ARGS+=("variant=${{matrix.build_variant}}") | |
else | |
B2_ARGS+=("variant=$DEFAULT_BUILD_VARIANT") | |
fi | |
if [ -n "${{matrix.threading}}" ] | |
then | |
B2_ARGS+=("threading=${{matrix.threading}}") | |
fi | |
if [ -n "${{matrix.ubsan}}" ] | |
then | |
export UBSAN_OPTIONS="print_stacktrace=1" | |
B2_ARGS+=("undefined-sanitizer=norecover" "linkflags=-fuse-ld=gold" "define=UBSAN=1" "debug-symbols=on" "visibility=global") | |
fi | |
if [ -n "${{matrix.cxxflags}}" ] | |
then | |
B2_ARGS+=("cxxflags=${{matrix.cxxflags}}") | |
fi | |
if [ -n "${{matrix.address-model}}" ] | |
then | |
B2_ARGS+=("address-model=${{matrix.address-model}}") | |
fi | |
if [ -n "${{matrix.linkflags}}" ] | |
then | |
B2_ARGS+=("linkflags=${{matrix.linkflags}}") | |
fi | |
B2_ARGS+=("libs/$LIBRARY/test") | |
./b2 "${B2_ARGS[@]}" | |
windows: | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- toolset: msvc-14.0 | |
cxxstd: "14" | |
addrmd: 32,64 | |
os: windows-2019 | |
- toolset: msvc-14.2 | |
cxxstd: "14,17,20,latest" | |
addrmd: 32,64 | |
os: windows-2019 | |
- toolset: msvc-14.3 | |
cxxstd: "14,17,20,latest" | |
addrmd: 32,64 | |
os: windows-2022 | |
- toolset: clang-win | |
cxxstd: "14,17,latest" | |
addrmd: 64 | |
os: windows-2022 | |
- toolset: gcc | |
cxxstd: "03,11,14,17,2a" | |
cxxflags: -pipe | |
addrmd: 64 | |
os: windows-2019 | |
timeout-minutes: 180 | |
runs-on: ${{matrix.os}} | |
steps: | |
- name: Setup Boost | |
shell: cmd | |
run: | | |
echo GITHUB_REPOSITORY: %GITHUB_REPOSITORY% | |
for /f %%i in ("%GITHUB_REPOSITORY%") do set LIBRARY=%%~nxi | |
echo LIBRARY: %LIBRARY% | |
echo LIBRARY=%LIBRARY%>>%GITHUB_ENV% | |
echo GITHUB_BASE_REF: %GITHUB_BASE_REF% | |
echo GITHUB_REF: %GITHUB_REF% | |
if "%GITHUB_BASE_REF%" == "" set GITHUB_BASE_REF=%GITHUB_REF% | |
set BOOST_BRANCH=develop | |
for /f %%i in ("%GITHUB_BASE_REF%") do if "%%~nxi" == "master" set BOOST_BRANCH=master | |
echo BOOST_BRANCH: %BOOST_BRANCH% | |
mkdir snapshot | |
cd snapshot | |
echo Downloading library snapshot: https://github.com/%GITHUB_REPOSITORY%/archive/%GITHUB_SHA%.zip | |
curl -L --retry %NET_RETRY_COUNT% -o "%LIBRARY%-%GITHUB_SHA%.zip" "https://github.com/%GITHUB_REPOSITORY%/archive/%GITHUB_SHA%.zip" | |
tar -xf "%LIBRARY%-%GITHUB_SHA%.zip" | |
if not exist "%LIBRARY%-%GITHUB_SHA%\" ( | |
echo Library snapshot does not contain the library directory %LIBRARY%-%GITHUB_SHA%: | |
dir | |
exit /b 1 | |
) | |
del /f "%LIBRARY%-%GITHUB_SHA%.zip" | |
cd .. | |
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root | |
cd boost-root | |
if not exist "libs\" mkdir libs | |
if exist "libs\%LIBRARY%\" rmdir /s /q "libs\%LIBRARY%" | |
move /Y "..\snapshot\%LIBRARY%-%GITHUB_SHA%" "libs\%LIBRARY%" | |
rmdir /s /q "..\snapshot" | |
git submodule update --init tools/boostdep | |
python tools/boostdep/depinst/depinst.py --git_args "--jobs %GIT_FETCH_JOBS%" %LIBRARY% | |
cmd /c bootstrap | |
b2 -d0 headers | |
- name: Run tests | |
shell: cmd | |
run: | | |
cd boost-root | |
b2 -j %NUMBER_OF_PROCESSORS% libs/%LIBRARY%/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} address-model=${{matrix.addrmd}} variant=debug,release embed-manifest-via=linker | |