mirror of
https://github.com/boostorg/stacktrace.git
synced 2026-01-29 08:02:09 +00:00
Compare commits
29 Commits
boost-1.85
...
feature/bo
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6624a0aaeb | ||
|
|
ca76415503 | ||
|
|
4352901d19 | ||
|
|
2820ed36b5 | ||
|
|
1a389747a3 | ||
|
|
1db160d566 | ||
|
|
1b16c5d6ae | ||
|
|
274aeaa351 | ||
|
|
a615135de0 | ||
|
|
32749a7041 | ||
|
|
08d4f46333 | ||
|
|
97bc049bcb | ||
|
|
98ed11d235 | ||
|
|
f1c5cd8963 | ||
|
|
94f11c52eb | ||
|
|
f6f3623594 | ||
|
|
aad95c2667 | ||
|
|
a95e7e5860 | ||
|
|
8b79199a2a | ||
|
|
6e39a41abf | ||
|
|
5747f85c0b | ||
|
|
c093aef138 | ||
|
|
66c0f7a54f | ||
|
|
aacfc2e557 | ||
|
|
80af3a44c3 | ||
|
|
69260779d1 | ||
|
|
2c83563695 | ||
|
|
39afcefb64 | ||
|
|
d1b7a61353 |
339
.github/workflows/ci.yml
vendored
339
.github/workflows/ci.yml
vendored
@@ -40,7 +40,7 @@ jobs:
|
|||||||
runs-on: ${{matrix.os}}
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install packages
|
- name: Install packages
|
||||||
if: matrix.install
|
if: matrix.install
|
||||||
@@ -126,7 +126,7 @@ jobs:
|
|||||||
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
|
||||||
@@ -165,3 +165,338 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
github-token: ${{ secrets.github_token }}
|
github-token: ${{ secrets.github_token }}
|
||||||
parallel-finished: true
|
parallel-finished: true
|
||||||
|
|
||||||
|
posix-cmake-subdir:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ ubuntu-20.04, ubuntu-22.04, macos-12, macos-13, macos-14 ]
|
||||||
|
shared: [ ON ] # https://github.com/boostorg/stacktrace/issues/169
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install packages
|
||||||
|
if: matrix.install
|
||||||
|
run: sudo apt-get -y install ${{matrix.install}}
|
||||||
|
|
||||||
|
- 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
|
||||||
|
cd ..
|
||||||
|
git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY
|
||||||
|
|
||||||
|
- name: Use library with add_subdirectory
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/$LIBRARY/test/cmake_subdir_test
|
||||||
|
mkdir __build__ && cd __build__
|
||||||
|
cmake -DBUILD_SHARED_LIBS=${{matrix.shared}} ..
|
||||||
|
cmake --build .
|
||||||
|
ctest --output-on-failure --no-tests=error
|
||||||
|
|
||||||
|
posix-cmake-install:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ ubuntu-20.04, ubuntu-22.04, macos-12, macos-13, macos-14 ]
|
||||||
|
shared: [ ON ] # https://github.com/boostorg/stacktrace/issues/169
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install packages
|
||||||
|
if: matrix.install
|
||||||
|
run: sudo apt-get -y install ${{matrix.install}}
|
||||||
|
|
||||||
|
- 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
|
||||||
|
cd ..
|
||||||
|
git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY
|
||||||
|
|
||||||
|
- name: Configure
|
||||||
|
run: |
|
||||||
|
cd ../boost-root
|
||||||
|
mkdir __build__ && cd __build__
|
||||||
|
cmake -DBOOST_INCLUDE_LIBRARIES=$LIBRARY -DCMAKE_INSTALL_PREFIX=~/.local -DBUILD_SHARED_LIBS=${{matrix.shared}} ..
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build .
|
||||||
|
|
||||||
|
- name: Install
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build . --target install
|
||||||
|
|
||||||
|
- name: Use the installed library
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/$LIBRARY/test/cmake_install_test && mkdir __build__ && cd __build__
|
||||||
|
cmake -DCMAKE_INSTALL_PREFIX=~/.local ..
|
||||||
|
cmake --build .
|
||||||
|
export LD_LIBRARY_PATH=$HOME/.local/lib:$LD_LIBRARY_PATH
|
||||||
|
ctest --output-on-failure --no-tests=error
|
||||||
|
|
||||||
|
posix-cmake-test:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ ubuntu-20.04, ubuntu-22.04, macos-12, macos-13, macos-14 ]
|
||||||
|
shared: [ ON ] # https://github.com/boostorg/stacktrace/issues/169
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install packages
|
||||||
|
if: matrix.install
|
||||||
|
run: sudo apt-get -y install ${{matrix.install}}
|
||||||
|
|
||||||
|
- 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
|
||||||
|
cd ..
|
||||||
|
git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY
|
||||||
|
|
||||||
|
- name: Configure (Debug)
|
||||||
|
run: |
|
||||||
|
cd ../boost-root
|
||||||
|
mkdir __build_debug__ && cd __build_debug__
|
||||||
|
cmake -DBOOST_INCLUDE_LIBRARIES=$LIBRARY -DBUILD_TESTING=ON -DBUILD_SHARED_LIBS=${{matrix.shared}} -DCMAKE_BUILD_TYPE=Debug ..
|
||||||
|
|
||||||
|
- name: Build tests (Debug)
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build_debug__
|
||||||
|
cmake --build . --target tests
|
||||||
|
|
||||||
|
- name: Run tests (Debug)
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build_debug__
|
||||||
|
ctest --output-on-failure --no-tests=error
|
||||||
|
|
||||||
|
windows-cmake-subdir:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ windows-2019, windows-2022 ]
|
||||||
|
shared: [ OFF, ON ]
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- 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%
|
||||||
|
cd ..
|
||||||
|
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY%
|
||||||
|
|
||||||
|
- name: Use library with add_subdirectory (Debug)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/%LIBRARY%/test/cmake_subdir_test
|
||||||
|
mkdir __build__ && cd __build__
|
||||||
|
cmake -DBUILD_SHARED_LIBS=${{matrix.shared}} ..
|
||||||
|
cmake --build . --config Debug
|
||||||
|
ctest --output-on-failure --no-tests=error -C Debug
|
||||||
|
|
||||||
|
- name: Use library with add_subdirectory (RelWithDebInfo)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/%LIBRARY%/test/cmake_subdir_test/__build__
|
||||||
|
cmake --build . --config RelWithDebInfo
|
||||||
|
ctest --output-on-failure --no-tests=error -C RelWithDebInfo
|
||||||
|
|
||||||
|
windows-cmake-install:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ windows-2019, windows-2022 ]
|
||||||
|
shared: [ OFF, ON ]
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- 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%
|
||||||
|
cd ..
|
||||||
|
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY%
|
||||||
|
|
||||||
|
- name: Configure
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root
|
||||||
|
mkdir __build__ && cd __build__
|
||||||
|
cmake -DBOOST_INCLUDE_LIBRARIES=%LIBRARY% -DCMAKE_INSTALL_PREFIX=C:/cmake-prefix -DBUILD_SHARED_LIBS=${{matrix.shared}} ..
|
||||||
|
|
||||||
|
- name: Install (Debug)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build . --target install --config Debug
|
||||||
|
|
||||||
|
- name: Install (RelWithDebInfo)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build . --target install --config RelWithDebInfo
|
||||||
|
|
||||||
|
- name: Use the installed library (Debug)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/%LIBRARY%/test/cmake_install_test && mkdir __build__ && cd __build__
|
||||||
|
cmake -DCMAKE_INSTALL_PREFIX=C:/cmake-prefix ..
|
||||||
|
cmake --build . --config Debug
|
||||||
|
PATH C:\cmake-prefix\bin;%PATH%
|
||||||
|
ctest --output-on-failure --no-tests=error -C Debug
|
||||||
|
|
||||||
|
- name: Use the installed library (RelWithDebInfo)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/libs/%LIBRARY%/test/cmake_install_test/__build__
|
||||||
|
cmake --build . --config RelWithDebInfo
|
||||||
|
PATH C:\cmake-prefix\bin;%PATH%
|
||||||
|
ctest --output-on-failure --no-tests=error -C RelWithDebInfo
|
||||||
|
|
||||||
|
windows-cmake-test:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [ windows-2019, windows-2022 ]
|
||||||
|
shared: [ ON ] # https://github.com/boostorg/stacktrace/issues/169
|
||||||
|
|
||||||
|
runs-on: ${{matrix.os}}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- 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%
|
||||||
|
cd ..
|
||||||
|
git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
cd boost-root
|
||||||
|
xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\
|
||||||
|
git submodule update --init tools/boostdep
|
||||||
|
python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY%
|
||||||
|
|
||||||
|
- name: Configure
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root
|
||||||
|
mkdir __build__ && cd __build__
|
||||||
|
cmake -DBOOST_INCLUDE_LIBRARIES=%LIBRARY% -DBUILD_TESTING=ON -DBUILD_SHARED_LIBS=${{matrix.shared}} ..
|
||||||
|
|
||||||
|
- name: Build tests (Debug)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build . --target tests --config Debug
|
||||||
|
|
||||||
|
- name: Run tests (Debug)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
ctest --output-on-failure --no-tests=error -C Debug
|
||||||
|
|
||||||
|
- name: Build tests (RelWithDebInfo)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
cmake --build . --target tests --config RelWithDebInfo
|
||||||
|
|
||||||
|
- name: Run tests (RelWithDebInfo)
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
cd ../boost-root/__build__
|
||||||
|
ctest --output-on-failure --no-tests=error -C RelWithDebInfo
|
||||||
|
|||||||
@@ -90,12 +90,43 @@ message(STATUS "Boost.Stacktrace: "
|
|||||||
)
|
)
|
||||||
|
|
||||||
stacktrace_add_library(noop ${BOOST_STACKTRACE_ENABLE_NOOP} "" "")
|
stacktrace_add_library(noop ${BOOST_STACKTRACE_ENABLE_NOOP} "" "")
|
||||||
stacktrace_add_library(backtrace ${BOOST_STACKTRACE_ENABLE_BACKTRACE} "backtrace" "")
|
stacktrace_add_library(backtrace ${BOOST_STACKTRACE_ENABLE_BACKTRACE} "backtrace;${CMAKE_DL_LIBS}" "")
|
||||||
stacktrace_add_library(addr2line ${BOOST_STACKTRACE_ENABLE_ADDR2LINE} "" "")
|
stacktrace_add_library(addr2line ${BOOST_STACKTRACE_ENABLE_ADDR2LINE} "${CMAKE_DL_LIBS}" "")
|
||||||
stacktrace_add_library(basic ${BOOST_STACKTRACE_ENABLE_BASIC} "" "")
|
stacktrace_add_library(basic ${BOOST_STACKTRACE_ENABLE_BASIC} "${CMAKE_DL_LIBS}" "")
|
||||||
stacktrace_add_library(windbg ${BOOST_STACKTRACE_ENABLE_WINDBG} "dbgeng;ole32" "_GNU_SOURCE=1")
|
stacktrace_add_library(windbg ${BOOST_STACKTRACE_ENABLE_WINDBG} "dbgeng;ole32" "_GNU_SOURCE=1")
|
||||||
stacktrace_add_library(windbg_cached ${BOOST_STACKTRACE_ENABLE_WINDBG_CACHED} "dbgeng;ole32" "_GNU_SOURCE=1")
|
stacktrace_add_library(windbg_cached ${BOOST_STACKTRACE_ENABLE_WINDBG_CACHED} "dbgeng;ole32" "_GNU_SOURCE=1")
|
||||||
|
|
||||||
|
# boost_stacktrace, default library
|
||||||
|
|
||||||
|
add_library(boost_stacktrace INTERFACE)
|
||||||
|
add_library(Boost::stacktrace ALIAS boost_stacktrace)
|
||||||
|
|
||||||
|
target_include_directories(boost_stacktrace INTERFACE include)
|
||||||
|
|
||||||
|
if(BOOST_STACKTRACE_ENABLE_WINDBG)
|
||||||
|
|
||||||
|
target_link_libraries(boost_stacktrace INTERFACE Boost::stacktrace_windbg)
|
||||||
|
|
||||||
|
elseif(BOOST_STACKTRACE_ENABLE_BACKTRACE)
|
||||||
|
|
||||||
|
target_link_libraries(boost_stacktrace INTERFACE Boost::stacktrace_backtrace)
|
||||||
|
|
||||||
|
elseif(BOOST_STACKTRACE_ENABLE_ADDR2LINE)
|
||||||
|
|
||||||
|
target_link_libraries(boost_stacktrace INTERFACE Boost::stacktrace_addr2line)
|
||||||
|
|
||||||
|
elseif(BOOST_STACKTRACE_ENABLE_BASIC)
|
||||||
|
|
||||||
|
target_link_libraries(boost_stacktrace INTERFACE Boost::stacktrace_basic)
|
||||||
|
|
||||||
|
elseif(BOOST_STACKTRACE_ENABLE_NOOP)
|
||||||
|
|
||||||
|
target_link_libraries(boost_stacktrace INTERFACE Boost::stacktrace_noop)
|
||||||
|
|
||||||
|
endif()
|
||||||
|
|
||||||
|
#
|
||||||
|
|
||||||
if(BUILD_TESTING AND EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/test/CMakeLists.txt")
|
if(BUILD_TESTING AND EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/test/CMakeLists.txt")
|
||||||
|
|
||||||
add_subdirectory(test)
|
add_subdirectory(test)
|
||||||
|
|||||||
@@ -6,6 +6,7 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
import feature ;
|
import feature ;
|
||||||
|
import property ;
|
||||||
import ../../config/checks/config : requires ;
|
import ../../config/checks/config : requires ;
|
||||||
|
|
||||||
project
|
project
|
||||||
@@ -134,19 +135,34 @@ lib boost_stacktrace_windbg_cached
|
|||||||
#<link>shared:<define>BOOST_STACKTRACE_DYN_LINK=1
|
#<link>shared:<define>BOOST_STACKTRACE_DYN_LINK=1
|
||||||
;
|
;
|
||||||
|
|
||||||
|
rule build-stacktrace-from-exception ( props * )
|
||||||
|
{
|
||||||
|
local enabled = [ property.select <boost.stacktrace.from_exception> : $(props) ] ;
|
||||||
|
switch $(enabled:G=)
|
||||||
|
{
|
||||||
|
case "on" : return ;
|
||||||
|
case "off" : return <build>no ;
|
||||||
|
}
|
||||||
|
|
||||||
|
local arch = [ property.select <architecture> : $(props) ] ;
|
||||||
|
if $(arch) && ( $(arch:G=) != x86 )
|
||||||
|
{
|
||||||
|
return <build>no ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
lib boost_stacktrace_from_exception
|
lib boost_stacktrace_from_exception
|
||||||
: # sources
|
: # sources
|
||||||
../src/from_exception.cpp
|
../src/from_exception.cpp
|
||||||
: # requirements
|
: # requirements
|
||||||
<warnings>all
|
<warnings>all
|
||||||
<target-os>linux:<library>dl
|
<target-os>linux:<library>dl
|
||||||
<target-os>windows:<build>no # not supported at the moment
|
|
||||||
|
|
||||||
# Command line option to disable build
|
# Enable build when explicitly requested, or by default, when on x86
|
||||||
<boost.stacktrace.from_exception>off:<build>no
|
<conditional>@build-stacktrace-from-exception
|
||||||
|
|
||||||
# Require usable libbacktrace on other platforms
|
# Require usable libbacktrace on other platforms
|
||||||
[ check-target-builds ../build//libbacktrace : : <build>no ]
|
#[ check-target-builds ../build//libbacktrace : : <build>no ]
|
||||||
: # default build
|
: # default build
|
||||||
: # usage-requirements
|
: # usage-requirements
|
||||||
#<link>shared:<define>BOOST_STACKTRACE_DYN_LINK=1
|
#<link>shared:<define>BOOST_STACKTRACE_DYN_LINK=1
|
||||||
|
|||||||
@@ -137,7 +137,7 @@ See [link stacktrace.theoretical_async_signal_safety "Theoretical async signal s
|
|||||||
[section Stacktrace from arbitrary exception]
|
[section Stacktrace from arbitrary exception]
|
||||||
|
|
||||||
[warning At the moment the functionality is only available for some of the
|
[warning At the moment the functionality is only available for some of the
|
||||||
popular C++ runtimes for POSIX systems and requires *libbacktrace*.
|
popular C++ runtimes for POSIX systems with *libbacktrace* and for Windows.
|
||||||
Make sure that your platform is supported by running some tests.
|
Make sure that your platform is supported by running some tests.
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -18,7 +18,17 @@
|
|||||||
#include <boost/core/noncopyable.hpp>
|
#include <boost/core/noncopyable.hpp>
|
||||||
#include <boost/stacktrace/detail/to_dec_array.hpp>
|
#include <boost/stacktrace/detail/to_dec_array.hpp>
|
||||||
#include <boost/stacktrace/detail/to_hex_array.hpp>
|
#include <boost/stacktrace/detail/to_hex_array.hpp>
|
||||||
|
|
||||||
|
#ifdef WIN32_LEAN_AND_MEAN
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
#else
|
||||||
|
// Prevent inclusion of extra Windows SDK headers which can cause conflict
|
||||||
|
// with other code using Windows SDK
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
#undef WIN32_LEAN_AND_MEAN
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "dbgeng.h"
|
#include "dbgeng.h"
|
||||||
|
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
|||||||
@@ -90,8 +90,8 @@ std::string frame::name() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(BOOST_WINDOWS) && !defined(__CYGWIN__)
|
#if !defined(BOOST_WINDOWS) && !defined(__CYGWIN__)
|
||||||
::Dl_info dli;
|
boost::stacktrace::detail::Dl_info dli;
|
||||||
const bool dl_ok = !!::dladdr(const_cast<void*>(addr_), &dli); // `dladdr` on Solaris accepts nonconst addresses
|
const bool dl_ok = !!boost::stacktrace::detail::dladdr(addr_, dli);
|
||||||
if (dl_ok && dli.dli_sname) {
|
if (dl_ok && dli.dli_sname) {
|
||||||
return boost::core::demangle(dli.dli_sname);
|
return boost::core::demangle(dli.dli_sname);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,17 +18,110 @@
|
|||||||
# include <boost/winapi/dll.hpp>
|
# include <boost/winapi/dll.hpp>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef _AIX
|
||||||
|
/* AIX doesn't provide dladdr syscall.
|
||||||
|
This provides a minimal implementation of dladdr which retrieves
|
||||||
|
only files information.
|
||||||
|
TODO: Implement the symbol name. */
|
||||||
|
|
||||||
|
#include <sys/ldr.h>
|
||||||
|
#include <sys/debug.h>
|
||||||
|
#include <cstring>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace boost { namespace stacktrace { namespace detail {
|
||||||
|
|
||||||
|
struct Dl_info {
|
||||||
|
std::string fname_storage{};
|
||||||
|
const char *dli_fname = nullptr;
|
||||||
|
const char *dli_sname = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
int dladdr(const void* address_raw, Dl_info* info) noexcept {
|
||||||
|
static constexpr std::size_t dl_buff_size = 0x1000;
|
||||||
|
|
||||||
|
try {
|
||||||
|
std::vector<struct ld_info> pld_info_storage;
|
||||||
|
pld_info_storage.resize(
|
||||||
|
(dl_buff_size + sizeof(struct ld_info) - 1) / sizeof(struct ld_info)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (loadquery(L_GETINFO, pld_info_storage.data(), dl_buff_size) == -1) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto* pld_info = pld_info_storage.data();
|
||||||
|
const char* const address = static_cast<const char*>(address_raw);
|
||||||
|
while (true) {
|
||||||
|
const auto* const dataorg = static_cast<char*>(pld_info->ldinfo_dataorg);
|
||||||
|
const auto* const textorg = static_cast<char*>(pld_info->ldinfo_textorg);
|
||||||
|
if ((address >= dataorg && address < dataorg + pld_info->ldinfo_datasize )
|
||||||
|
|| (address >= textorg && address < textorg + pld_info->ldinfo_textsize )) {
|
||||||
|
|
||||||
|
/* ldinfo_filename is the null-terminated path name followed
|
||||||
|
by null-terminated member name.
|
||||||
|
If the file is not an archive, then member name is null. */
|
||||||
|
const auto size_filename = std::strlen(pld_info->ldinfo_filename);
|
||||||
|
const auto size_member = std::strlen(pld_info->ldinfo_filename + size_filename + 1);
|
||||||
|
|
||||||
|
/* If member is not null, '(' and ')' must be added to create a
|
||||||
|
fname looking like "filename(membername)". */
|
||||||
|
info->fname_storage.reserve(size_filename + (size_member ? size_member + 3 : 1));
|
||||||
|
info->fname_storage = pld_info->ldinfo_filename;
|
||||||
|
if (size_member) {
|
||||||
|
info->fname_storage += "(";
|
||||||
|
info->fname_storage += pld_info->ldinfo_filename + size_filename + 1;
|
||||||
|
info->fname_storage += ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
info->dli_fname = info->fname_storage.c_str();
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!pld_info->ldinfo_next) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pld_info = reinterpret_cast<const struct ld_info *>(
|
||||||
|
reinterpret_cast<const char*>(pld_info) + pld_info->ldinfo_next
|
||||||
|
);
|
||||||
|
};
|
||||||
|
} catch (...) {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}}} // namespace boost::stacktrace::detail
|
||||||
|
|
||||||
|
#elif !defined(BOOST_WINDOWS) && !defined(__CYGWIN__)
|
||||||
|
|
||||||
|
namespace boost { namespace stacktrace { namespace detail {
|
||||||
|
|
||||||
|
using Dl_info = ::Dl_info;
|
||||||
|
|
||||||
|
inline int dladdr(const void* addr, Dl_info& dli) noexcept {
|
||||||
|
// `dladdr` on Solaris accepts nonconst addresses
|
||||||
|
return ::dladdr(const_cast<void*>(addr), &dli);
|
||||||
|
}
|
||||||
|
|
||||||
|
}}} // namespace boost::stacktrace::detail
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace boost { namespace stacktrace { namespace detail {
|
namespace boost { namespace stacktrace { namespace detail {
|
||||||
|
|
||||||
#if !defined(BOOST_WINDOWS) && !defined(__CYGWIN__)
|
#if !defined(BOOST_WINDOWS) && !defined(__CYGWIN__)
|
||||||
class location_from_symbol {
|
class location_from_symbol {
|
||||||
::Dl_info dli_;
|
boost::stacktrace::detail::Dl_info dli_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit location_from_symbol(const void* addr) noexcept
|
explicit location_from_symbol(const void* addr) noexcept
|
||||||
: dli_()
|
: dli_()
|
||||||
{
|
{
|
||||||
if (!::dladdr(const_cast<void*>(addr), &dli_)) { // `dladdr` on Solaris accepts nonconst addresses
|
if (!boost::stacktrace::detail::dladdr(addr, dli_)) {
|
||||||
dli_.dli_fname = 0;
|
dli_.dli_fname = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ namespace boost { namespace stacktrace {
|
|||||||
/// @cond
|
/// @cond
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
|
||||||
typedef const void* native_frame_ptr_t; // TODO: change to `typedef void(*native_frame_ptr_t)();`
|
using native_frame_ptr_t = const void*;
|
||||||
enum helper{ max_frames_dump = 128 };
|
enum helper{ max_frames_dump = 128 };
|
||||||
|
|
||||||
BOOST_STACKTRACE_FUNCTION std::size_t from_dump(const char* filename, native_frame_ptr_t* out_frames);
|
BOOST_STACKTRACE_FUNCTION std::size_t from_dump(const char* filename, native_frame_ptr_t* out_frames);
|
||||||
@@ -52,7 +52,7 @@ struct this_thread_frames { // struct is required to avoid warning about usage o
|
|||||||
BOOST_NOINLINE BOOST_STACKTRACE_FUNCTION static std::size_t collect(native_frame_ptr_t* out_frames, std::size_t max_frames_count, std::size_t skip) noexcept;
|
BOOST_NOINLINE BOOST_STACKTRACE_FUNCTION static std::size_t collect(native_frame_ptr_t* out_frames, std::size_t max_frames_count, std::size_t skip) noexcept;
|
||||||
|
|
||||||
BOOST_NOINLINE static std::size_t safe_dump_to_impl(void* memory, std::size_t size, std::size_t skip) noexcept {
|
BOOST_NOINLINE static std::size_t safe_dump_to_impl(void* memory, std::size_t size, std::size_t skip) noexcept {
|
||||||
typedef boost::stacktrace::detail::native_frame_ptr_t native_frame_ptr_t;
|
using boost::stacktrace::detail::native_frame_ptr_t;
|
||||||
|
|
||||||
if (size < sizeof(native_frame_ptr_t)) {
|
if (size < sizeof(native_frame_ptr_t)) {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -66,7 +66,7 @@ struct this_thread_frames { // struct is required to avoid warning about usage o
|
|||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
BOOST_NOINLINE static std::size_t safe_dump_to_impl(T file, std::size_t skip, std::size_t max_depth) noexcept {
|
BOOST_NOINLINE static std::size_t safe_dump_to_impl(T file, std::size_t skip, std::size_t max_depth) noexcept {
|
||||||
typedef boost::stacktrace::detail::native_frame_ptr_t native_frame_ptr_t;
|
using boost::stacktrace::detail::native_frame_ptr_t;
|
||||||
|
|
||||||
native_frame_ptr_t buffer[boost::stacktrace::detail::max_frames_dump + 1];
|
native_frame_ptr_t buffer[boost::stacktrace::detail::max_frames_dump + 1];
|
||||||
if (max_depth > boost::stacktrace::detail::max_frames_dump) {
|
if (max_depth > boost::stacktrace::detail::max_frames_dump) {
|
||||||
|
|||||||
@@ -33,6 +33,26 @@
|
|||||||
# pragma warning(disable:2196) // warning #2196: routine is both "inline" and "noinline"
|
# pragma warning(disable:2196) // warning #2196: routine is both "inline" and "noinline"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(BOOST_MSVC)
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
|
||||||
|
BOOST_SYMBOL_EXPORT inline void* boost_stacktrace_impl_return_nullptr() { return nullptr; }
|
||||||
|
const char* boost_stacktrace_impl_current_exception_stacktrace();
|
||||||
|
bool* boost_stacktrace_impl_ref_capture_stacktraces_at_throw();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef _M_IX86
|
||||||
|
# pragma comment(linker, "/ALTERNATENAME:_boost_stacktrace_impl_current_exception_stacktrace=_boost_stacktrace_impl_return_nullptr")
|
||||||
|
# pragma comment(linker, "/ALTERNATENAME:_boost_stacktrace_impl_ref_capture_stacktraces_at_throw=_boost_stacktrace_impl_return_nullptr")
|
||||||
|
#else
|
||||||
|
# pragma comment(linker, "/ALTERNATENAME:boost_stacktrace_impl_current_exception_stacktrace=boost_stacktrace_impl_return_nullptr")
|
||||||
|
# pragma comment(linker, "/ALTERNATENAME:boost_stacktrace_impl_ref_capture_stacktraces_at_throw=boost_stacktrace_impl_return_nullptr")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace boost { namespace stacktrace {
|
namespace boost { namespace stacktrace {
|
||||||
|
|
||||||
namespace impl {
|
namespace impl {
|
||||||
@@ -381,6 +401,8 @@ public:
|
|||||||
if (impl::current_exception_stacktrace) {
|
if (impl::current_exception_stacktrace) {
|
||||||
trace = impl::current_exception_stacktrace();
|
trace = impl::current_exception_stacktrace();
|
||||||
}
|
}
|
||||||
|
#elif defined(BOOST_MSVC)
|
||||||
|
trace = boost_stacktrace_impl_current_exception_stacktrace();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (trace) {
|
if (trace) {
|
||||||
|
|||||||
@@ -27,6 +27,10 @@ inline void set_capture_stacktraces_at_throw(bool enable = true) noexcept {
|
|||||||
if (impl::ref_capture_stacktraces_at_throw) {
|
if (impl::ref_capture_stacktraces_at_throw) {
|
||||||
impl::ref_capture_stacktraces_at_throw() = enable;
|
impl::ref_capture_stacktraces_at_throw() = enable;
|
||||||
}
|
}
|
||||||
|
#elif defined(BOOST_MSVC)
|
||||||
|
if (bool* p = boost_stacktrace_impl_ref_capture_stacktraces_at_throw()) {
|
||||||
|
*p = enable;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
(void)enable;
|
(void)enable;
|
||||||
}
|
}
|
||||||
@@ -45,6 +49,10 @@ inline bool get_capture_stacktraces_at_throw() noexcept {
|
|||||||
if (impl::ref_capture_stacktraces_at_throw) {
|
if (impl::ref_capture_stacktraces_at_throw) {
|
||||||
return impl::ref_capture_stacktraces_at_throw();
|
return impl::ref_capture_stacktraces_at_throw();
|
||||||
}
|
}
|
||||||
|
#elif defined(BOOST_MSVC)
|
||||||
|
if (bool* p = boost_stacktrace_impl_ref_capture_stacktraces_at_throw()) {
|
||||||
|
return *p;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,147 @@
|
|||||||
// accompanying file LICENSE_1_0.txt or copy at
|
// accompanying file LICENSE_1_0.txt or copy at
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
|
||||||
|
#include <boost/stacktrace/safe_dump_to.hpp>
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
extern "C" void** __cdecl __current_exception(); // exported from vcruntime.dll
|
||||||
|
#define _pCurrentException static_cast<PEXCEPTION_RECORD>(*__current_exception())
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
constexpr std::size_t kStacktraceDumpSize = 4096;
|
||||||
|
|
||||||
|
struct thrown_info {
|
||||||
|
ULONG_PTR object;
|
||||||
|
char* dump;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct exception_data {
|
||||||
|
bool capture_stacktraces_at_throw = true;
|
||||||
|
unsigned count = 0;
|
||||||
|
thrown_info* info = nullptr;
|
||||||
|
|
||||||
|
~exception_data() noexcept {
|
||||||
|
HANDLE hHeap = GetProcessHeap();
|
||||||
|
for (unsigned i = 0; i < count; ++i) {
|
||||||
|
HeapFree(hHeap, 0, info[i].dump);
|
||||||
|
}
|
||||||
|
HeapFree(hHeap, 0, info);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
thread_local exception_data data;
|
||||||
|
|
||||||
|
inline bool PER_IS_MSVC_EH(PEXCEPTION_RECORD p) noexcept {
|
||||||
|
const DWORD EH_EXCEPTION_NUMBER = 0xE06D7363;
|
||||||
|
const ULONG_PTR EH_MAGIC_NUMBER1 = 0x19930520;
|
||||||
|
|
||||||
|
return p->ExceptionCode == EH_EXCEPTION_NUMBER &&
|
||||||
|
(p->NumberParameters == 3 || p->NumberParameters == 4) &&
|
||||||
|
p->ExceptionInformation[0] == EH_MAGIC_NUMBER1;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline ULONG_PTR PER_PEXCEPTOBJ(PEXCEPTION_RECORD p) noexcept {
|
||||||
|
return p->ExceptionInformation[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned current_cxx_exception_index() noexcept {
|
||||||
|
if (PEXCEPTION_RECORD current_cxx_exception = _pCurrentException) {
|
||||||
|
for (unsigned i = data.count; i > 0;) {
|
||||||
|
--i;
|
||||||
|
if (data.info[i].object == PER_PEXCEPTOBJ(current_cxx_exception)) {
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return data.count;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool is_processing_rethrow(PEXCEPTION_RECORD p) noexcept {
|
||||||
|
// Processing flow:
|
||||||
|
// 0. throw;
|
||||||
|
// 1. _CxxThrowException(pExceptionObject = nullptr)
|
||||||
|
// 2. VEH & SEH (may throw new c++ exceptions!)
|
||||||
|
// 3. __RethrowException(_pCurrentException)
|
||||||
|
// 4. VEH
|
||||||
|
if (PER_PEXCEPTOBJ(p) == 0) return true;
|
||||||
|
PEXCEPTION_RECORD current_cxx_exception = _pCurrentException;
|
||||||
|
if (current_cxx_exception == nullptr) return false;
|
||||||
|
return PER_PEXCEPTOBJ(p) == PER_PEXCEPTOBJ(current_cxx_exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
LONG NTAPI veh(PEXCEPTION_POINTERS p) {
|
||||||
|
if (data.capture_stacktraces_at_throw &&
|
||||||
|
PER_IS_MSVC_EH(p->ExceptionRecord) &&
|
||||||
|
!is_processing_rethrow(p->ExceptionRecord)) {
|
||||||
|
HANDLE hHeap = GetProcessHeap();
|
||||||
|
unsigned index = current_cxx_exception_index();
|
||||||
|
unsigned new_count = 1 + (index < data.count ? index + 1 : 0);
|
||||||
|
|
||||||
|
for (unsigned i = new_count; i < data.count; ++i) {
|
||||||
|
HeapFree(hHeap, 0, data.info[i].dump);
|
||||||
|
data.info[i].dump = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* new_info;
|
||||||
|
if (data.info) {
|
||||||
|
new_info = HeapReAlloc(hHeap, HEAP_ZERO_MEMORY, data.info, sizeof(thrown_info) * new_count);
|
||||||
|
} else {
|
||||||
|
new_info = HeapAlloc(hHeap, HEAP_ZERO_MEMORY, sizeof(thrown_info) * new_count);
|
||||||
|
}
|
||||||
|
if (new_info) {
|
||||||
|
data.count = new_count;
|
||||||
|
data.info = static_cast<thrown_info*>(new_info);
|
||||||
|
data.info[data.count - 1].object = PER_PEXCEPTOBJ(p->ExceptionRecord);
|
||||||
|
char*& dump_ptr = data.info[data.count - 1].dump;
|
||||||
|
if (dump_ptr == nullptr) {
|
||||||
|
dump_ptr = static_cast<char*>(HeapAlloc(hHeap, 0, kStacktraceDumpSize));
|
||||||
|
}
|
||||||
|
if (dump_ptr != nullptr) {
|
||||||
|
const std::size_t kSkip = 4;
|
||||||
|
boost::stacktrace::safe_dump_to(kSkip, dump_ptr, kStacktraceDumpSize);
|
||||||
|
}
|
||||||
|
} else if (new_count <= data.count) {
|
||||||
|
data.count = new_count - 1;
|
||||||
|
HeapFree(hHeap, 0, data.info[data.count - 1].dump);
|
||||||
|
data.info[data.count - 1].dump = nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return EXCEPTION_CONTINUE_SEARCH;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct veh_installer {
|
||||||
|
PVOID h;
|
||||||
|
veh_installer() noexcept : h(AddVectoredExceptionHandler(1, veh)) {}
|
||||||
|
~veh_installer() noexcept { RemoveVectoredExceptionHandler(h); }
|
||||||
|
} installer;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
|
||||||
|
BOOST_SYMBOL_EXPORT const char* boost_stacktrace_impl_current_exception_stacktrace() {
|
||||||
|
unsigned index = current_cxx_exception_index();
|
||||||
|
return index < data.count ? data.info[index].dump : nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_SYMBOL_EXPORT bool* boost_stacktrace_impl_ref_capture_stacktraces_at_throw() {
|
||||||
|
return &data.capture_stacktraces_at_throw;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace boost { namespace stacktrace { namespace impl {
|
||||||
|
|
||||||
|
BOOST_SYMBOL_EXPORT void assert_no_pending_traces() noexcept {
|
||||||
|
}
|
||||||
|
|
||||||
|
}}} // namespace boost::stacktrace::impl
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
#include "exception_headers.h"
|
#include "exception_headers.h"
|
||||||
|
|
||||||
// At the moment the file is used only on POSIX. _Unwind_Backtrace may be
|
// At the moment the file is used only on POSIX. _Unwind_Backtrace may be
|
||||||
@@ -92,7 +233,7 @@ static const char*& reference_to_empty_padding(void* ptr) noexcept {
|
|||||||
if (is_libcpp_runtime()) {
|
if (is_libcpp_runtime()) {
|
||||||
// libc++-runtime
|
// libc++-runtime
|
||||||
BOOST_ASSERT_MSG(
|
BOOST_ASSERT_MSG(
|
||||||
sizeof(void*) == 4,
|
sizeof(void*) != 4,
|
||||||
"32bit platforms are unsupported with libc++ runtime padding reusage. "
|
"32bit platforms are unsupported with libc++ runtime padding reusage. "
|
||||||
"Please report this issue to the library maintainters."
|
"Please report this issue to the library maintainters."
|
||||||
);
|
);
|
||||||
@@ -222,3 +363,4 @@ BOOST_SYMBOL_EXPORT void assert_no_pending_traces() noexcept {
|
|||||||
|
|
||||||
}}} // namespace boost::stacktrace::impl
|
}}} // namespace boost::stacktrace::impl
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|||||||
14
test/CMakeLists.txt
Normal file
14
test/CMakeLists.txt
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# Copyright 2018-2020 Peter Dimov
|
||||||
|
# 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
|
||||||
|
|
||||||
|
include(BoostTest OPTIONAL RESULT_VARIABLE HAVE_BOOST_TEST)
|
||||||
|
|
||||||
|
if(NOT HAVE_BOOST_TEST)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
boost_test(TYPE run SOURCES test.cpp test_impl.cpp LINK_LIBRARIES Boost::stacktrace Boost::core)
|
||||||
|
boost_test(TYPE run SOURCES test_noop.cpp test_impl.cpp LINK_LIBRARIES Boost::stacktrace_noop Boost::core)
|
||||||
|
|
||||||
|
boost_test(TYPE run SOURCES test_trivial.cpp LINK_LIBRARIES Boost::stacktrace Boost::core)
|
||||||
@@ -24,7 +24,7 @@ lib backtrace
|
|||||||
|
|
||||||
project
|
project
|
||||||
: requirements
|
: requirements
|
||||||
[ requires cxx11_rvalue_references ]
|
[ requires cxx11_rvalue_references cxx11_template_aliases cxx11_noexcept ]
|
||||||
<toolset>msvc:<asynch-exceptions>on
|
<toolset>msvc:<asynch-exceptions>on
|
||||||
<toolset>intel:<cxxflags>-wd2196
|
<toolset>intel:<cxxflags>-wd2196
|
||||||
<target-os>linux:<linkflags>-lpthread
|
<target-os>linux:<linkflags>-lpthread
|
||||||
@@ -183,17 +183,29 @@ test-suite stacktrace_tests
|
|||||||
[ run test_from_exception_none.cpp : : : $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_none_basic_ho ]
|
[ run test_from_exception_none.cpp : : : $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_none_basic_ho ]
|
||||||
[ run test_from_exception_none.cpp : : : $(LINKSHARED_BT) <debug-symbols>on : from_exception_none_bt ]
|
[ run test_from_exception_none.cpp : : : $(LINKSHARED_BT) <debug-symbols>on : from_exception_none_bt ]
|
||||||
[ run test_from_exception_none.cpp : : : <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) <debug-symbols>on : from_exception_none_bt_ho ]
|
[ run test_from_exception_none.cpp : : : <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) <debug-symbols>on : from_exception_none_bt_ho ]
|
||||||
|
[ run test_from_exception_none.cpp : : : $(LINKSHARED_WIND) <debug-symbols>on : from_exception_none_windbg ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <define>BOOST_STACKTRACE_USE_WINDBG $(WIND_DEPS) <debug-symbols>on : from_exception_none_windbg_ho ]
|
||||||
|
[ run test_from_exception_none.cpp : : : $(LINKSHARED_WIND_CACHED) <debug-symbols>on : from_exception_none_windbg_cached ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <define>BOOST_STACKTRACE_USE_WINDBG_CACHED $(WICA_DEPS) <debug-symbols>on : from_exception_none_windbg_cached_ho ]
|
||||||
|
|
||||||
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BASIC) <debug-symbols>on : from_exception_disabled_basic ]
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BASIC) <debug-symbols>on : from_exception_disabled_basic ]
|
||||||
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_disabled_basic_ho ]
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_disabled_basic_ho ]
|
||||||
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BT) <debug-symbols>on : from_exception_disabled_bt ]
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BT) <debug-symbols>on : from_exception_disabled_bt ]
|
||||||
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) : from_exception_disabled_bt_ho ]
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) : from_exception_disabled_bt_ho ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_WIND) <debug-symbols>on : from_exception_disabled_windbg ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_WINDBG $(WIND_DEPS) <debug-symbols>on : from_exception_disabled_windbg_ho ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_WIND_CACHED) <debug-symbols>on : from_exception_disabled_windbg_cached ]
|
||||||
|
[ run test_from_exception_none.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_WINDBG_CACHED $(WICA_DEPS) <debug-symbols>on : from_exception_disabled_windbg_cached_ho ]
|
||||||
|
|
||||||
[ link test_from_exception.cpp : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BASIC) <debug-symbols>on : from_exception_basic ]
|
[ link test_from_exception.cpp : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BASIC) <debug-symbols>on : from_exception_basic ]
|
||||||
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BT) <debug-symbols>on : from_exception_bt ]
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_BT) <debug-symbols>on : from_exception_bt ]
|
||||||
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_WIND) <debug-symbols>on : from_exception_windbg ]
|
||||||
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception $(LINKSHARED_WIND_CACHED) <debug-symbols>on : from_exception_windbg_cached ]
|
||||||
|
|
||||||
[ link test_from_exception.cpp : <library>/boost/stacktrace//boost_stacktrace_from_exception $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_basic_ho ]
|
[ link test_from_exception.cpp : <library>/boost/stacktrace//boost_stacktrace_from_exception $(FORCE_SYMBOL_EXPORT) $(BASIC_DEPS) <debug-symbols>on : from_exception_basic_ho ]
|
||||||
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) <debug-symbols>on : from_exception_bt_ho ]
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_BACKTRACE $(BT_DEPS) <debug-symbols>on : from_exception_bt_ho ]
|
||||||
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_WINDBG $(WIND_DEPS) <debug-symbols>on : from_exception_windbg_ho ]
|
||||||
|
[ run test_from_exception.cpp : : : <library>/boost/stacktrace//boost_stacktrace_from_exception <define>BOOST_STACKTRACE_USE_WINDBG_CACHED $(WICA_DEPS) <debug-symbols>on : from_exception_windbg_cached_ho ]
|
||||||
;
|
;
|
||||||
|
|
||||||
# Assuring that examples compile and run. Adding sources from `examples` directory to the `type_index` test suite.
|
# Assuring that examples compile and run. Adding sources from `examples` directory to the `type_index` test suite.
|
||||||
|
|||||||
15
test/cmake_install_test/CMakeLists.txt
Normal file
15
test/cmake_install_test/CMakeLists.txt
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
# Copyright 2018-2021 Peter Dimov
|
||||||
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
|
# https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.5...3.20)
|
||||||
|
|
||||||
|
project(cmake_install_test LANGUAGES CXX)
|
||||||
|
|
||||||
|
find_package(boost_stacktrace REQUIRED)
|
||||||
|
|
||||||
|
add_executable(main main.cpp)
|
||||||
|
target_link_libraries(main Boost::stacktrace)
|
||||||
|
|
||||||
|
enable_testing()
|
||||||
|
add_test(main main)
|
||||||
12
test/cmake_install_test/main.cpp
Normal file
12
test/cmake_install_test/main.cpp
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
// Copyright 2019 Peter Dimov
|
||||||
|
// Copyright 2022-2024 Antony Polukhin
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/stacktrace/stacktrace.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
std::cout << boost::stacktrace::stacktrace() << std::endl;
|
||||||
|
}
|
||||||
46
test/cmake_subdir_test/CMakeLists.txt
Normal file
46
test/cmake_subdir_test/CMakeLists.txt
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
# Copyright 2018-2021 Peter Dimov
|
||||||
|
# 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
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.5...3.20)
|
||||||
|
|
||||||
|
project(cmake_subdir_test LANGUAGES CXX)
|
||||||
|
|
||||||
|
# Put boost_stacktrace_*.dll in the same directory as main.exe
|
||||||
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR})
|
||||||
|
|
||||||
|
add_subdirectory(../.. boostorg/stacktrace)
|
||||||
|
|
||||||
|
# boostdep --brief stacktrace
|
||||||
|
|
||||||
|
set(deps
|
||||||
|
|
||||||
|
# Primary dependencies
|
||||||
|
|
||||||
|
assert
|
||||||
|
config
|
||||||
|
container_hash
|
||||||
|
core
|
||||||
|
predef
|
||||||
|
winapi
|
||||||
|
|
||||||
|
# Secondary dependencies
|
||||||
|
|
||||||
|
describe
|
||||||
|
mp11
|
||||||
|
static_assert
|
||||||
|
throw_exception
|
||||||
|
|
||||||
|
)
|
||||||
|
|
||||||
|
foreach(dep IN LISTS deps)
|
||||||
|
|
||||||
|
add_subdirectory(../../../${dep} boostorg/${dep})
|
||||||
|
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
add_executable(main main.cpp)
|
||||||
|
target_link_libraries(main Boost::stacktrace)
|
||||||
|
|
||||||
|
enable_testing()
|
||||||
|
add_test(main main)
|
||||||
12
test/cmake_subdir_test/main.cpp
Normal file
12
test/cmake_subdir_test/main.cpp
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
// Copyright 2019 Peter Dimov
|
||||||
|
// Copyright 2022-2024 Antony Polukhin
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/stacktrace/stacktrace.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
std::cout << boost::stacktrace::stacktrace() << std::endl;
|
||||||
|
}
|
||||||
@@ -257,6 +257,12 @@ void test_empty_basic_stacktrace() {
|
|||||||
BOOST_TEST(!(st > st_t(0, 0)));
|
BOOST_TEST(!(st > st_t(0, 0)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_stacktrace_limits()
|
||||||
|
{
|
||||||
|
BOOST_TEST_EQ(boost::stacktrace::stacktrace(0, 1).size(), 1);
|
||||||
|
BOOST_TEST_EQ(boost::stacktrace::stacktrace(1, 1).size(), 1);
|
||||||
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
test_deeply_nested_namespaces();
|
test_deeply_nested_namespaces();
|
||||||
test_frames_string_data_validity();
|
test_frames_string_data_validity();
|
||||||
@@ -275,8 +281,8 @@ int main() {
|
|||||||
test_comparisons_base(make_some_stacktrace1(), make_some_stacktrace2());
|
test_comparisons_base(make_some_stacktrace1(), make_some_stacktrace2());
|
||||||
|
|
||||||
test_nested<260>(false);
|
test_nested<260>(false);
|
||||||
BOOST_TEST(boost::stacktrace::stacktrace(0, 1).size() == 1);
|
|
||||||
BOOST_TEST(boost::stacktrace::stacktrace(1, 1).size() == 1);
|
test_stacktrace_limits();
|
||||||
|
|
||||||
return boost::report_errors();
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,7 +31,27 @@ BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void in_test_throw_1(const char* msg) {
|
|||||||
|
|
||||||
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void in_test_throw_2(const char* msg) {
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void in_test_throw_2(const char* msg) {
|
||||||
std::string new_msg{msg};
|
std::string new_msg{msg};
|
||||||
throw std::runtime_error(new_msg);
|
throw std::logic_error(new_msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void in_test_rethrow_1(const char* msg) {
|
||||||
|
try {
|
||||||
|
in_test_throw_1(msg);
|
||||||
|
} catch (const std::exception&) {
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void in_test_rethrow_2(const char* msg) {
|
||||||
|
try {
|
||||||
|
in_test_throw_2(msg);
|
||||||
|
} catch (const std::exception&) {
|
||||||
|
try {
|
||||||
|
in_test_throw_1(msg);
|
||||||
|
} catch (const std::exception&) {}
|
||||||
|
|
||||||
|
throw;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_no_exception() {
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_no_exception() {
|
||||||
@@ -67,6 +87,31 @@ BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_after_other_exception() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_rethrow() {
|
||||||
|
try {
|
||||||
|
in_test_rethrow_1("test rethrow");
|
||||||
|
} catch (const std::exception&) {
|
||||||
|
auto trace = stacktrace::from_current_exception();
|
||||||
|
BOOST_TEST(trace);
|
||||||
|
std::cout << "Tarce in test_rethrow(): " << trace << '\n';
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_throw_1") != std::string::npos);
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_rethrow_1") != std::string::npos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_rethrow_after_other_exception() {
|
||||||
|
try {
|
||||||
|
in_test_rethrow_2("test_rethrow_after_other_exception");
|
||||||
|
} catch (const std::exception&) {
|
||||||
|
auto trace = stacktrace::from_current_exception();
|
||||||
|
BOOST_TEST(trace);
|
||||||
|
std::cout << "Tarce in test_rethrow_after_other_exception(): " << trace << '\n';
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_throw_1") == std::string::npos);
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_throw_2") != std::string::npos);
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_rethrow_2") != std::string::npos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_nested() {
|
BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_nested() {
|
||||||
try {
|
try {
|
||||||
in_test_throw_1("test_other_exception_active");
|
in_test_throw_1("test_other_exception_active");
|
||||||
@@ -103,7 +148,11 @@ BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_rethrow_nested() {
|
|||||||
BOOST_TEST(trace);
|
BOOST_TEST(trace);
|
||||||
std::cout << "Tarce in test_rethrow_nested(): " << trace << '\n';
|
std::cout << "Tarce in test_rethrow_nested(): " << trace << '\n';
|
||||||
BOOST_TEST(to_string(trace).find("in_test_throw_1") == std::string::npos);
|
BOOST_TEST(to_string(trace).find("in_test_throw_1") == std::string::npos);
|
||||||
|
#if defined(BOOST_MSVC)
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_throw_2") == std::string::npos);
|
||||||
|
#else
|
||||||
BOOST_TEST(to_string(trace).find("in_test_throw_2") != std::string::npos);
|
BOOST_TEST(to_string(trace).find("in_test_throw_2") != std::string::npos);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -133,7 +182,11 @@ BOOST_NOINLINE BOOST_SYMBOL_VISIBLE void test_from_other_thread() {
|
|||||||
BOOST_TEST(trace);
|
BOOST_TEST(trace);
|
||||||
std::cout << "Tarce in test_rethrow_nested(): " << trace << '\n';
|
std::cout << "Tarce in test_rethrow_nested(): " << trace << '\n';
|
||||||
BOOST_TEST(to_string(trace).find("in_test_throw_1") == std::string::npos);
|
BOOST_TEST(to_string(trace).find("in_test_throw_1") == std::string::npos);
|
||||||
|
#if defined(BOOST_MSVC)
|
||||||
|
BOOST_TEST(to_string(trace).find("in_test_throw_2") == std::string::npos);
|
||||||
|
#else
|
||||||
BOOST_TEST(to_string(trace).find("in_test_throw_2") != std::string::npos);
|
BOOST_TEST(to_string(trace).find("in_test_throw_2") != std::string::npos);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -146,6 +199,8 @@ int main() {
|
|||||||
test_no_exception();
|
test_no_exception();
|
||||||
test_trace_from_exception();
|
test_trace_from_exception();
|
||||||
test_after_other_exception();
|
test_after_other_exception();
|
||||||
|
test_rethrow();
|
||||||
|
test_rethrow_after_other_exception();
|
||||||
test_nested();
|
test_nested();
|
||||||
test_rethrow_nested();
|
test_rethrow_nested();
|
||||||
test_from_other_thread();
|
test_from_other_thread();
|
||||||
|
|||||||
Reference in New Issue
Block a user