]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR libstdc++/10378 ([library DR 402] cannot add object with inplace new into STL...
authorPaolo Carlini <pcarlini@suse.de>
Mon, 1 Dec 2003 15:34:07 +0000 (15:34 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Mon, 1 Dec 2003 15:34:07 +0000 (15:34 +0000)
2003-12-01  Paolo Carlini  <pcarlini@suse.de>

PR libstdc++/10378
* include/bits/allocator.h (allocator::construct): Implement
resolution of DR 402 [Ready] (in Revision 28).
* include/bits/allocator_traits.h (__allocator::construct):
Likewise.
* include/bits/stl_construct.h (_Construct): Likewise.
* testsuite/20_util/allocator_members.cc: Move to...
* testsuite/20_util/allocator/1.cc: ... here.
* testsuite/20_util/allocator/10378.cc: New.
* docs/html/ext/howto.html: Add an entry for DR 402.

From-SVN: r74104

libstdc++-v3/ChangeLog
libstdc++-v3/docs/html/ext/howto.html
libstdc++-v3/include/bits/allocator.h
libstdc++-v3/include/bits/allocator_traits.h
libstdc++-v3/include/bits/stl_construct.h
libstdc++-v3/testsuite/20_util/allocator/1.cc [moved from libstdc++-v3/testsuite/20_util/allocator_members.cc with 100% similarity]
libstdc++-v3/testsuite/20_util/allocator/10378.cc [new file with mode: 0644]

index 4ee7fd7967be986ca0e5b15063391cc253cdf94b..0a9e6729f93bb07e855d4e3e8eccf3fcdf40d670 100644 (file)
@@ -1,3 +1,16 @@
+2003-12-01  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/10378
+       * include/bits/allocator.h (allocator::construct): Implement
+       resolution of DR 402 [Ready] (in Revision 28).
+       * include/bits/allocator_traits.h (__allocator::construct):
+       Likewise.
+       * include/bits/stl_construct.h (_Construct): Likewise.
+       * testsuite/20_util/allocator_members.cc: Move to...
+       * testsuite/20_util/allocator/1.cc: ... here.
+       * testsuite/20_util/allocator/10378.cc: New.
+       * docs/html/ext/howto.html: Add an entry for DR 402.
+
 2003-11-30  Paolo Carlini  <pcarlini@suse.de>
 
        * config/locale/gnu/codecvt_members.cc (codecvt::do_in,
index 82930a80e9fe7d67c3b17e778dab001998a92f2e..c5e3e20d08c55497c337129d98b8aeef455ffbb7 100644 (file)
     </dt>
     <dd>Change the format string to &quot;%.0Lf&quot;.
     </dd>
+
+    <dt><a href="lwg-active.html#402">402</a>:
+        <em>Wrong new expression in [some_]allocator::construct</em>
+    </dt>
+    <dd>Replace &quot;new&quot; with &quot;::new&quot;.
+    </dd>
 <!--
     <dt><a href="lwg-defects.html#"></a>:
         <em></em>
index 9d01b7e292e797feadd5c72bb141af582b1a57cf..53d1d351f08ae3003993b2e7e3a5608b10e02303 100644 (file)
@@ -172,8 +172,10 @@ namespace std
       size_type
       max_size() const throw() { return size_t(-1) / sizeof(_Tp); }
 
+      // _GLIBCXX_RESOLVE_LIB_DEFECTS
+      // 402. wrong new expression in [some_]allocator::construct
       void 
-      construct(pointer __p, const _Tp& __val) { new(__p) _Tp(__val); }
+      construct(pointer __p, const _Tp& __val) { ::new(__p) _Tp(__val); }
 
       void 
       destroy(pointer __p) { __p->~_Tp(); }
index 35ef1d4ebb94ceea30513c62c509a6669bf8c486..93bae7a2d44236131b892e58ca403e59c6f9fc26 100644 (file)
@@ -149,9 +149,11 @@ namespace std
       
       size_type
       max_size() const throw() { return size_t(-1) / sizeof(_Tp); }
-      
+
+      // _GLIBCXX_RESOLVE_LIB_DEFECTS
+      // 402. wrong new expression in [some_]allocator::construct
       void
-      construct(pointer __p, const _Tp& __val) { new(__p) _Tp(__val); }
+      construct(pointer __p, const _Tp& __val) { ::new(__p) _Tp(__val); }
       
       void
       destroy(pointer __p) { __p->~_Tp(); }
index 08841174f07c290df2eb5943ad5fffea413cec56..d33bd7d749dde04adad6dedebac9d1282655d264 100644 (file)
@@ -75,7 +75,11 @@ namespace std
   template <class _T1, class _T2>
     inline void
     _Construct(_T1* __p, const _T2& __value)
-    { new (static_cast<void*>(__p)) _T1(__value); }
+    {
+      // _GLIBCXX_RESOLVE_LIB_DEFECTS
+      // 402. wrong new expression in [some_]allocator::construct
+      ::new (static_cast<void*>(__p)) _T1(__value); 
+    }
   
   /**
    * @if maint
@@ -86,7 +90,11 @@ namespace std
   template <class _T1>
     inline void
     _Construct(_T1* __p)
-    { new (static_cast<void*>(__p)) _T1(); }
+    {
+      // _GLIBCXX_RESOLVE_LIB_DEFECTS
+      // 402. wrong new expression in [some_]allocator::construct     
+      ::new (static_cast<void*>(__p)) _T1();
+    }
 
   /**
    * @if maint
diff --git a/libstdc++-v3/testsuite/20_util/allocator/10378.cc b/libstdc++-v3/testsuite/20_util/allocator/10378.cc
new file mode 100644 (file)
index 0000000..88193b5
--- /dev/null
@@ -0,0 +1,46 @@
+// Copyright (C) 2003 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, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 20.1.5 allocator requirements / 20.4.1.1 allocator members
+
+#include <list>
+#include <cstdlib>
+#include <testsuite_hooks.h>
+
+class Bob
+{
+public:
+  static void* operator new(size_t sz)
+  { return std::malloc(sz); }
+};
+
+// libstdc++/10378
+void test01()
+{
+  using namespace std;
+  bool test __attribute__((unused)) = true;
+
+  list<Bob> uniset;
+  uniset.push_back(Bob());
+}
+
+int main()
+{
+  test01();
+  return 0;
+}