diff options
author | rofl0r <retnyg@gmx.net> | 2013-01-04 18:47:17 +0100 |
---|---|---|
committer | rofl0r <retnyg@gmx.net> | 2013-01-04 20:36:34 +0100 |
commit | d84923d89e4fe46877334cbaa5e4549f2c4cb8a6 (patch) | |
tree | dab643d17b226cac9c4df5fcb8ec0ae6d99cc392 | |
parent | 2ba3f44db51a816d3f89ca64d8943a3bee03fa5f (diff) | |
download | musl-d84923d89e4fe46877334cbaa5e4549f2c4cb8a6.tar.gz musl-d84923d89e4fe46877334cbaa5e4549f2c4cb8a6.tar.bz2 musl-d84923d89e4fe46877334cbaa5e4549f2c4cb8a6.tar.xz musl-d84923d89e4fe46877334cbaa5e4549f2c4cb8a6.zip |
setjmp.h: add struct tag for sigjmp_buf (GCC C++ compatibility)
the anonymous struct typedef with array notation breaks with
GCC in C++ mode:
error: non-local function 'static<anonymous struct>
(& boost::signal_handler::jump_buffer())[1]' uses anonymous type
this is a known GCC issue, as search results for that error msg
suggest.
since this is hard to work around in the calling C++ code, a
fix in musl is preferable.
-rw-r--r-- | include/setjmp.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/include/setjmp.h b/include/setjmp.h index abc74234..5456d8f8 100644 --- a/include/setjmp.h +++ b/include/setjmp.h @@ -13,7 +13,7 @@ extern "C" { #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ || defined(_BSD_SOURCE) -typedef struct { +typedef struct __sigjmp_buf { jmp_buf __jb; unsigned long __fl; unsigned long __ss[128/sizeof(long)]; |