vector_copy_no_alloc.patch [plain text]
#rdar://problem/6473222 copy-constructing a std::vector from an empty std::vector calls malloc
diff -upr libstdc++-v3/include/bits/stl_vector.h libstdc++-v3/include/bits/stl_vector.h
--- libstdc++-v3/include/bits/stl_vector.h 2009-01-06 17:33:39.000000000 -0500
+++ libstdc++-v3/include/bits/stl_vector.h 2006-09-20 20:11:52.000000000 -0400
@@ -111,9 +111,12 @@ _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GL
_Vector_base(size_t __n, const allocator_type& __a)
: _M_impl(__a)
{
- this->_M_impl._M_start = this->_M_allocate(__n);
- this->_M_impl._M_finish = this->_M_impl._M_start;
- this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __n;
+ if (__n)
+ {
+ this->_M_impl._M_start = this->_M_allocate(__n);
+ this->_M_impl._M_finish = this->_M_impl._M_start;
+ this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __n;
+ }
}
~_Vector_base()
--- /dev/null 2009-01-06 17:44:13.000000000 -0500
+++ libstdc++-v3/testsuite/23_containers/vector/cons/copy_no_alloc.cc 2009-01-06 17:39:50.000000000 -0500
@@ -0,0 +1,37 @@
+// 2009-01-06 Howard Hinnant
+
+// Copyright (C) 2009
+// 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 2, 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 COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+
+// vector copy construction of zero-sized vector should not allocate
+
+#include <vector>
+#include <new>
+
+void* operator new(std::size_t size) throw(std::bad_alloc)
+{
+ throw std::bad_alloc();
+ void* p = 0;
+ return p;
+}
+
+int main() {
+ std::vector<int> X;
+ std::vector<int> Y(X);
+}