diff options
author | Howard Hinnant <hhinnant@apple.com> | 2013-06-19 21:29:40 +0000 |
---|---|---|
committer | Howard Hinnant <hhinnant@apple.com> | 2013-06-19 21:29:40 +0000 |
commit | 07d3eccd26a600a6cad3bb6807880f46a76f269e (patch) | |
tree | 8f9a3056982d04fbb15a89146326e7a7834aabe5 /libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp | |
parent | 64f440518b3dc41da99ace80d9289bfa8d92aa15 (diff) | |
download | bcm5719-llvm-07d3eccd26a600a6cad3bb6807880f46a76f269e.tar.gz bcm5719-llvm-07d3eccd26a600a6cad3bb6807880f46a76f269e.zip |
Implement full support for non-pointer types in custom allocators. This is for the associative containers only. This work still needs to be done on the unordered and sequence containers. Fixes http://llvm.org/bugs/show_bug.cgi?id=15978
llvm-svn: 184358
Diffstat (limited to 'libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp')
-rw-r--r-- | libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp b/libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp index ed5eb24abcb..c807b4ff558 100644 --- a/libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp +++ b/libcxx/test/containers/associative/multimap/multimap.cons/move_alloc.pass.cpp @@ -19,6 +19,7 @@ #include "../../../MoveOnly.h" #include "../../../test_compare.h" #include "../../../test_allocator.h" +#include "../../../min_allocator.h" int main() { @@ -140,5 +141,46 @@ int main() assert(m3.key_comp() == C(5)); assert(m1.empty()); } +#if __cplusplus >= 201103L + { + typedef std::pair<MoveOnly, MoveOnly> V; + typedef std::pair<const MoveOnly, MoveOnly> VC; + typedef test_compare<std::less<MoveOnly> > C; + typedef min_allocator<VC> A; + typedef std::multimap<MoveOnly, MoveOnly, C, A> M; + typedef std::move_iterator<V*> I; + V a1[] = + { + V(1, 1), + V(1, 2), + V(1, 3), + V(2, 1), + V(2, 2), + V(2, 3), + V(3, 1), + V(3, 2), + V(3, 3) + }; + M m1(I(a1), I(a1+sizeof(a1)/sizeof(a1[0])), C(5), A()); + V a2[] = + { + V(1, 1), + V(1, 2), + V(1, 3), + V(2, 1), + V(2, 2), + V(2, 3), + V(3, 1), + V(3, 2), + V(3, 3) + }; + M m2(I(a2), I(a2+sizeof(a2)/sizeof(a2[0])), C(5), A()); + M m3(std::move(m1), A()); + assert(m3 == m2); + assert(m3.get_allocator() == A()); + assert(m3.key_comp() == C(5)); + assert(m1.empty()); + } +#endif #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES } |