aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely@redhat.com>2014-12-12 15:10:08 +0000
committerJonathan Wakely <redi@gcc.gnu.org>2014-12-12 15:10:08 +0000
commit8f596ff51a4177ce494b6567c83a2fa0bbf12c71 (patch)
tree7495594fbd2fed9ddef1699b6279da6a6968dbd0 /libstdc++-v3
parentdd92baee2ac422ac25fe6fdf1f1e650ca846526f (diff)
downloadgcc-8f596ff51a4177ce494b6567c83a2fa0bbf12c71.zip
gcc-8f596ff51a4177ce494b6567c83a2fa0bbf12c71.tar.gz
gcc-8f596ff51a4177ce494b6567c83a2fa0bbf12c71.tar.bz2
re PR libstdc++/64241 (make_exception_ptr returns garbage with -fno-exceptions)
PR libstdc++/64241 * libsupc++/exception_ptr.h: Return empty object when exceptions are disabled. * testsuite/18_support/exception_ptr/64241.cc: New. From-SVN: r218675
Diffstat (limited to 'libstdc++-v3')
-rw-r--r--libstdc++-v3/ChangeLog7
-rw-r--r--libstdc++-v3/libsupc++/exception_ptr.h10
-rw-r--r--libstdc++-v3/testsuite/18_support/exception_ptr/64241.cc39
3 files changed, 52 insertions, 4 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index ba90672..52f6d00 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,5 +1,12 @@
2014-12-12 Jonathan Wakely <jwakely@redhat.com>
+ PR libstdc++/64241
+ * libsupc++/exception_ptr.h: Return empty object when exceptions are
+ disabled.
+ * testsuite/18_support/exception_ptr/64241.cc: New.
+
+2014-12-12 Jonathan Wakely <jwakely@redhat.com>
+
* include/bits/stl_iterator.h (make_reverse_iterator): LWG DR 2285.
* include/std/tuple: Add feature-test macro.
* testsuite/24_iterators/reverse_iterator/make.cc: New.
diff --git a/libstdc++-v3/libsupc++/exception_ptr.h b/libstdc++-v3/libsupc++/exception_ptr.h
index 9ba0de4..8b27359 100644
--- a/libstdc++-v3/libsupc++/exception_ptr.h
+++ b/libstdc++-v3/libsupc++/exception_ptr.h
@@ -168,16 +168,18 @@ namespace std
exception_ptr
make_exception_ptr(_Ex __ex) _GLIBCXX_USE_NOEXCEPT
{
- __try
- {
#ifdef __EXCEPTIONS
+ try
+ {
throw __ex;
-#endif
}
- __catch(...)
+ catch(...)
{
return current_exception();
}
+#else
+ return exception_ptr();
+#endif
}
// _GLIBCXX_RESOLVE_LIB_DEFECTS
diff --git a/libstdc++-v3/testsuite/18_support/exception_ptr/64241.cc b/libstdc++-v3/testsuite/18_support/exception_ptr/64241.cc
new file mode 100644
index 0000000..c7e1433
--- /dev/null
+++ b/libstdc++-v3/testsuite/18_support/exception_ptr/64241.cc
@@ -0,0 +1,39 @@
+// Copyright (C) 2014 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+// { dg-options "-std=gnu++11 -fno-exceptions -O0" }
+
+#include <exception>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ bool test __attribute__((unused)) = true;
+ {
+ // Put some non-zero bytes on the stack
+ void* p __attribute__((unused)) = &test;
+ }
+ std::exception_ptr p = std::make_exception_ptr(1);
+ VERIFY( p == nullptr );
+}
+
+int
+main()
+{
+ test01();
+}