re PR libstdc++/63500 (bug in debug version of std::make_move_iterator?)
authorFrançois Dumont <fdumont@gcc.gnu.org>
Wed, 15 Oct 2014 20:40:31 +0000 (20:40 +0000)
committerFrançois Dumont <fdumont@gcc.gnu.org>
Wed, 15 Oct 2014 20:40:31 +0000 (20:40 +0000)
2014-10-15  François Dumont  <fdumont@gcc.gnu.org>
    Jonathan Wakely  <jwakely@redhat.com>

PR libstdc++/63500
* include/debug/functions.h (__foreign_iterator_aux2): Do not check for
foreign iterators if input iterators returns rvalue reference.
* testsuite/23_containers/vector/63500.cc: New.

Co-Authored-By: Jonathan Wakely <jwakely@redhat.com>
From-SVN: r216286

libstdc++-v3/ChangeLog
libstdc++-v3/include/debug/functions.h
libstdc++-v3/testsuite/23_containers/vector/63500.cc [new file with mode: 0644]

index 711cd2374dac5f97ea9fd5a2aee6499855e535f9..89b86eb1b208a720e71e740ac0459c46e72be90c 100644 (file)
@@ -1,3 +1,11 @@
+2014-10-15  François Dumont  <fdumont@gcc.gnu.org>
+           Jonathan Wakely  <jwakely@redhat.com>
+
+       PR libstdc++/63500
+       * include/debug/functions.h (__foreign_iterator_aux2): Do not check for
+       foreign iterators if input iterators returns rvalue reference.
+       * testsuite/23_containers/vector/63500.cc: New.
+
 2014-10-15  Paolo Carlini  <paolo.carlini@oracle.com>
 
        * testsuite/21_strings/basic_string/capacity/char/shrink_to_fit.cc:
index b48c36d4a1e5d7f5b1dec6cac0dedd09b9b45e8a..0e7f1b7855cb71cdbabd263ce3ee549388bb372a 100644 (file)
@@ -34,7 +34,7 @@
                                          // _Iter_base
 #include <bits/cpp_type_traits.h>        // for __is_integer
 #include <bits/move.h>                    // for __addressof and addressof
-# include <bits/stl_function.h>                  // for less
+#include <bits/stl_function.h>           // for less
 #if __cplusplus >= 201103L
 # include <type_traits>                          // for is_lvalue_reference and __and_
 #endif
@@ -252,8 +252,16 @@ namespace __gnu_debug
                            const _InputIterator& __other,
                            const _InputIterator& __other_end)
     {
-      return __foreign_iterator_aux3(__it, __other, __other_end,
-                                    _Is_contiguous_sequence<_Sequence>());
+#if __cplusplus < 201103L
+      typedef _Is_contiguous_sequence<_Sequence> __tag;
+#else
+      using __lvalref = std::is_lvalue_reference<
+       typename std::iterator_traits<_InputIterator>::reference>;
+      using __contiguous = _Is_contiguous_sequence<_Sequence>;
+      using __tag = typename std::conditional<__lvalref::value, __contiguous,
+                                             std::__false_type>::type;
+#endif
+      return __foreign_iterator_aux3(__it, __other, __other_end, __tag());
     }
 
   /* Handle the case where we aren't really inserting a range after all */
diff --git a/libstdc++-v3/testsuite/23_containers/vector/63500.cc b/libstdc++-v3/testsuite/23_containers/vector/63500.cc
new file mode 100644 (file)
index 0000000..99fc9f4
--- /dev/null
@@ -0,0 +1,39 @@
+// -*- C++ -*-
+
+// 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/>.
+
+// { dg-options "-std=gnu++11" }
+// { dg-do compile }
+
+#include <memory>
+#include <iterator>
+#include <debug/vector>
+
+class Foo
+{};
+
+void
+test01()
+{
+  __gnu_debug::vector<std::unique_ptr<Foo>> v;
+  __gnu_debug::vector<std::unique_ptr<Foo>> w;
+
+  v.insert(end(v),
+          make_move_iterator(begin(w)),
+          make_move_iterator(end(w)));
+}