2007-06-26 17:58:45 +02:00
|
|
|
// -*- C++ -*-
|
2016-04-29 18:11:43 +02:00
|
|
|
// Exception testing utils for the C++ library testsuite.
|
2007-06-26 17:58:45 +02:00
|
|
|
//
|
2021-01-04 10:26:59 +01:00
|
|
|
// Copyright (C) 2007-2021 Free Software Foundation, Inc.
|
2007-06-26 17:58:45 +02:00
|
|
|
//
|
|
|
|
// 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
|
2009-04-09 17:00:19 +02:00
|
|
|
// Free Software Foundation; either version 3, or (at your option)
|
2007-06-26 17:58:45 +02:00
|
|
|
// 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
|
2009-04-09 17:00:19 +02:00
|
|
|
// with this library; see the file COPYING3. If not see
|
|
|
|
// <http://www.gnu.org/licenses/>.
|
2007-06-26 17:58:45 +02:00
|
|
|
//
|
|
|
|
|
2007-10-06 05:06:37 +02:00
|
|
|
#include <exception>
|
2007-06-26 17:58:45 +02:00
|
|
|
#include <testsuite_hooks.h>
|
|
|
|
|
2007-09-26 19:04:06 +02:00
|
|
|
#ifndef _TESTSUITE_API
|
|
|
|
#define _TESTSUITE_API 1
|
2007-06-26 17:58:45 +02:00
|
|
|
|
|
|
|
namespace __gnu_test
|
|
|
|
{
|
|
|
|
// Checks for virtual public derivation in exception classes.
|
|
|
|
// See:
|
|
|
|
// http://www.boost.org/more/error_handling.html
|
|
|
|
struct bad_non_virtual : virtual public std::exception { };
|
|
|
|
|
|
|
|
template<typename Exception, bool DefaultCons>
|
|
|
|
struct diamond_derivation_base;
|
|
|
|
|
|
|
|
template<typename Exception>
|
|
|
|
struct diamond_derivation_base<Exception, true>
|
|
|
|
{
|
2008-08-05 22:39:48 +02:00
|
|
|
struct diamond_derivation_error
|
|
|
|
: bad_non_virtual, Exception
|
2007-06-26 17:58:45 +02:00
|
|
|
{
|
2008-08-05 22:39:48 +02:00
|
|
|
diamond_derivation_error()
|
|
|
|
: bad_non_virtual(), Exception() { }
|
2007-06-26 17:58:45 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename Exception>
|
|
|
|
struct diamond_derivation_base<Exception, false>
|
|
|
|
{
|
2008-08-05 22:39:48 +02:00
|
|
|
struct diamond_derivation_error
|
|
|
|
: bad_non_virtual, Exception
|
2007-06-26 17:58:45 +02:00
|
|
|
{
|
|
|
|
diamond_derivation_error()
|
|
|
|
: bad_non_virtual(), Exception("construct diamond") { }
|
|
|
|
};
|
|
|
|
};
|
2016-04-29 18:11:43 +02:00
|
|
|
|
2007-06-26 17:58:45 +02:00
|
|
|
template<typename Exception, bool DefaultCons>
|
2008-08-05 22:39:48 +02:00
|
|
|
struct diamond_derivation
|
|
|
|
: diamond_derivation_base<Exception, DefaultCons>
|
2007-06-26 17:58:45 +02:00
|
|
|
{
|
|
|
|
typedef diamond_derivation_base<Exception, DefaultCons> base_type;
|
|
|
|
typedef typename base_type::diamond_derivation_error error_type;
|
2008-08-05 22:39:48 +02:00
|
|
|
|
|
|
|
// NB: In the libstdc++-v3 testsuite, all the standard exception
|
|
|
|
// classes (+ a couple of extensions) are checked: since they
|
|
|
|
// all derive *non* virtually from std::exception, the expected
|
|
|
|
// behavior is ambiguity.
|
2007-06-26 17:58:45 +02:00
|
|
|
static void test()
|
|
|
|
{
|
2008-08-05 22:39:48 +02:00
|
|
|
try
|
|
|
|
{ throw error_type(); }
|
|
|
|
catch (std::exception const&)
|
2007-06-26 17:58:45 +02:00
|
|
|
{ VERIFY( false ); }
|
2016-04-29 18:11:43 +02:00
|
|
|
catch (...)
|
2008-08-05 22:39:48 +02:00
|
|
|
{ VERIFY( true ); }
|
2007-06-26 17:58:45 +02:00
|
|
|
}
|
|
|
|
};
|
2007-09-26 19:04:06 +02:00
|
|
|
|
|
|
|
// Testing type requirements for template arguments.
|
|
|
|
struct NonDefaultConstructible
|
|
|
|
{
|
|
|
|
NonDefaultConstructible(int) { }
|
|
|
|
NonDefaultConstructible(const NonDefaultConstructible&) { }
|
2008-06-27 12:47:27 +02:00
|
|
|
|
2012-11-10 18:27:22 +01:00
|
|
|
#if __cplusplus >= 201103L
|
2020-10-29 23:47:21 +01:00
|
|
|
NonDefaultConstructible&
|
|
|
|
operator=(const NonDefaultConstructible&) = default;
|
|
|
|
|
2008-06-27 12:47:27 +02:00
|
|
|
// For std::iota.
|
|
|
|
NonDefaultConstructible&
|
|
|
|
operator++()
|
|
|
|
{ return *this; }
|
|
|
|
#endif
|
2007-09-26 19:04:06 +02:00
|
|
|
};
|
2016-04-29 18:11:43 +02:00
|
|
|
|
2007-09-26 19:04:06 +02:00
|
|
|
// See: 20.1.1 Template argument requirements.
|
|
|
|
inline bool
|
|
|
|
operator==(const NonDefaultConstructible&, const NonDefaultConstructible&)
|
|
|
|
{ return false; }
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
operator<(const NonDefaultConstructible&, const NonDefaultConstructible&)
|
|
|
|
{ return false; }
|
|
|
|
|
2009-11-19 17:55:25 +01:00
|
|
|
// For 23 unordered_* requirements.
|
|
|
|
struct NonDefaultConstructible_hash
|
|
|
|
{
|
re PR libstdc++/32618 (std::vector calls uneccessary constructors instead of inplace construction of first object)
2010-06-18 Paolo Carlini <paolo.carlini@oracle.com>
PR libstdc++/32618
* include/bits/stl_list.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(list<>::list(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/list.tcc (list<>::resize, _M_default_append): Define.
* include/bits/stl_vector.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(vector<>::vector(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/vector.tcc (vector<>::_M_default_append): Define.
* include/bits/stl_deque.h (deque<>::_M_default_initialize,
_M_default_append): Declare.
(deque<>::deque(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/deque.tcc (deque<>::_M_default_append): Define.
* include/debug/vector: Update.
* include/debug/deque: Likewise.
* include/debug/list: Likewise.
* include/profile/vector: Likewise.
* include/profile/deque: Likewise.
* include/profile/list: Likewise.
* include/bits/forward_list.h (_M_default_initialize,
_M_default_insert_after): Declare.
(forward_list<>::forward_list(size_type), resize(size_type)): Fix,
use the latter.
* include/bits/forward_list.tcc (forward_list<>::_M_default_append,
_M_default_insert_after): Define.
* testsuite/util/testsuite_api.h (NonCopyConstructible): Add.
* testsuite/23_containers/forward_list/modifiers/6.cc: Move to...
* testsuite/23_containers/forward_list/capacity/resize_size.cc:
... here.
* testsuite/23_containers/forward_list/cons/10.cc: Move to...
* testsuite/23_containers/forward_list/cons/cons_size.cc: ... here.
* testsuite/23_containers/vector/resize/1.cc: Move to...
* testsuite/23_containers/vector/capacity/resize/1.cc: ... here.
* testsuite/23_containers/vector/resize/moveable.cc: Move to...
* testsuite/23_containers/vector/resize/capacity/moveable.cc: ... here.
* testsuite/23_containers/vector/cons/cons_size.cc: New.
* testsuite/23_containers/vector/capacity/resize/resize_size.cc:
Likewise.
* testsuite/23_containers/deque/cons/cons_size.cc: Likewise.
* testsuite/23_containers/deque/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/list/cons/cons_size.cc: Likewise.
* testsuite/23_containers/list/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/vector/capacity/resize/moveable.cc: Adjust.
* testsuite/23_containers/deque/capacity/moveable.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
assign_neg.cc: Adjust dg-error line numbers.
* testsuite/23_containers/forward_list/requirements/dr438/
insert_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/assign_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_2_neg.cc: Likewise.
From-SVN: r161009
2010-06-18 20:07:45 +02:00
|
|
|
std::size_t
|
2009-11-19 17:55:25 +01:00
|
|
|
operator()(NonDefaultConstructible) const
|
|
|
|
{ return 1; }
|
|
|
|
};
|
|
|
|
|
2007-09-26 19:04:06 +02:00
|
|
|
// For 26 numeric algorithms requirements, need addable,
|
|
|
|
// subtractable, multiplicable.
|
|
|
|
inline NonDefaultConstructible
|
2019-05-29 16:45:50 +02:00
|
|
|
operator+(const NonDefaultConstructible&, const NonDefaultConstructible&)
|
2007-09-26 19:04:06 +02:00
|
|
|
{ return NonDefaultConstructible(1); }
|
|
|
|
|
|
|
|
inline NonDefaultConstructible
|
2019-05-29 16:45:50 +02:00
|
|
|
operator-(const NonDefaultConstructible&, const NonDefaultConstructible&)
|
2007-09-26 19:04:06 +02:00
|
|
|
{ return NonDefaultConstructible(1); }
|
|
|
|
|
|
|
|
inline NonDefaultConstructible
|
2019-05-29 16:45:50 +02:00
|
|
|
operator*(const NonDefaultConstructible&, const NonDefaultConstructible&)
|
2007-09-26 19:04:06 +02:00
|
|
|
{ return NonDefaultConstructible(1); }
|
|
|
|
|
|
|
|
// Like unary_function, but takes no argument. (ie, void).
|
|
|
|
// Used for generator template parameter.
|
|
|
|
template<typename _Result>
|
|
|
|
struct void_function
|
|
|
|
{
|
2016-04-29 18:11:43 +02:00
|
|
|
typedef _Result result_type;
|
2007-12-10 17:55:30 +01:00
|
|
|
|
2007-09-26 19:04:06 +02:00
|
|
|
result_type
|
|
|
|
operator()() const
|
2007-12-10 17:55:30 +01:00
|
|
|
{ return result_type(); }
|
2007-09-26 19:04:06 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
template<>
|
|
|
|
struct void_function<NonDefaultConstructible>
|
|
|
|
{
|
2016-04-29 18:11:43 +02:00
|
|
|
typedef NonDefaultConstructible result_type;
|
2007-12-10 17:55:30 +01:00
|
|
|
|
2007-09-26 19:04:06 +02:00
|
|
|
result_type
|
|
|
|
operator()() const
|
|
|
|
{ return result_type(2); }
|
|
|
|
};
|
2010-05-21 00:35:49 +02:00
|
|
|
|
|
|
|
// For std::addressof, etc.
|
|
|
|
struct OverloadedAddressAux { };
|
2016-04-29 18:11:43 +02:00
|
|
|
|
2010-05-21 00:35:49 +02:00
|
|
|
struct OverloadedAddress
|
|
|
|
{
|
|
|
|
OverloadedAddressAux
|
|
|
|
operator&() const { return OverloadedAddressAux(); }
|
|
|
|
};
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
operator<(const OverloadedAddress&, const OverloadedAddress&)
|
|
|
|
{ return false; }
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
operator==(const OverloadedAddress&, const OverloadedAddress&)
|
|
|
|
{ return false; }
|
|
|
|
|
|
|
|
struct OverloadedAddress_hash
|
|
|
|
{
|
re PR libstdc++/32618 (std::vector calls uneccessary constructors instead of inplace construction of first object)
2010-06-18 Paolo Carlini <paolo.carlini@oracle.com>
PR libstdc++/32618
* include/bits/stl_list.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(list<>::list(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/list.tcc (list<>::resize, _M_default_append): Define.
* include/bits/stl_vector.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(vector<>::vector(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/vector.tcc (vector<>::_M_default_append): Define.
* include/bits/stl_deque.h (deque<>::_M_default_initialize,
_M_default_append): Declare.
(deque<>::deque(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/deque.tcc (deque<>::_M_default_append): Define.
* include/debug/vector: Update.
* include/debug/deque: Likewise.
* include/debug/list: Likewise.
* include/profile/vector: Likewise.
* include/profile/deque: Likewise.
* include/profile/list: Likewise.
* include/bits/forward_list.h (_M_default_initialize,
_M_default_insert_after): Declare.
(forward_list<>::forward_list(size_type), resize(size_type)): Fix,
use the latter.
* include/bits/forward_list.tcc (forward_list<>::_M_default_append,
_M_default_insert_after): Define.
* testsuite/util/testsuite_api.h (NonCopyConstructible): Add.
* testsuite/23_containers/forward_list/modifiers/6.cc: Move to...
* testsuite/23_containers/forward_list/capacity/resize_size.cc:
... here.
* testsuite/23_containers/forward_list/cons/10.cc: Move to...
* testsuite/23_containers/forward_list/cons/cons_size.cc: ... here.
* testsuite/23_containers/vector/resize/1.cc: Move to...
* testsuite/23_containers/vector/capacity/resize/1.cc: ... here.
* testsuite/23_containers/vector/resize/moveable.cc: Move to...
* testsuite/23_containers/vector/resize/capacity/moveable.cc: ... here.
* testsuite/23_containers/vector/cons/cons_size.cc: New.
* testsuite/23_containers/vector/capacity/resize/resize_size.cc:
Likewise.
* testsuite/23_containers/deque/cons/cons_size.cc: Likewise.
* testsuite/23_containers/deque/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/list/cons/cons_size.cc: Likewise.
* testsuite/23_containers/list/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/vector/capacity/resize/moveable.cc: Adjust.
* testsuite/23_containers/deque/capacity/moveable.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
assign_neg.cc: Adjust dg-error line numbers.
* testsuite/23_containers/forward_list/requirements/dr438/
insert_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/assign_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_2_neg.cc: Likewise.
From-SVN: r161009
2010-06-18 20:07:45 +02:00
|
|
|
std::size_t
|
2010-05-21 00:35:49 +02:00
|
|
|
operator()(const OverloadedAddress&) const
|
|
|
|
{ return 1; }
|
|
|
|
};
|
re PR libstdc++/32618 (std::vector calls uneccessary constructors instead of inplace construction of first object)
2010-06-18 Paolo Carlini <paolo.carlini@oracle.com>
PR libstdc++/32618
* include/bits/stl_list.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(list<>::list(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/list.tcc (list<>::resize, _M_default_append): Define.
* include/bits/stl_vector.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(vector<>::vector(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/vector.tcc (vector<>::_M_default_append): Define.
* include/bits/stl_deque.h (deque<>::_M_default_initialize,
_M_default_append): Declare.
(deque<>::deque(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/deque.tcc (deque<>::_M_default_append): Define.
* include/debug/vector: Update.
* include/debug/deque: Likewise.
* include/debug/list: Likewise.
* include/profile/vector: Likewise.
* include/profile/deque: Likewise.
* include/profile/list: Likewise.
* include/bits/forward_list.h (_M_default_initialize,
_M_default_insert_after): Declare.
(forward_list<>::forward_list(size_type), resize(size_type)): Fix,
use the latter.
* include/bits/forward_list.tcc (forward_list<>::_M_default_append,
_M_default_insert_after): Define.
* testsuite/util/testsuite_api.h (NonCopyConstructible): Add.
* testsuite/23_containers/forward_list/modifiers/6.cc: Move to...
* testsuite/23_containers/forward_list/capacity/resize_size.cc:
... here.
* testsuite/23_containers/forward_list/cons/10.cc: Move to...
* testsuite/23_containers/forward_list/cons/cons_size.cc: ... here.
* testsuite/23_containers/vector/resize/1.cc: Move to...
* testsuite/23_containers/vector/capacity/resize/1.cc: ... here.
* testsuite/23_containers/vector/resize/moveable.cc: Move to...
* testsuite/23_containers/vector/resize/capacity/moveable.cc: ... here.
* testsuite/23_containers/vector/cons/cons_size.cc: New.
* testsuite/23_containers/vector/capacity/resize/resize_size.cc:
Likewise.
* testsuite/23_containers/deque/cons/cons_size.cc: Likewise.
* testsuite/23_containers/deque/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/list/cons/cons_size.cc: Likewise.
* testsuite/23_containers/list/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/vector/capacity/resize/moveable.cc: Adjust.
* testsuite/23_containers/deque/capacity/moveable.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
assign_neg.cc: Adjust dg-error line numbers.
* testsuite/23_containers/forward_list/requirements/dr438/
insert_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/assign_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_2_neg.cc: Likewise.
From-SVN: r161009
2010-06-18 20:07:45 +02:00
|
|
|
|
2012-11-10 18:27:22 +01:00
|
|
|
#if __cplusplus >= 201103L
|
re PR libstdc++/32618 (std::vector calls uneccessary constructors instead of inplace construction of first object)
2010-06-18 Paolo Carlini <paolo.carlini@oracle.com>
PR libstdc++/32618
* include/bits/stl_list.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(list<>::list(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/list.tcc (list<>::resize, _M_default_append): Define.
* include/bits/stl_vector.h (vector<>::_M_default_initialize,
_M_default_append): Declare.
(vector<>::vector(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/vector.tcc (vector<>::_M_default_append): Define.
* include/bits/stl_deque.h (deque<>::_M_default_initialize,
_M_default_append): Declare.
(deque<>::deque(size_type), resize(size_type)): Add in C++0x mode,
use the latter.
* include/bits/deque.tcc (deque<>::_M_default_append): Define.
* include/debug/vector: Update.
* include/debug/deque: Likewise.
* include/debug/list: Likewise.
* include/profile/vector: Likewise.
* include/profile/deque: Likewise.
* include/profile/list: Likewise.
* include/bits/forward_list.h (_M_default_initialize,
_M_default_insert_after): Declare.
(forward_list<>::forward_list(size_type), resize(size_type)): Fix,
use the latter.
* include/bits/forward_list.tcc (forward_list<>::_M_default_append,
_M_default_insert_after): Define.
* testsuite/util/testsuite_api.h (NonCopyConstructible): Add.
* testsuite/23_containers/forward_list/modifiers/6.cc: Move to...
* testsuite/23_containers/forward_list/capacity/resize_size.cc:
... here.
* testsuite/23_containers/forward_list/cons/10.cc: Move to...
* testsuite/23_containers/forward_list/cons/cons_size.cc: ... here.
* testsuite/23_containers/vector/resize/1.cc: Move to...
* testsuite/23_containers/vector/capacity/resize/1.cc: ... here.
* testsuite/23_containers/vector/resize/moveable.cc: Move to...
* testsuite/23_containers/vector/resize/capacity/moveable.cc: ... here.
* testsuite/23_containers/vector/cons/cons_size.cc: New.
* testsuite/23_containers/vector/capacity/resize/resize_size.cc:
Likewise.
* testsuite/23_containers/deque/cons/cons_size.cc: Likewise.
* testsuite/23_containers/deque/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/list/cons/cons_size.cc: Likewise.
* testsuite/23_containers/list/capacity/resize_size.cc: Likewise.
* testsuite/23_containers/vector/capacity/resize/moveable.cc: Adjust.
* testsuite/23_containers/deque/capacity/moveable.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
assign_neg.cc: Adjust dg-error line numbers.
* testsuite/23_containers/forward_list/requirements/dr438/
insert_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/forward_list/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/vector/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
assign_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/deque/requirements/dr438/
constructor_2_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/assign_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/insert_neg.cc:
Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_1_neg.cc: Likewise.
* testsuite/23_containers/list/requirements/dr438/
constructor_2_neg.cc: Likewise.
From-SVN: r161009
2010-06-18 20:07:45 +02:00
|
|
|
struct NonCopyConstructible
|
|
|
|
{
|
|
|
|
NonCopyConstructible() : num(-1) { }
|
|
|
|
|
|
|
|
NonCopyConstructible(NonCopyConstructible&& other)
|
|
|
|
: num(other.num)
|
|
|
|
{ other.num = 0; }
|
|
|
|
|
|
|
|
NonCopyConstructible(const NonCopyConstructible&) = delete;
|
|
|
|
|
|
|
|
operator int() { return num; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
int num;
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2007-06-26 17:58:45 +02:00
|
|
|
}
|
2009-11-19 17:55:25 +01:00
|
|
|
|
2007-06-26 17:58:45 +02:00
|
|
|
#endif
|