diff options
author | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-01-16 09:20:34 +0000 |
---|---|---|
committer | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-01-16 09:20:34 +0000 |
commit | 17ae7f11546e1ce8bec4e4ec71ccb59891ad19cc (patch) | |
tree | 09d17ad81858e565dc037a69cf4b591e41101256 /libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc | |
parent | 31fd081da3d7a8b1184013bf5f9ad06e1ee02462 (diff) | |
download | gcc-17ae7f11546e1ce8bec4e4ec71ccb59891ad19cc.tar.gz |
PR libstdc++/55043
* include/std/unordered_map: Include alloc_traits.h
* include/std/unordered_set: Likewise.
* include/bits/alloc_traits.h: Define __is_copy_insertable.
* include/bits/unordered_map.h: Use it.
* include/bits/unordered_set.h: Likewise.
* include/debug/unordered_map.h: Likewise.
* include/debug/unordered_set.h: Likewise.
* include/profile/unordered_map.h: Likewise.
* include/profile/unordered_set.h: Likewise.
* include/bits/hashtable.h: Fix comment typos.
* testsuite/23_containers/unordered_map/55043.cc: New.
* testsuite/23_containers/unordered_multimap/55043.cc: New.
* testsuite/23_containers/unordered_multiset/55043.cc: New.
* testsuite/23_containers/unordered_set/55043.cc: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@195231 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc')
-rw-r--r-- | libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc b/libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc new file mode 100644 index 00000000000..3b0b973e80d --- /dev/null +++ b/libstdc++-v3/testsuite/23_containers/unordered_set/55043.cc @@ -0,0 +1,73 @@ +// { dg-options "-std=gnu++0x" } +// { dg-do compile } + +// Copyright (C) 2013 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/>. + +// libstdc++/55043 + +#include <unordered_set> +#include <vector> + +struct MoveOnly +{ + MoveOnly() = default; + MoveOnly(MoveOnly&&) = default; +}; + +struct equal { + bool operator()(const MoveOnly&, const MoveOnly) const { return true; } +}; +struct hash { + size_t operator()(const MoveOnly&) const { return 0; } +}; + +template<typename Alloc> + using test_type = std::unordered_set<MoveOnly, hash, equal, Alloc>; + +void test01() +{ + typedef test_type<std::allocator<MoveOnly>> uim; + std::vector<uim> v; + v.emplace_back(uim()); +} + +// Unordered containers don't use allocator_traits yet so need full +// Allocator interface, derive from std::allocator to get it. +template<typename T, bool R> +struct Alloc : std::allocator<T> +{ + template<typename U> + struct rebind { typedef Alloc<U, R> other; }; + + Alloc() = default; + + template<typename U> + Alloc(const Alloc<U, R>&) { } + + typedef typename std::conditional<R, T&&, const T&>::type arg_type; + + void construct(T* p, arg_type) const + { new((void*)p) T(); } +}; + +// verify is_copy_constructible depends on allocator +typedef test_type<Alloc<MoveOnly, true>> uim_rval; +static_assert(std::is_copy_constructible<uim_rval>::value, "is not copyable"); + +typedef test_type<Alloc<MoveOnly, false>> uim_lval; +static_assert(std::is_copy_constructible<uim_lval>::value, "is copyable"); |