mirror of
https://github.com/boostorg/exception.git
synced 2025-06-29 14:01:03 +02:00
Compare commits
47 Commits
boost-1.77
...
develop
Author | SHA1 | Date | |
---|---|---|---|
95b1ead06c | |||
e46dd22b3c | |||
1da3782f79 | |||
71ff2a5254 | |||
9238ef8e7f | |||
5ea93e34e1 | |||
40554e238c | |||
95854acc9a | |||
b5bf79462e | |||
ec7442e3b7 | |||
a27c2d5127 | |||
64ca508153 | |||
ece51fe0f7 | |||
399208b682 | |||
1c66828bb5 | |||
fd72443067 | |||
752185750d | |||
948578d5b4 | |||
b9170a02f1 | |||
f719cc1af5 | |||
ad15fefae7 | |||
11f102a987 | |||
fe23c01a93 | |||
ea70868a45 | |||
03aa58e06e | |||
0d69599d91 | |||
652e8e01d2 | |||
b039b4ea18 | |||
89d8033fed | |||
bd347f048a | |||
e2faee265d | |||
7df9fc8a85 | |||
9259706f08 | |||
eafe6dbd5c | |||
941754ed23 | |||
0d205cd71f | |||
b8e9e98b33 | |||
54f2228f78 | |||
4d18ec3e0d | |||
929ae48aa0 | |||
1dd151ae69 | |||
076211f4b4 | |||
52da83a1d7 | |||
1ed2045e07 | |||
38769cfd6b | |||
fdfd8f49fb | |||
c5367711b7 |
255
.github/workflows/ci.yml
vendored
255
.github/workflows/ci.yml
vendored
@ -17,116 +17,208 @@ jobs:
|
|||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- toolset: gcc-4.7
|
|
||||||
cxxstd: "03,11"
|
|
||||||
os: ubuntu-16.04
|
|
||||||
install: g++-4.7
|
|
||||||
- toolset: gcc-4.8
|
- toolset: gcc-4.8
|
||||||
cxxstd: "03,11"
|
cxxstd: "11"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
install: g++-4.8
|
install: g++-4.8
|
||||||
- toolset: gcc-4.9
|
|
||||||
cxxstd: "03,11"
|
|
||||||
os: ubuntu-16.04
|
|
||||||
install: g++-4.9
|
|
||||||
- toolset: gcc-5
|
- toolset: gcc-5
|
||||||
cxxstd: "03,11,14,1z"
|
cxxstd: "11,14,1z"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
|
install: g++-5
|
||||||
- toolset: gcc-6
|
- toolset: gcc-6
|
||||||
cxxstd: "03,11,14,1z"
|
cxxstd: "11,14,1z"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
install: g++-6
|
install: g++-6
|
||||||
- toolset: gcc-7
|
- toolset: gcc-7
|
||||||
cxxstd: "03,11,14,17"
|
cxxstd: "11,14,17"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
- toolset: gcc-8
|
- toolset: gcc-8
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17,2a"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-20.04
|
||||||
|
install: g++-8
|
||||||
- toolset: gcc-9
|
- toolset: gcc-9
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17,2a"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-20.04
|
||||||
- toolset: gcc-10
|
- toolset: gcc-10
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17,2a"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-20.04
|
||||||
- toolset: clang
|
install: g++-10
|
||||||
compiler: clang++-3.5
|
- toolset: gcc-11
|
||||||
cxxstd: "03,11,14"
|
cxxstd: "11,14,17,2a"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-22.04
|
||||||
install: clang-3.5
|
- toolset: gcc-12
|
||||||
- toolset: clang
|
cxxstd: "11,14,17,20,2b"
|
||||||
compiler: clang++-3.6
|
os: ubuntu-22.04
|
||||||
cxxstd: "03,11,14"
|
install: g++-12
|
||||||
os: ubuntu-16.04
|
- toolset: gcc-13
|
||||||
install: clang-3.6
|
cxxstd: "11,14,17,20,2b"
|
||||||
- toolset: clang
|
os: ubuntu-latest
|
||||||
compiler: clang++-3.7
|
container: ubuntu:24.04
|
||||||
cxxstd: "03,11,14"
|
install: g++-13
|
||||||
os: ubuntu-16.04
|
- toolset: gcc-14
|
||||||
install: clang-3.7
|
cxxstd: "11,14,17,20,2b"
|
||||||
- toolset: clang
|
os: ubuntu-latest
|
||||||
compiler: clang++-3.8
|
container: ubuntu:24.04
|
||||||
cxxstd: "03,11,14"
|
install: g++-14
|
||||||
os: ubuntu-16.04
|
|
||||||
install: clang-3.8
|
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-3.9
|
compiler: clang++-3.9
|
||||||
cxxstd: "03,11,14"
|
cxxstd: "11,14"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
install: clang-3.9
|
install: clang-3.9
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-4.0
|
compiler: clang++-4.0
|
||||||
cxxstd: "03,11,14"
|
cxxstd: "11,14"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
install: clang-4.0
|
install: clang-4.0
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-5.0
|
compiler: clang++-5.0
|
||||||
cxxstd: "03,11,14,1z"
|
cxxstd: "11,14,1z"
|
||||||
os: ubuntu-16.04
|
os: ubuntu-latest
|
||||||
|
container: ubuntu:18.04
|
||||||
install: clang-5.0
|
install: clang-5.0
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-6.0
|
compiler: clang++-6.0
|
||||||
cxxstd: "03,11,14,17"
|
cxxstd: "11,14,17"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-20.04
|
||||||
|
install: clang-6.0
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-7
|
compiler: clang++-7
|
||||||
cxxstd: "03,11,14,17"
|
cxxstd: "11,14,17"
|
||||||
os: ubuntu-18.04
|
os: ubuntu-20.04
|
||||||
install: clang-7
|
install: clang-7
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-8
|
compiler: clang++-8
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17"
|
||||||
os: ubuntu-20.04
|
os: ubuntu-20.04
|
||||||
|
install: clang-8
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-9
|
compiler: clang++-9
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17"
|
||||||
os: ubuntu-20.04
|
os: ubuntu-20.04
|
||||||
|
install: clang-9
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
compiler: clang++-10
|
compiler: clang++-10
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17,2a"
|
||||||
os: ubuntu-20.04
|
os: ubuntu-20.04
|
||||||
- toolset: clang
|
- toolset: clang
|
||||||
cxxstd: "03,11,14,17,2a"
|
compiler: clang++-11
|
||||||
os: macos-10.15
|
cxxstd: "11,14,17,2a"
|
||||||
|
os: ubuntu-20.04
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-12
|
||||||
|
cxxstd: "11,14,17,20"
|
||||||
|
os: ubuntu-20.04
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-13
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:22.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-13
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-14
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:22.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-14
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-15
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:22.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-15
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-16
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:24.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-16
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-17
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:24.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-17
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-18
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:24.04
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-18
|
||||||
|
- toolset: clang
|
||||||
|
compiler: clang++-19
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
container: ubuntu:24.10
|
||||||
|
os: ubuntu-latest
|
||||||
|
install: clang-19
|
||||||
|
- toolset: clang
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
os: macos-13
|
||||||
|
- toolset: clang
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
os: macos-14
|
||||||
|
- toolset: clang
|
||||||
|
cxxstd: "11,14,17,20,2b"
|
||||||
|
os: macos-15
|
||||||
|
|
||||||
runs-on: ${{matrix.os}}
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
container:
|
||||||
|
image: ${{matrix.container}}
|
||||||
|
volumes:
|
||||||
|
- /node20217:/node20217:rw,rshared
|
||||||
|
- ${{ startsWith(matrix.container, 'ubuntu:1') && '/node20217:/__e/node20:ro,rshared' || ' ' }}
|
||||||
|
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- name: Setup container environment
|
||||||
|
if: matrix.container
|
||||||
|
run: |
|
||||||
|
apt-get update
|
||||||
|
apt-get -y install sudo python3 git g++ curl xz-utils
|
||||||
|
|
||||||
|
- name: Install nodejs20glibc2.17
|
||||||
|
if: ${{ startsWith( matrix.container, 'ubuntu:1' ) }}
|
||||||
|
run: |
|
||||||
|
curl -LO https://archives.boost.io/misc/node/node-v20.9.0-linux-x64-glibc-217.tar.xz
|
||||||
|
tar -xf node-v20.9.0-linux-x64-glibc-217.tar.xz --strip-components 1 -C /node20217
|
||||||
|
ldd /__e/node20/bin/node
|
||||||
|
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install packages
|
- name: Install packages
|
||||||
if: matrix.install
|
if: matrix.install
|
||||||
run: sudo apt install ${{matrix.install}}
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get -y install ${{matrix.install}}
|
||||||
|
|
||||||
- name: Setup Boost
|
- name: Setup Boost
|
||||||
run: |
|
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=${GITHUB_BASE_REF:-$GITHUB_REF}
|
||||||
|
REF=${REF#refs/heads/}
|
||||||
|
echo REF: $REF
|
||||||
BOOST_BRANCH=develop && [ "$REF" == "master" ] && BOOST_BRANCH=master || true
|
BOOST_BRANCH=develop && [ "$REF" == "master" ] && BOOST_BRANCH=master || true
|
||||||
|
echo BOOST_BRANCH: $BOOST_BRANCH
|
||||||
cd ..
|
cd ..
|
||||||
git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
cd boost-root
|
cd boost-root
|
||||||
cp -r $GITHUB_WORKSPACE/* libs/exception
|
cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
|
||||||
git submodule update --init tools/boostdep
|
git submodule update --init tools/boostdep
|
||||||
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" exception
|
python3 tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY
|
||||||
./bootstrap.sh
|
./bootstrap.sh
|
||||||
./b2 -d0 headers
|
./b2 -d0 headers
|
||||||
|
|
||||||
@ -138,43 +230,58 @@ jobs:
|
|||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: |
|
run: |
|
||||||
cd ../boost-root
|
cd ../boost-root
|
||||||
./b2 -j3 libs/exception/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} variant=debug,release exception-handling=on,off rtti=on,off link=static,shared visibility=hidden,global
|
./b2 -j3 libs/$LIBRARY/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} variant=debug,release exception-handling=on,off rtti=on,off link=static,shared visibility=hidden,global
|
||||||
|
|
||||||
windows:
|
windows:
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- toolset: msvc-14.1
|
- toolset: msvc-14.0
|
||||||
cxxstd: "14,17,latest"
|
cxxstd: "14"
|
||||||
addrmd: 32,64
|
|
||||||
os: windows-2016
|
|
||||||
- toolset: msvc-14.2
|
|
||||||
cxxstd: "14,17,latest"
|
|
||||||
addrmd: 32,64
|
addrmd: 32,64
|
||||||
os: windows-2019
|
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,20,latest"
|
||||||
|
addrmd: 32,64
|
||||||
|
os: windows-2022
|
||||||
- toolset: gcc
|
- toolset: gcc
|
||||||
cxxstd: "03,11,14,17,2a"
|
cxxstd: "11,14,17,2a"
|
||||||
addrmd: 64
|
addrmd: 64
|
||||||
os: windows-2019
|
os: windows-2019
|
||||||
|
|
||||||
runs-on: ${{matrix.os}}
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Setup Boost
|
- name: Setup Boost
|
||||||
shell: cmd
|
shell: cmd
|
||||||
run: |
|
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%
|
if "%GITHUB_BASE_REF%" == "" set GITHUB_BASE_REF=%GITHUB_REF%
|
||||||
set BOOST_BRANCH=develop
|
set BOOST_BRANCH=develop
|
||||||
if "%GITHUB_BASE_REF%" == "master" set BOOST_BRANCH=master
|
for /f %%i in ("%GITHUB_BASE_REF%") do if "%%~nxi" == "master" set BOOST_BRANCH=master
|
||||||
|
echo BOOST_BRANCH: %BOOST_BRANCH%
|
||||||
cd ..
|
cd ..
|
||||||
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
cd boost-root
|
cd boost-root
|
||||||
xcopy /s /e /q %GITHUB_WORKSPACE% libs\exception\
|
xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\
|
||||||
git submodule update --init tools/boostdep
|
git submodule update --init tools/boostdep
|
||||||
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" exception
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY%
|
||||||
cmd /c bootstrap
|
cmd /c bootstrap
|
||||||
b2 -d0 headers
|
b2 -d0 headers
|
||||||
|
|
||||||
@ -182,4 +289,4 @@ jobs:
|
|||||||
shell: cmd
|
shell: cmd
|
||||||
run: |
|
run: |
|
||||||
cd ../boost-root
|
cd ../boost-root
|
||||||
b2 -j3 libs/exception/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} address-model=${{matrix.addrmd}} variant=debug,release exception-handling=on,off rtti=on,off
|
b2 -j3 libs/%LIBRARY%/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} address-model=${{matrix.addrmd}} variant=debug,release exception-handling=on,off rtti=on,off embed-manifest-via=linker
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
# Generated by `boostdep --cmake exception`
|
||||||
# Copyright 2020, 2021 Peter Dimov
|
# Copyright 2020, 2021 Peter Dimov
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
# https://www.boost.org/LICENSE_1_0.txt
|
# https://www.boost.org/LICENSE_1_0.txt
|
||||||
@ -6,16 +7,13 @@ cmake_minimum_required(VERSION 3.5...3.20)
|
|||||||
|
|
||||||
project(boost_exception VERSION "${BOOST_SUPERPROJECT_VERSION}" LANGUAGES CXX)
|
project(boost_exception VERSION "${BOOST_SUPERPROJECT_VERSION}" LANGUAGES CXX)
|
||||||
|
|
||||||
add_library(boost_exception STATIC
|
add_library(boost_exception INTERFACE)
|
||||||
src/clone_current_exception_non_intrusive.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
add_library(Boost::exception ALIAS boost_exception)
|
add_library(Boost::exception ALIAS boost_exception)
|
||||||
|
|
||||||
target_include_directories(boost_exception PUBLIC include)
|
target_include_directories(boost_exception INTERFACE include)
|
||||||
|
|
||||||
target_link_libraries(boost_exception
|
target_link_libraries(boost_exception
|
||||||
PUBLIC
|
INTERFACE
|
||||||
Boost::assert
|
Boost::assert
|
||||||
Boost::config
|
Boost::config
|
||||||
Boost::core
|
Boost::core
|
||||||
|
@ -16,6 +16,7 @@ environment:
|
|||||||
matrix:
|
matrix:
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
TOOLSET: msvc-9.0,msvc-10.0,msvc-11.0
|
TOOLSET: msvc-9.0,msvc-10.0,msvc-11.0
|
||||||
|
ADDRMD: 32
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
TOOLSET: msvc-12.0,msvc-14.0
|
TOOLSET: msvc-12.0,msvc-14.0
|
||||||
ADDRMD: 32,64
|
ADDRMD: 32,64
|
||||||
@ -29,18 +30,22 @@ environment:
|
|||||||
ADDRMD: 64
|
ADDRMD: 64
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
||||||
TOOLSET: msvc-14.2
|
TOOLSET: msvc-14.2
|
||||||
CXXSTD: 14,17
|
CXXSTD: 14,17,latest
|
||||||
ADDRMD: 32,64
|
ADDRMD: 32,64
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
ADDPATH: C:\cygwin\bin;
|
ADDPATH: C:\cygwin\bin;
|
||||||
TOOLSET: gcc
|
TOOLSET: gcc
|
||||||
CXXSTD: 03,11,14,1z
|
CXXSTD: 03,11,14,1z
|
||||||
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
|
ADDPATH: C:\cygwin64\bin;
|
||||||
|
TOOLSET: gcc
|
||||||
|
CXXSTD: 03,11,14,1z
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
ADDPATH: C:\mingw\bin;
|
ADDPATH: C:\mingw\bin;
|
||||||
TOOLSET: gcc
|
TOOLSET: gcc
|
||||||
CXXSTD: 03,11,14,1z
|
CXXSTD: 03,11,14,1z
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
ADDPATH: C:\mingw-w64\x86_64-7.2.0-posix-seh-rt_v5-rev1\mingw64\bin;
|
ADDPATH: C:\mingw-w64\x86_64-6.3.0-posix-seh-rt_v5-rev1\mingw64\bin;
|
||||||
TOOLSET: gcc
|
TOOLSET: gcc
|
||||||
CXXSTD: 03,11,14,1z
|
CXXSTD: 03,11,14,1z
|
||||||
|
|
||||||
|
27
build.jam
Normal file
27
build.jam
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# Copyright René Ferdinand Rivera Morell 2023-2024
|
||||||
|
# Distributed under 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)
|
||||||
|
|
||||||
|
require-b2 5.2 ;
|
||||||
|
|
||||||
|
constant boost_dependencies :
|
||||||
|
/boost/assert//boost_assert
|
||||||
|
/boost/config//boost_config
|
||||||
|
/boost/core//boost_core
|
||||||
|
/boost/smart_ptr//boost_smart_ptr
|
||||||
|
/boost/throw_exception//boost_throw_exception
|
||||||
|
/boost/tuple//boost_tuple
|
||||||
|
/boost/type_traits//boost_type_traits ;
|
||||||
|
|
||||||
|
project /boost/exception
|
||||||
|
;
|
||||||
|
|
||||||
|
explicit
|
||||||
|
[ alias boost_exception : build//boost_exception ]
|
||||||
|
[ alias all : boost_exception example test ]
|
||||||
|
;
|
||||||
|
|
||||||
|
call-if : boost-library exception
|
||||||
|
: install boost_exception
|
||||||
|
;
|
@ -5,10 +5,11 @@
|
|||||||
# Distributed under the Boost Software License, Version 1.0. (See accompanying
|
# Distributed under 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)
|
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
project boost/exception
|
project
|
||||||
: source-location ../src
|
: source-location ../src
|
||||||
|
: common-requirements <include>../include <library>$(boost_dependencies)
|
||||||
: requirements <link>static
|
: requirements <link>static
|
||||||
|
: usage-requirements <define>BOOST_EXCEPTION_NO_LIB=1
|
||||||
;
|
;
|
||||||
|
|
||||||
lib boost_exception : clone_current_exception_non_intrusive.cpp ;
|
lib boost_exception : clone_current_exception_non_intrusive.cpp : <exception-handling>on ;
|
||||||
boost-install boost_exception ;
|
|
||||||
|
@ -27,7 +27,6 @@
|
|||||||
#include <boost/current_function.hpp>
|
#include <boost/current_function.hpp>
|
||||||
#define <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span>(x)\
|
#define <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span>(x)\
|
||||||
::boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>( ::boost::<span class="RenoLink"><a href="enable_error_info.html">enable_error_info</a></span>(x) <<\
|
::boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>( ::boost::<span class="RenoLink"><a href="enable_error_info.html">enable_error_info</a></span>(x) <<\
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_function</a></span>(<span class="RenoLink"><a href="configuration_macros.html">BOOST_THROW_EXCEPTION_CURRENT_FUNCTION</a></span>) <<\
|
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_file</a></span>(__FILE__) <<\
|
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_file</a></span>(__FILE__) <<\
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_line</a></span>((int)__LINE__) )
|
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_line</a></span>((int)__LINE__) )
|
||||||
#else
|
#else
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
<p>The cost is that boost::<span class="RenoLink"><a href="exception.html">exception</a></span> is added as a base of the exception emitted by boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> (unless the passed type already derives from boost::<span class="RenoLink"><a href="exception.html">exception</a></span>.)</p>
|
<p>The cost is that boost::<span class="RenoLink"><a href="exception.html">exception</a></span> is added as a base of the exception emitted by boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> (unless the passed type already derives from boost::<span class="RenoLink"><a href="exception.html">exception</a></span>.)</p>
|
||||||
<p>Calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> does not cause dynamic memory allocations.</p>
|
<p>Calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> does not cause dynamic memory allocations.</p>
|
||||||
<h3>What is the cost of BOOST_THROW_EXCEPTION?</h3>
|
<h3>What is the cost of BOOST_THROW_EXCEPTION?</h3>
|
||||||
<p>In addition to calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>, <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span> invokes __FILE__, __LINE__ and the <span class="RenoLink"><a href="configuration_macros.html">BOOST_THROW_EXCEPTION_CURRENT_FUNCTION</a></span> macros. The space required to store the information is already included in sizeof(boost::<span class="RenoLink"><a href="exception.html">exception</a></span>).</p>
|
<p>In addition to calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>, <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span> invokes __FILE__ and __LINE__ macros. The space required to store the information is already included in sizeof(boost::<span class="RenoLink"><a href="exception.html">exception</a></span>).</p>
|
||||||
<p>Calling <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span> does not cause dynamic memory allocations.</p>
|
<p>Calling <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span> does not cause dynamic memory allocations.</p>
|
||||||
<h3>Should I use boost::throw_exception or BOOST_THROW_EXCEPTION or just throw?</h3>
|
<h3>Should I use boost::throw_exception or BOOST_THROW_EXCEPTION or just throw?</h3>
|
||||||
<p>The benefit of calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> instead of using throw directly is that it ensures that the emitted exception derives from boost::<span class="RenoLink"><a href="exception.html">exception</a></span> and that it is compatible with boost::<span class="RenoLink"><a href="current_exception.html">current_exception</a></span>.</p>
|
<p>The benefit of calling boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span> instead of using throw directly is that it ensures that the emitted exception derives from boost::<span class="RenoLink"><a href="exception.html">exception</a></span> and that it is compatible with boost::<span class="RenoLink"><a href="current_exception.html">current_exception</a></span>.</p>
|
||||||
|
@ -158,7 +158,6 @@ boost
|
|||||||
#include <boost/current_function.hpp>
|
#include <boost/current_function.hpp>
|
||||||
#define <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span>(x)\
|
#define <span class="RenoLink"><a href="BOOST_THROW_EXCEPTION.html">BOOST_THROW_EXCEPTION</a></span>(x)\
|
||||||
::boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>( ::boost::<span class="RenoLink"><a href="enable_error_info.html">enable_error_info</a></span>(x) <<\
|
::boost::<span class="RenoLink"><a href="throw_exception.html">throw_exception</a></span>( ::boost::<span class="RenoLink"><a href="enable_error_info.html">enable_error_info</a></span>(x) <<\
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_function</a></span>(<span class="RenoLink"><a href="configuration_macros.html">BOOST_THROW_EXCEPTION_CURRENT_FUNCTION</a></span>) <<\
|
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_file</a></span>(__FILE__) <<\
|
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_file</a></span>(__FILE__) <<\
|
||||||
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_line</a></span>((int)__LINE__) )
|
::boost::<span class="RenoLink"><a href="boost_exception_exception_hpp.html">throw_line</a></span>((int)__LINE__) )
|
||||||
#else
|
#else
|
||||||
|
@ -5,11 +5,13 @@
|
|||||||
# Distributed under the Boost Software License, Version 1.0. (See accompanying
|
# Distributed under 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)
|
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
project : requirements <library>/boost/exception//boost_exception ;
|
||||||
|
|
||||||
exe example_io : example_io.cpp ;
|
exe example_io : example_io.cpp ;
|
||||||
obj error_info_1 : error_info_1.cpp ;
|
obj error_info_1 : error_info_1.cpp ;
|
||||||
obj error_info_2 : error_info_2.cpp ;
|
obj error_info_2 : error_info_2.cpp ;
|
||||||
obj cloning_1 : cloning_1.cpp ;
|
obj cloning_1 : cloning_1.cpp ;
|
||||||
obj cloning_2 : cloning_2.cpp : <threading>multi ;
|
obj cloning_2 : cloning_2.cpp /boost/thread//boost_thread : <threading>multi ;
|
||||||
obj info_tuple : info_tuple.cpp ;
|
obj info_tuple : info_tuple.cpp ;
|
||||||
obj enable_error_info : enable_error_info.cpp ;
|
obj enable_error_info : enable_error_info.cpp ;
|
||||||
obj logging : logging.cpp ;
|
obj logging : logging.cpp ;
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#define BOOST_EXCEPTION_7E83C166200811DE885E826156D89593
|
#define BOOST_EXCEPTION_7E83C166200811DE885E826156D89593
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#define BOOST_EXCEPTION_81522C0EB56511DFAB613DB0DFD72085
|
#define BOOST_EXCEPTION_81522C0EB56511DFAB613DB0DFD72085
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#ifndef BOOST_EXCEPTION_618474C2DE1511DEB74A388C56D89593
|
#ifndef BOOST_EXCEPTION_618474C2DE1511DEB74A388C56D89593
|
||||||
#define BOOST_EXCEPTION_618474C2DE1511DEB74A388C56D89593
|
#define BOOST_EXCEPTION_618474C2DE1511DEB74A388C56D89593
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
#include <boost/exception/detail/requires_cxx11.hpp>
|
||||||
#include <boost/exception/exception.hpp>
|
#include <boost/exception/exception.hpp>
|
||||||
#include <boost/exception/info.hpp>
|
#include <boost/exception/info.hpp>
|
||||||
#include <boost/exception/diagnostic_information.hpp>
|
#include <boost/exception/diagnostic_information.hpp>
|
||||||
@ -26,7 +26,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
@ -40,6 +40,36 @@
|
|||||||
namespace
|
namespace
|
||||||
boost
|
boost
|
||||||
{
|
{
|
||||||
|
namespace
|
||||||
|
exception_detail
|
||||||
|
{
|
||||||
|
#ifndef BOOST_NO_CXX11_HDR_EXCEPTION
|
||||||
|
struct
|
||||||
|
std_exception_ptr_wrapper:
|
||||||
|
std::exception
|
||||||
|
{
|
||||||
|
std::exception_ptr p;
|
||||||
|
explicit std_exception_ptr_wrapper( std::exception_ptr const & ptr ) BOOST_NOEXCEPT:
|
||||||
|
p(ptr)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
|
||||||
|
explicit std_exception_ptr_wrapper( std::exception_ptr && ptr ) BOOST_NOEXCEPT:
|
||||||
|
p(static_cast<std::exception_ptr &&>(ptr))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
shared_ptr<exception_detail::clone_base const>
|
||||||
|
inline
|
||||||
|
wrap_exception_ptr( std::exception_ptr const & e )
|
||||||
|
{
|
||||||
|
exception_detail::clone_base const & base = boost::enable_current_exception(std_exception_ptr_wrapper(e));
|
||||||
|
return shared_ptr<exception_detail::clone_base const>(base.clone());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
class exception_ptr;
|
class exception_ptr;
|
||||||
namespace exception_detail { void rethrow_exception_( exception_ptr const & ); }
|
namespace exception_detail { void rethrow_exception_( exception_ptr const & ); }
|
||||||
|
|
||||||
@ -54,6 +84,12 @@ boost
|
|||||||
exception_ptr()
|
exception_ptr()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
#ifndef BOOST_NO_CXX11_HDR_EXCEPTION
|
||||||
|
exception_ptr( std::exception_ptr const & e ):
|
||||||
|
ptr_(exception_detail::wrap_exception_ptr(e))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
#endif
|
||||||
explicit
|
explicit
|
||||||
exception_ptr( impl const & ptr ):
|
exception_ptr( impl const & ptr ):
|
||||||
ptr_(ptr)
|
ptr_(ptr)
|
||||||
@ -75,14 +111,24 @@ boost
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
namespace
|
||||||
|
exception_detail
|
||||||
|
{
|
||||||
|
template <class E>
|
||||||
|
inline
|
||||||
|
exception_ptr
|
||||||
|
copy_exception_impl( E const & e )
|
||||||
|
{
|
||||||
|
return exception_ptr(boost::make_shared<E>(e));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
template <class E>
|
template <class E>
|
||||||
inline
|
inline
|
||||||
exception_ptr
|
exception_ptr
|
||||||
copy_exception( E const & e )
|
copy_exception( E const & e )
|
||||||
{
|
{
|
||||||
E cp = e;
|
return exception_detail::copy_exception_impl(boost::enable_current_exception(e));
|
||||||
exception_detail::copy_boost_exception(&cp, &e);
|
|
||||||
return exception_ptr(boost::make_shared<wrapexcept<E> >(cp));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
@ -307,24 +353,6 @@ boost
|
|||||||
return boost::copy_exception(unknown_exception(e));
|
return boost::copy_exception(unknown_exception(e));
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef BOOST_NO_CXX11_HDR_EXCEPTION
|
|
||||||
struct
|
|
||||||
std_exception_ptr_wrapper
|
|
||||||
{
|
|
||||||
std::exception_ptr p;
|
|
||||||
explicit std_exception_ptr_wrapper( std::exception_ptr const & ptr ) BOOST_NOEXCEPT:
|
|
||||||
p(ptr)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
|
|
||||||
explicit std_exception_ptr_wrapper( std::exception_ptr && ptr ) BOOST_NOEXCEPT:
|
|
||||||
p(static_cast<std::exception_ptr &&>(ptr))
|
|
||||||
{
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
inline
|
inline
|
||||||
exception_ptr
|
exception_ptr
|
||||||
current_exception_impl()
|
current_exception_impl()
|
||||||
@ -366,6 +394,9 @@ boost
|
|||||||
{
|
{
|
||||||
return exception_ptr(shared_ptr<exception_detail::clone_base const>(e.clone()));
|
return exception_ptr(shared_ptr<exception_detail::clone_base const>(e.clone()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef BOOST_NO_CXX11_HDR_EXCEPTION
|
||||||
|
|
||||||
catch(
|
catch(
|
||||||
std::domain_error & e )
|
std::domain_error & e )
|
||||||
{
|
{
|
||||||
@ -438,29 +469,26 @@ boost
|
|||||||
{
|
{
|
||||||
return exception_detail::current_exception_std_exception(e);
|
return exception_detail::current_exception_std_exception(e);
|
||||||
}
|
}
|
||||||
#ifdef BOOST_NO_CXX11_HDR_EXCEPTION
|
|
||||||
// this case can be handled losslesly with std::current_exception() (see below)
|
|
||||||
catch(
|
catch(
|
||||||
std::exception & e )
|
std::exception & e )
|
||||||
{
|
{
|
||||||
return exception_detail::current_exception_unknown_std_exception(e);
|
return exception_detail::current_exception_unknown_std_exception(e);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
catch(
|
catch(
|
||||||
boost::exception & e )
|
boost::exception & e )
|
||||||
{
|
{
|
||||||
return exception_detail::current_exception_unknown_boost_exception(e);
|
return exception_detail::current_exception_unknown_boost_exception(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif // #ifdef BOOST_NO_CXX11_HDR_EXCEPTION
|
||||||
|
|
||||||
catch(
|
catch(
|
||||||
... )
|
... )
|
||||||
{
|
{
|
||||||
#ifndef BOOST_NO_CXX11_HDR_EXCEPTION
|
#ifndef BOOST_NO_CXX11_HDR_EXCEPTION
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// wrap the std::exception_ptr in a clone-enabled Boost.Exception object
|
return exception_ptr(std::current_exception());
|
||||||
exception_detail::clone_base const & base =
|
|
||||||
boost::enable_current_exception(std_exception_ptr_wrapper(std::current_exception()));
|
|
||||||
return exception_ptr(shared_ptr<exception_detail::clone_base const>(base.clone()));
|
|
||||||
}
|
}
|
||||||
catch(
|
catch(
|
||||||
...)
|
...)
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
#include <ostream>
|
#include <ostream>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
24
include/boost/exception/detail/requires_cxx11.hpp
Normal file
24
include/boost/exception/detail/requires_cxx11.hpp
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
#ifndef BOOST_EXCEPTION_DETAIL_REQUIRES_CXX11_HPP_INCLUDED
|
||||||
|
#define BOOST_EXCEPTION_DETAIL_REQUIRES_CXX11_HPP_INCLUDED
|
||||||
|
|
||||||
|
// Copyright 2023 Peter Dimov
|
||||||
|
// Copyright 2024 Emil Dotchevski
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/config.hpp>
|
||||||
|
#include <boost/config/pragma_message.hpp>
|
||||||
|
|
||||||
|
#if defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES) || \
|
||||||
|
defined(BOOST_NO_CXX11_RVALUE_REFERENCES) || \
|
||||||
|
defined(BOOST_NO_CXX11_DECLTYPE) || \
|
||||||
|
defined(BOOST_NO_CXX11_CONSTEXPR) || \
|
||||||
|
defined(BOOST_NO_CXX11_NOEXCEPT) || \
|
||||||
|
defined(BOOST_NO_CXX11_NULLPTR) || \
|
||||||
|
defined(BOOST_NO_CXX11_SMART_PTR)
|
||||||
|
|
||||||
|
BOOST_PRAGMA_MESSAGE("C++03 support was deprecated in Boost.Exception 1.85 and will be removed in Boost.Exception 1.87.")
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
@ -14,7 +14,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
#include <boost/exception/get_error_info.hpp>
|
#include <boost/exception/get_error_info.hpp>
|
||||||
#include <boost/exception/info.hpp>
|
#include <boost/exception/info.hpp>
|
||||||
#include <boost/utility/enable_if.hpp>
|
#include <boost/core/enable_if.hpp>
|
||||||
#ifndef BOOST_NO_RTTI
|
#ifndef BOOST_NO_RTTI
|
||||||
#include <boost/core/demangle.hpp>
|
#include <boost/core/demangle.hpp>
|
||||||
#endif
|
#endif
|
||||||
@ -21,7 +21,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
@ -149,11 +149,11 @@ boost
|
|||||||
if( f )
|
if( f )
|
||||||
{
|
{
|
||||||
tmp << *f;
|
tmp << *f;
|
||||||
if( int const * l=get_error_info<throw_line>(*be) )
|
if( l )
|
||||||
tmp << '(' << *l << "): ";
|
tmp << '(' << *l << "): ";
|
||||||
}
|
}
|
||||||
tmp << "Throw in function ";
|
tmp << "Throw in function ";
|
||||||
if( char const * const * fn=get_error_info<throw_function>(*be) )
|
if( fn )
|
||||||
tmp << *fn;
|
tmp << *fn;
|
||||||
else
|
else
|
||||||
tmp << "(unknown)";
|
tmp << "(unknown)";
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
@ -31,7 +31,7 @@ boost
|
|||||||
template <class Tag,class T>
|
template <class Tag,class T>
|
||||||
inline
|
inline
|
||||||
std::string
|
std::string
|
||||||
error_info_name( error_info<Tag,T> const & x )
|
error_info_name( error_info<Tag,T> const & )
|
||||||
{
|
{
|
||||||
return tag_type_name<Tag>();
|
return tag_type_name<Tag>();
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
#include <boost/tuple/tuple.hpp>
|
#include <boost/tuple/tuple.hpp>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -6,12 +6,12 @@
|
|||||||
#ifndef BOOST_EXCEPTION_7E48761AD92811DC9011477D56D89593
|
#ifndef BOOST_EXCEPTION_7E48761AD92811DC9011477D56D89593
|
||||||
#define BOOST_EXCEPTION_7E48761AD92811DC9011477D56D89593
|
#define BOOST_EXCEPTION_7E48761AD92811DC9011477D56D89593
|
||||||
|
|
||||||
#include <boost/utility/enable_if.hpp>
|
#include <boost/core/enable_if.hpp>
|
||||||
#include <boost/exception/detail/is_output_streamable.hpp>
|
#include <boost/exception/detail/is_output_streamable.hpp>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
|
|
||||||
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
#ifndef BOOST_EXCEPTION_ENABLE_WARNINGS
|
||||||
#if __GNUC__*100+__GNUC_MINOR__>301
|
#if defined(__GNUC__) && __GNUC__*100+__GNUC_MINOR__>301
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
"description": "The Boost Exception library supports transporting of arbitrary data in exception objects, and transporting of exceptions between threads.",
|
"description": "The Boost Exception library supports transporting of arbitrary data in exception objects, and transporting of exceptions between threads.",
|
||||||
"documentation": "doc/boost-exception.html",
|
"documentation": "doc/boost-exception.html",
|
||||||
"category": [
|
"category": [
|
||||||
|
"Error-handling",
|
||||||
"Emulation"
|
"Emulation"
|
||||||
],
|
],
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
|
|
||||||
import testing ;
|
import testing ;
|
||||||
|
|
||||||
|
project : requirements <library>/boost/exception//boost_exception ;
|
||||||
|
|
||||||
#to_string
|
#to_string
|
||||||
|
|
||||||
run is_output_streamable_test.cpp ;
|
run is_output_streamable_test.cpp ;
|
||||||
@ -22,7 +24,7 @@ run 2-throw_exception_no_exceptions_test.cpp : : : <exception-handling>off ;
|
|||||||
run 3-throw_exception_no_integration_test.cpp : : : <exception-handling>on ;
|
run 3-throw_exception_no_integration_test.cpp : : : <exception-handling>on ;
|
||||||
run 4-throw_exception_no_both_test.cpp : : : <exception-handling>off ;
|
run 4-throw_exception_no_both_test.cpp : : : <exception-handling>off ;
|
||||||
run cloning_test.cpp : : : <exception-handling>on ;
|
run cloning_test.cpp : : : <exception-handling>on ;
|
||||||
run copy_exception_test.cpp ../../thread/src/tss_null.cpp /boost//thread : : : <threading>multi <exception-handling>on ;
|
run copy_exception_test.cpp ../../thread/src/tss_null.cpp /boost/thread//boost_thread : : : <threading>multi <exception-handling>on ;
|
||||||
run copy_exception_no_exceptions_test.cpp : : : <exception-handling>off <rtti>on ;
|
run copy_exception_no_exceptions_test.cpp : : : <exception-handling>off <rtti>on ;
|
||||||
run unknown_exception_test.cpp : : : <exception-handling>on ;
|
run unknown_exception_test.cpp : : : <exception-handling>on ;
|
||||||
run exception_test.cpp : : : <exception-handling>on ;
|
run exception_test.cpp : : : <exception-handling>on ;
|
||||||
@ -39,8 +41,9 @@ run refcount_ptr_test.cpp ;
|
|||||||
run current_exception_cast_test.cpp : : : <exception-handling>on ;
|
run current_exception_cast_test.cpp : : : <exception-handling>on ;
|
||||||
run no_exceptions_test.cpp : : : <exception-handling>off ;
|
run no_exceptions_test.cpp : : : <exception-handling>off ;
|
||||||
run errinfos_test.cpp : : : <exception-handling>on ;
|
run errinfos_test.cpp : : : <exception-handling>on ;
|
||||||
run exception_ptr_test.cpp/<define>BOOST_ENABLE_NON_INTRUSIVE_EXCEPTION_PTR ../../thread/src/tss_null.cpp /boost/exception /boost//thread : : : <threading>multi <exception-handling>on : non_intrusive_exception_ptr_test ;
|
run exception_ptr_test.cpp/<define>BOOST_ENABLE_NON_INTRUSIVE_EXCEPTION_PTR ../../thread/src/tss_null.cpp /boost/exception//boost_exception /boost/thread//boost_thread : : : <threading>multi <exception-handling>on : non_intrusive_exception_ptr_test ;
|
||||||
run exception_ptr_test.cpp ../../thread/src/tss_null.cpp /boost//thread : : : <threading>multi <exception-handling>on ;
|
run exception_ptr_test.cpp ../../thread/src/tss_null.cpp /boost/thread//boost_thread : : : <threading>multi <exception-handling>on ;
|
||||||
|
run exception_ptr_test2.cpp ;
|
||||||
|
|
||||||
lib visibility_test_lib : visibility_test_lib.cpp : <visibility>hidden <exception-handling>on ;
|
lib visibility_test_lib : visibility_test_lib.cpp : <visibility>hidden <exception-handling>on ;
|
||||||
run visibility_test.cpp visibility_test_lib/<link>shared : : : <visibility>hidden <exception-handling>on ;
|
run visibility_test.cpp visibility_test_lib/<link>shared : : : <visibility>hidden <exception-handling>on ;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include <boost/exception_ptr.hpp>
|
#include <boost/exception_ptr.hpp>
|
||||||
#include <boost/exception/get_error_info.hpp>
|
#include <boost/exception/get_error_info.hpp>
|
||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <boost/detail/atomic_count.hpp>
|
#include <boost/smart_ptr/detail/atomic_count.hpp>
|
||||||
#include <boost/detail/lightweight_test.hpp>
|
#include <boost/detail/lightweight_test.hpp>
|
||||||
|
|
||||||
typedef boost::error_info<struct tag_answer,int> answer;
|
typedef boost::error_info<struct tag_answer,int> answer;
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <boost/detail/atomic_count.hpp>
|
#include <boost/smart_ptr/detail/atomic_count.hpp>
|
||||||
#include <boost/detail/lightweight_test.hpp>
|
#include <boost/detail/lightweight_test.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
|
114
test/exception_ptr_test2.cpp
Normal file
114
test/exception_ptr_test2.cpp
Normal file
@ -0,0 +1,114 @@
|
|||||||
|
// Copyright 2022 Peter Dimov
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/config.hpp>
|
||||||
|
|
||||||
|
#if defined(BOOST_NO_EXCEPTIONS)
|
||||||
|
|
||||||
|
#include <boost/config/pragma_message.hpp>
|
||||||
|
BOOST_PRAGMA_MESSAGE( "Skipping test because BOOST_NO_EXCEPTIONS is defined" )
|
||||||
|
|
||||||
|
int main() {}
|
||||||
|
|
||||||
|
#elif defined(BOOST_NO_CXX11_HDR_EXCEPTION)
|
||||||
|
|
||||||
|
#include <boost/config/pragma_message.hpp>
|
||||||
|
BOOST_PRAGMA_MESSAGE( "Skipping test because BOOST_NO_CXX11_HDR_EXCEPTION is defined" )
|
||||||
|
|
||||||
|
int main() {}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#include <boost/exception_ptr.hpp>
|
||||||
|
#include <boost/exception/exception.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
#include <exception>
|
||||||
|
#include <new>
|
||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
class my_exception
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
class my_exception2: public std::exception
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
class my_exception3: public std::bad_alloc
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
class my_exception4: public std::exception, public boost::exception
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
class my_exception5: public std::logic_error, public virtual boost::exception
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
my_exception5(): std::logic_error( "" ) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
throw my_exception();
|
||||||
|
}
|
||||||
|
catch( ... )
|
||||||
|
{
|
||||||
|
boost::exception_ptr p = boost::current_exception();
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), my_exception );
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
throw my_exception2();
|
||||||
|
}
|
||||||
|
catch( ... )
|
||||||
|
{
|
||||||
|
boost::exception_ptr p = boost::current_exception();
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), my_exception2 );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), std::exception );
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
throw my_exception3();
|
||||||
|
}
|
||||||
|
catch( ... )
|
||||||
|
{
|
||||||
|
boost::exception_ptr p = boost::current_exception();
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), my_exception3 );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), std::bad_alloc );
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
throw my_exception4();
|
||||||
|
}
|
||||||
|
catch( ... )
|
||||||
|
{
|
||||||
|
boost::exception_ptr p = boost::current_exception();
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), my_exception4 );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), std::exception );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), boost::exception );
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
throw my_exception5();
|
||||||
|
}
|
||||||
|
catch( ... )
|
||||||
|
{
|
||||||
|
boost::exception_ptr p = boost::current_exception();
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), my_exception5 );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), std::logic_error );
|
||||||
|
BOOST_TEST_THROWS( boost::rethrow_exception( p ), boost::exception );
|
||||||
|
}
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Reference in New Issue
Block a user