diff options
author | Paolo Carlini <pcarlini@suse.de> | 2003-12-01 15:34:07 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2003-12-01 15:34:07 +0000 |
commit | 9dbaa9489f9671b98caf92c6d1f87589d4eb799d (patch) | |
tree | 5b0afb3841c075eaec8f179b049a6ff4579b5fce | |
parent | ec22cdf1405e694fb9b1c9557e6ef20baa7f7e01 (diff) | |
download | gcc-9dbaa9489f9671b98caf92c6d1f87589d4eb799d.zip gcc-9dbaa9489f9671b98caf92c6d1f87589d4eb799d.tar.gz gcc-9dbaa9489f9671b98caf92c6d1f87589d4eb799d.tar.bz2 |
re PR libstdc++/10378 ([library DR 402] cannot add object with inplace new into STL collections)
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
-rw-r--r-- | libstdc++-v3/ChangeLog | 13 | ||||
-rw-r--r-- | libstdc++-v3/docs/html/ext/howto.html | 6 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/allocator.h | 4 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/allocator_traits.h | 6 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/stl_construct.h | 12 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/20_util/allocator/1.cc (renamed from libstdc++-v3/testsuite/20_util/allocator_members.cc) | 0 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/20_util/allocator/10378.cc | 46 |
7 files changed, 82 insertions, 5 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 4ee7fd7..0a9e672 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -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, diff --git a/libstdc++-v3/docs/html/ext/howto.html b/libstdc++-v3/docs/html/ext/howto.html index 82930a8..c5e3e20 100644 --- a/libstdc++-v3/docs/html/ext/howto.html +++ b/libstdc++-v3/docs/html/ext/howto.html @@ -694,6 +694,12 @@ </dt> <dd>Change the format string to "%.0Lf". </dd> + + <dt><a href="lwg-active.html#402">402</a>: + <em>Wrong new expression in [some_]allocator::construct</em> + </dt> + <dd>Replace "new" with "::new". + </dd> <!-- <dt><a href="lwg-defects.html#"></a>: <em></em> diff --git a/libstdc++-v3/include/bits/allocator.h b/libstdc++-v3/include/bits/allocator.h index 9d01b7e..53d1d35 100644 --- a/libstdc++-v3/include/bits/allocator.h +++ b/libstdc++-v3/include/bits/allocator.h @@ -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(); } diff --git a/libstdc++-v3/include/bits/allocator_traits.h b/libstdc++-v3/include/bits/allocator_traits.h index 35ef1d4..93bae7a 100644 --- a/libstdc++-v3/include/bits/allocator_traits.h +++ b/libstdc++-v3/include/bits/allocator_traits.h @@ -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(); } diff --git a/libstdc++-v3/include/bits/stl_construct.h b/libstdc++-v3/include/bits/stl_construct.h index 0884117..d33bd7d 100644 --- a/libstdc++-v3/include/bits/stl_construct.h +++ b/libstdc++-v3/include/bits/stl_construct.h @@ -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_members.cc b/libstdc++-v3/testsuite/20_util/allocator/1.cc index 4170a9d..4170a9d 100644 --- a/libstdc++-v3/testsuite/20_util/allocator_members.cc +++ b/libstdc++-v3/testsuite/20_util/allocator/1.cc diff --git a/libstdc++-v3/testsuite/20_util/allocator/10378.cc b/libstdc++-v3/testsuite/20_util/allocator/10378.cc new file mode 100644 index 0000000..88193b5 --- /dev/null +++ b/libstdc++-v3/testsuite/20_util/allocator/10378.cc @@ -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; +} |