]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR libstdc++/59548 (Abort after copying std::unordered_map in debug mode)
authorJonathan Wakely <jwakely@redhat.com>
Fri, 24 Jan 2014 20:08:20 +0000 (20:08 +0000)
committerJonathan Wakely <redi@gcc.gnu.org>
Fri, 24 Jan 2014 20:08:20 +0000 (20:08 +0000)
PR libstdc++/59548
* include/debug/safe_base.h (_Safe_sequence_base): Define copy
constructor to prevent it being implicitly defined as deleted, but
do not copy anything.
* include/debug/safe_unordered_base.h (_Safe_unordered_container_base):
Define copy and move constructors similar to _Safe_sequence_base's.
* testsuite/23_containers/unordered_map/59548.cc: New.

From-SVN: r207059

libstdc++-v3/ChangeLog
libstdc++-v3/include/debug/safe_base.h
libstdc++-v3/include/debug/safe_unordered_base.h
libstdc++-v3/testsuite/23_containers/unordered_map/59548.cc [new file with mode: 0644]

index 211f7317131279c5593e9e0534f47398b05d33e1..30e4f22b8c82ae67020a93db71a3dd1ff12ee751 100644 (file)
@@ -1,3 +1,13 @@
+2014-01-24  Jonathan Wakely  <jwakely@redhat.com>
+
+       PR libstdc++/59548
+       * include/debug/safe_base.h (_Safe_sequence_base): Define copy
+       constructor to prevent it being implicitly defined as deleted, but
+       do not copy anything.
+       * include/debug/safe_unordered_base.h (_Safe_unordered_container_base):
+       Define copy and move constructors similar to _Safe_sequence_base's.
+       * testsuite/23_containers/unordered_map/59548.cc: New.
+
 2014-01-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
            Steve Ellcey  <sellcey@mips.com>
 
index 4b1d082d264e21cefe379b30f9640bd26f4ee1c8..631ac773ddb45048d2857c425ba2e689a93e24ae 100644 (file)
@@ -193,6 +193,9 @@ namespace __gnu_debug
     { }
 
 #if __cplusplus >= 201103L
+    _Safe_sequence_base(const _Safe_sequence_base&) noexcept
+      : _Safe_sequence_base() { }
+
     _Safe_sequence_base(_Safe_sequence_base&& __x) noexcept
       : _Safe_sequence_base()
     { _M_swap(__x); }
index 9cde781364cace67ed64653dce3630f9df83fc48..bbb274f34e4fae896c55cdf71c3fc2c0c6872080 100644 (file)
@@ -133,9 +133,19 @@ namespace __gnu_debug
   protected:
     // Initialize with a version number of 1 and no iterators
     _Safe_unordered_container_base()
-    : _M_local_iterators(0), _M_const_local_iterators(0)
+    : _M_local_iterators(nullptr), _M_const_local_iterators(nullptr)
     { }
 
+    // Initialize with a version number of 1 and no iterators
+    _Safe_unordered_container_base(const _Safe_unordered_container_base&)
+    noexcept
+    : _Safe_unordered_container_base() { }
+
+    _Safe_unordered_container_base(_Safe_unordered_container_base&& __x)
+    noexcept
+    : _Safe_unordered_container_base()
+    { this->_M_swap(__x); }
+
     /** Notify all iterators that reference this container that the
        container is being destroyed. */
     ~_Safe_unordered_container_base()
diff --git a/libstdc++-v3/testsuite/23_containers/unordered_map/59548.cc b/libstdc++-v3/testsuite/23_containers/unordered_map/59548.cc
new file mode 100644 (file)
index 0000000..1e81bb7
--- /dev/null
@@ -0,0 +1,34 @@
+// { dg-options "-std=gnu++11" }
+// { dg-do compile }
+// { dg-require-debug-mode "" }
+
+// Copyright (C) 2014 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++/59548
+
+#include <unordered_map>
+
+int main()
+{
+  std::unordered_map<int,int> foo{ {0,1} };
+  auto i = foo.begin();
+  {
+    auto bar = foo;
+  }
+  return i->first;
+}