diff options
author | Paolo Carlini <paolo.carlini@oracle.com> | 2012-08-04 11:44:28 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2012-08-04 11:44:28 +0000 |
commit | 75235f0597d6ad6dc53ce7a763e5fe7c8534e41a (patch) | |
tree | 6129cf34eb28bcb6d35dd02f41e40d2a8b49a66e | |
parent | fc27f749afc49dbf95594caff81a9f33e2b59d8e (diff) | |
download | gcc-75235f0597d6ad6dc53ce7a763e5fe7c8534e41a.zip gcc-75235f0597d6ad6dc53ce7a763e5fe7c8534e41a.tar.gz gcc-75235f0597d6ad6dc53ce7a763e5fe7c8534e41a.tar.bz2 |
revert: stl_map.h (operator[](key_type&&)): Replace std::make_pair with value_type.
2012-08-04 Paolo Carlini <paolo.carlini@oracle.com>
Revert:
2012-08-03 Ollie Wild <aaw@google.com>
Richard Smith <richardsmith@google.com>
* include/bits/stl_map.h (operator[](key_type&&)): Replace
std::make_pair with value_type.
* testsuite/23_containers/map/operators/2.cc: New test.
From-SVN: r190142
-rw-r--r-- | libstdc++-v3/ChangeLog | 10 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/stl_map.h | 2 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/23_containers/map/operators/2.cc | 38 |
3 files changed, 11 insertions, 39 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 546bdee..d247f5b 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,13 @@ +2012-08-04 Paolo Carlini <paolo.carlini@oracle.com> + + Revert: + 2012-08-03 Ollie Wild <aaw@google.com> + Richard Smith <richardsmith@google.com> + + * include/bits/stl_map.h (operator[](key_type&&)): Replace + std::make_pair with value_type. + * testsuite/23_containers/map/operators/2.cc: New test. + 2012-08-03 François Dumont <fdumont@gcc.gnu.org> * include/debug/functions.h (__check_partition_lower_aux): Remove diff --git a/libstdc++-v3/include/bits/stl_map.h b/libstdc++-v3/include/bits/stl_map.h index a3abdd4..cfd478a 100644 --- a/libstdc++-v3/include/bits/stl_map.h +++ b/libstdc++-v3/include/bits/stl_map.h @@ -475,7 +475,7 @@ _GLIBCXX_BEGIN_NAMESPACE_CONTAINER iterator __i = lower_bound(__k); // __i->first is greater than or equivalent to __k. if (__i == end() || key_comp()(__k, (*__i).first)) - __i = insert(__i, value_type(std::move(__k), mapped_type())); + __i = insert(__i, std::make_pair(std::move(__k), mapped_type())); return (*__i).second; } #endif diff --git a/libstdc++-v3/testsuite/23_containers/map/operators/2.cc b/libstdc++-v3/testsuite/23_containers/map/operators/2.cc deleted file mode 100644 index ce633d7..0000000 --- a/libstdc++-v3/testsuite/23_containers/map/operators/2.cc +++ /dev/null @@ -1,38 +0,0 @@ -// Copyright (C) 2012 -// 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/>. - -// 23.4.4 template class map - -// This test verifies that the value type of a map need not be default -// copyable. - -// { dg-do compile } -// { dg-options "-std=gnu++11" } - -#include <map> - -struct Mapped { - Mapped(); - explicit Mapped(const Mapped&); -}; - -Mapped & foo() -{ - std::map<int, Mapped> m; - return m[0]; -} |