[libcxx] [test] D26813: allocator<const T> is non-Standard.

N4582 17.6.3.5 [allocator.requirements] says that allocators are given
cv-unqualified object types, and N4582 20.9.9 [default.allocator]
implies that allocator<const T> is ill-formed (due to colliding
address() overloads). Therefore, tests for allocator<const T>
should be marked as libcxx-specific (if not removed outright).

git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@287381 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Stephan T. Lavavej
2016-11-18 21:54:31 +00:00
parent 60479ea31b
commit cb9d881ca0
2 changed files with 18 additions and 18 deletions

View File

@@ -16,6 +16,8 @@
#include <memory> #include <memory>
#include <cassert> #include <cassert>
#include "test_macros.h"
template <typename T> template <typename T>
void test_max(size_t count) void test_max(size_t count)
{ {
@@ -27,10 +29,10 @@ void test_max(size_t count)
} }
} }
int main() template <typename T>
void test()
{ {
{ // Bug 26812 -- allocating too large // Bug 26812 -- allocating too large
typedef double T;
std::allocator<T> a; std::allocator<T> a;
test_max<T> (a.max_size() + 1); // just barely too large test_max<T> (a.max_size() + 1); // just barely too large
test_max<T> (a.max_size() * 2); // significantly too large test_max<T> (a.max_size() * 2); // significantly too large
@@ -38,12 +40,8 @@ int main()
test_max<T> ((size_t) -1); // way too large test_max<T> ((size_t) -1); // way too large
} }
int main()
{ {
typedef const double T; test<double>();
std::allocator<T> a; LIBCPP_ONLY(test<const double>());
test_max<T> (a.max_size() + 1); // just barely too large
test_max<T> (a.max_size() * 2); // significantly too large
test_max<T> (((size_t) -1) / sizeof(T) + 1); // multiply will overflow
test_max<T> ((size_t) -1); // way too large
}
} }

View File

@@ -32,6 +32,8 @@
#include <type_traits> #include <type_traits>
#include <cstddef> #include <cstddef>
#include "test_macros.h"
int main() int main()
{ {
static_assert((std::is_same<std::allocator<char>::size_type, std::size_t>::value), ""); static_assert((std::is_same<std::allocator<char>::size_type, std::size_t>::value), "");
@@ -45,7 +47,7 @@ int main()
std::allocator<int> >::value), ""); std::allocator<int> >::value), "");
static_assert((std::is_same<std::allocator< char>::is_always_equal, std::true_type>::value), ""); static_assert((std::is_same<std::allocator< char>::is_always_equal, std::true_type>::value), "");
static_assert((std::is_same<std::allocator<const char>::is_always_equal, std::true_type>::value), ""); LIBCPP_STATIC_ASSERT((std::is_same<std::allocator<const char>::is_always_equal, std::true_type>::value), "");
std::allocator<char> a; std::allocator<char> a;
std::allocator<char> a2 = a; std::allocator<char> a2 = a;