summaryrefslogtreecommitdiffstats
path: root/libcxx/test
diff options
context:
space:
mode:
authorHoward Hinnant <hhinnant@apple.com>2013-03-23 17:27:16 +0000
committerHoward Hinnant <hhinnant@apple.com>2013-03-23 17:27:16 +0000
commit65a87ccdbf0c5ffc387e711946ddcb417efb48b8 (patch)
treea10d0696bf2ab6a31c22035a22e2c4bb9e8cca3f /libcxx/test
parent794e05b03b394038490043d80647c97f96cca5eb (diff)
downloadbcm5719-llvm-65a87ccdbf0c5ffc387e711946ddcb417efb48b8.tar.gz
bcm5719-llvm-65a87ccdbf0c5ffc387e711946ddcb417efb48b8.zip
This is a start at making the libc++ test suite friendlier to the -fnoexceptions flag. Although this is not a complete solution, it does reduce the number of test failures on OS X from 467 to 128 on OS X when -fno-exceptions is enabled, and does not impact the number of failures at all when -fno-exceptions is not enabled. The bulk of this code was donated anonymously.
llvm-svn: 177824
Diffstat (limited to 'libcxx/test')
-rw-r--r--libcxx/test/containers/stack_allocator.h7
-rw-r--r--libcxx/test/containers/test_allocator.h7
-rw-r--r--libcxx/test/re/test_allocator.h7
-rw-r--r--libcxx/test/strings/basic.string/test_allocator.h7
-rw-r--r--libcxx/test/thread/futures/test_allocator.h7
-rw-r--r--libcxx/test/utilities/function.objects/func.wrap/func.wrap.func/test_allocator.h7
-rw-r--r--libcxx/test/utilities/memory/util.smartptr/util.smartptr.shared/test_allocator.h7
7 files changed, 42 insertions, 7 deletions
diff --git a/libcxx/test/containers/stack_allocator.h b/libcxx/test/containers/stack_allocator.h
index 30f58718eb2..e6af473816a 100644
--- a/libcxx/test/containers/stack_allocator.h
+++ b/libcxx/test/containers/stack_allocator.h
@@ -29,8 +29,13 @@ private:
public:
pointer allocate(size_type n, const void* = 0)
{
- if (n > N - (ptr_ - buf_) / sizeof(value_type))
+ if (n > N - (ptr_ - buf_) / sizeof(value_type)) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
pointer r = (T*)ptr_;
ptr_ += n * sizeof(T);
return r;
diff --git a/libcxx/test/containers/test_allocator.h b/libcxx/test/containers/test_allocator.h
index c5da7e6390d..eed33a0e3ea 100644
--- a/libcxx/test/containers/test_allocator.h
+++ b/libcxx/test/containers/test_allocator.h
@@ -48,8 +48,13 @@ public:
const_pointer address(const_reference x) const {return &x;}
pointer allocate(size_type n, const void* = 0)
{
- if (count >= throw_after)
+ if (count >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++count;
return (pointer)std::malloc(n * sizeof(T));
}
diff --git a/libcxx/test/re/test_allocator.h b/libcxx/test/re/test_allocator.h
index c5da7e6390d..eed33a0e3ea 100644
--- a/libcxx/test/re/test_allocator.h
+++ b/libcxx/test/re/test_allocator.h
@@ -48,8 +48,13 @@ public:
const_pointer address(const_reference x) const {return &x;}
pointer allocate(size_type n, const void* = 0)
{
- if (count >= throw_after)
+ if (count >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++count;
return (pointer)std::malloc(n * sizeof(T));
}
diff --git a/libcxx/test/strings/basic.string/test_allocator.h b/libcxx/test/strings/basic.string/test_allocator.h
index 001ca98bd67..89852159d3c 100644
--- a/libcxx/test/strings/basic.string/test_allocator.h
+++ b/libcxx/test/strings/basic.string/test_allocator.h
@@ -48,8 +48,13 @@ public:
const_pointer address(const_reference x) const {return &x;}
pointer allocate(size_type n, const void* = 0)
{
- if (count >= throw_after)
+ if (count >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++count;
return (pointer)std::malloc(n * sizeof(T));
}
diff --git a/libcxx/test/thread/futures/test_allocator.h b/libcxx/test/thread/futures/test_allocator.h
index 7644bc7c968..e04d4320619 100644
--- a/libcxx/test/thread/futures/test_allocator.h
+++ b/libcxx/test/thread/futures/test_allocator.h
@@ -48,8 +48,13 @@ public:
const_pointer address(const_reference x) const {return &x;}
pointer allocate(size_type n, const void* = 0)
{
- if (count >= throw_after)
+ if (count >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++count;
return (pointer)std::malloc(n * sizeof(T));
}
diff --git a/libcxx/test/utilities/function.objects/func.wrap/func.wrap.func/test_allocator.h b/libcxx/test/utilities/function.objects/func.wrap/func.wrap.func/test_allocator.h
index c5da7e6390d..eed33a0e3ea 100644
--- a/libcxx/test/utilities/function.objects/func.wrap/func.wrap.func/test_allocator.h
+++ b/libcxx/test/utilities/function.objects/func.wrap/func.wrap.func/test_allocator.h
@@ -48,8 +48,13 @@ public:
const_pointer address(const_reference x) const {return &x;}
pointer allocate(size_type n, const void* = 0)
{
- if (count >= throw_after)
+ if (count >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++count;
return (pointer)std::malloc(n * sizeof(T));
}
diff --git a/libcxx/test/utilities/memory/util.smartptr/util.smartptr.shared/test_allocator.h b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.shared/test_allocator.h
index 795f6e1f77e..d9b72bce49e 100644
--- a/libcxx/test/utilities/memory/util.smartptr/util.smartptr.shared/test_allocator.h
+++ b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.shared/test_allocator.h
@@ -54,8 +54,13 @@ public:
pointer allocate(size_type n, const void* = 0)
{
assert(data_ >= 0);
- if (time_to_throw >= throw_after)
+ if (time_to_throw >= throw_after) {
+#ifndef _LIBCPP_NO_EXCEPTIONS
throw std::bad_alloc();
+#else
+ std::terminate();
+#endif
+ }
++time_to_throw;
++alloc_count;
return (pointer)std::malloc(n * sizeof(T));
OpenPOWER on IntegriCloud