type_traits (has_trivial_copy, [...]): Adjust according to the resolution of TR1 issue 3.21.
2005-04-27 Paolo Carlini <pcarlini@suse.de> * include/tr1/type_traits (has_trivial_copy, has_trivial_assign, has_nothrow_copy, has_nothrow_assign): Adjust according to the resolution of TR1 issue 3.21. * testsuite/testsuite_tr1.h (test_copy_property, test_assign_property): Remove. * testsuite/tr1/4_metaprogramming/type_properties/ has_nothrow_assign/has_nothrow_assign.cc: Adjust. * testsuite/tr1/4_metaprogramming/type_properties/ has_nothrow_copy/has_nothrow_copy.cc: Likewise. * testsuite/tr1/4_metaprogramming/type_properties/ has_trivial_assign/has_trivial_assign.cc: Likewise. * testsuite/tr1/4_metaprogramming/type_properties/ has_trivial_copy/has_trivial_copy.cc: Likewise. From-SVN: r98829
This commit is contained in:
parent
e3cc72542b
commit
4e5362a2a3
@ -1,3 +1,19 @@
|
|||||||
|
2005-04-27 Paolo Carlini <pcarlini@suse.de>
|
||||||
|
|
||||||
|
* include/tr1/type_traits (has_trivial_copy, has_trivial_assign,
|
||||||
|
has_nothrow_copy, has_nothrow_assign): Adjust according to the
|
||||||
|
resolution of TR1 issue 3.21.
|
||||||
|
* testsuite/testsuite_tr1.h (test_copy_property,
|
||||||
|
test_assign_property): Remove.
|
||||||
|
* testsuite/tr1/4_metaprogramming/type_properties/
|
||||||
|
has_nothrow_assign/has_nothrow_assign.cc: Adjust.
|
||||||
|
* testsuite/tr1/4_metaprogramming/type_properties/
|
||||||
|
has_nothrow_copy/has_nothrow_copy.cc: Likewise.
|
||||||
|
* testsuite/tr1/4_metaprogramming/type_properties/
|
||||||
|
has_trivial_assign/has_trivial_assign.cc: Likewise.
|
||||||
|
* testsuite/tr1/4_metaprogramming/type_properties/
|
||||||
|
has_trivial_copy/has_trivial_copy.cc: Likewise.
|
||||||
|
|
||||||
2005-04-26 Jones Desougi <jones@ingate.com>
|
2005-04-26 Jones Desougi <jones@ingate.com>
|
||||||
|
|
||||||
PR libstdc++/21131
|
PR libstdc++/21131
|
||||||
|
@ -366,14 +366,11 @@ namespace tr1
|
|||||||
|
|
||||||
template<typename _Tp>
|
template<typename _Tp>
|
||||||
struct has_trivial_copy
|
struct has_trivial_copy
|
||||||
: public integral_constant<bool, (is_pod<_Tp>::value
|
: public integral_constant<bool, is_pod<_Tp>::value> { };
|
||||||
&& !is_volatile<_Tp>::value)> { };
|
|
||||||
|
|
||||||
template<typename _Tp>
|
template<typename _Tp>
|
||||||
struct has_trivial_assign
|
struct has_trivial_assign
|
||||||
: public integral_constant<bool, (is_pod<_Tp>::value
|
: public integral_constant<bool, is_pod<_Tp>::value> { };
|
||||||
&& !is_const<_Tp>::value
|
|
||||||
&& !is_volatile<_Tp>::value)> { };
|
|
||||||
|
|
||||||
template<typename _Tp>
|
template<typename _Tp>
|
||||||
struct has_trivial_destructor
|
struct has_trivial_destructor
|
||||||
@ -385,14 +382,11 @@ namespace tr1
|
|||||||
|
|
||||||
template<typename _Tp>
|
template<typename _Tp>
|
||||||
struct has_nothrow_copy
|
struct has_nothrow_copy
|
||||||
: public integral_constant<bool, (is_pod<_Tp>::value
|
: public integral_constant<bool, is_pod<_Tp>::value> { };
|
||||||
&& !is_volatile<_Tp>::value)> { };
|
|
||||||
|
|
||||||
template<typename _Tp>
|
template<typename _Tp>
|
||||||
struct has_nothrow_assign
|
struct has_nothrow_assign
|
||||||
: public integral_constant<bool, (is_pod<_Tp>::value
|
: public integral_constant<bool, is_pod<_Tp>::value> { };
|
||||||
&& !is_const<_Tp>::value
|
|
||||||
&& !is_volatile<_Tp>::value)> { };
|
|
||||||
|
|
||||||
template<typename>
|
template<typename>
|
||||||
struct has_virtual_destructor
|
struct has_virtual_destructor
|
||||||
|
@ -62,40 +62,6 @@ namespace __gnu_test
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<template<typename> class Property,
|
|
||||||
typename Type>
|
|
||||||
bool
|
|
||||||
test_copy_property(bool value)
|
|
||||||
{
|
|
||||||
bool ret = true;
|
|
||||||
ret &= Property<Type>::value == value;
|
|
||||||
ret &= Property<const Type>::value == value;
|
|
||||||
ret &= Property<volatile Type>::value == !value;
|
|
||||||
ret &= Property<const volatile Type>::value == !value;
|
|
||||||
ret &= Property<Type>::type::value == value;
|
|
||||||
ret &= Property<const Type>::type::value == value;
|
|
||||||
ret &= Property<volatile Type>::type::value == !value;
|
|
||||||
ret &= Property<const volatile Type>::type::value == !value;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<template<typename> class Property,
|
|
||||||
typename Type>
|
|
||||||
bool
|
|
||||||
test_assign_property(bool value)
|
|
||||||
{
|
|
||||||
bool ret = true;
|
|
||||||
ret &= Property<Type>::value == value;
|
|
||||||
ret &= Property<const Type>::value == !value;
|
|
||||||
ret &= Property<volatile Type>::value == !value;
|
|
||||||
ret &= Property<const volatile Type>::value == !value;
|
|
||||||
ret &= Property<Type>::type::value == value;
|
|
||||||
ret &= Property<const Type>::type::value == !value;
|
|
||||||
ret &= Property<volatile Type>::type::value == !value;
|
|
||||||
ret &= Property<const volatile Type>::type::value == !value;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<template<typename, typename> class Relationship,
|
template<template<typename, typename> class Relationship,
|
||||||
typename Type1, typename Type2>
|
typename Type1, typename Type2>
|
||||||
bool
|
bool
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
||||||
//
|
//
|
||||||
// Copyright (C) 2004 Free Software Foundation, Inc.
|
// Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
||||||
//
|
//
|
||||||
// This file is part of the GNU ISO C++ Library. This library is free
|
// 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
|
// software; you can redistribute it and/or modify it under the
|
||||||
@ -30,23 +30,21 @@ void test01()
|
|||||||
using std::tr1::has_nothrow_assign;
|
using std::tr1::has_nothrow_assign;
|
||||||
using namespace __gnu_test;
|
using namespace __gnu_test;
|
||||||
|
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, void>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, void>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, float>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, float>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, EnumType>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, EnumType>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int*>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int*>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int(*)(int)>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int(*)(int)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int (ClassType::*)>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int (ClassType::*)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign,
|
VERIFY( (test_category<has_nothrow_assign, int (ClassType::*) (int)>(true)) );
|
||||||
int (ClassType::*) (int)>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int[2]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int[2]>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, float[][3]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, float[][3]>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, EnumType[2][3][4]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, EnumType[2][3][4]>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int*[3]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int*[3]>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int(*[][2])(int)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign, int(*[][2])(int)>(true)) );
|
VERIFY( (test_category<has_nothrow_assign, int (ClassType::*[2][3])>(true)) );
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign,
|
VERIFY( (test_category<has_nothrow_assign,
|
||||||
int (ClassType::*[2][3])>(true)) );
|
|
||||||
VERIFY( (test_assign_property<has_nothrow_assign,
|
|
||||||
int (ClassType::*[][2][3]) (int)>(true)) );
|
int (ClassType::*[][2][3]) (int)>(true)) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
||||||
//
|
//
|
||||||
// Copyright (C) 2004 Free Software Foundation, Inc.
|
// Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
||||||
//
|
//
|
||||||
// This file is part of the GNU ISO C++ Library. This library is free
|
// 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
|
// software; you can redistribute it and/or modify it under the
|
||||||
@ -30,23 +30,21 @@ void test01()
|
|||||||
using std::tr1::has_nothrow_copy;
|
using std::tr1::has_nothrow_copy;
|
||||||
using namespace __gnu_test;
|
using namespace __gnu_test;
|
||||||
|
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, void>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, void>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, float>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, float>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, EnumType>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, EnumType>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int*>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int*>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int(*)(int)>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int(*)(int)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int (ClassType::*)>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int (ClassType::*)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy,
|
VERIFY( (test_category<has_nothrow_copy, int (ClassType::*) (int)>(true)) );
|
||||||
int (ClassType::*) (int)>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int[2]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int[2]>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, float[][3]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, float[][3]>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, EnumType[2][3][4]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, EnumType[2][3][4]>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int*[3]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int*[3]>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int(*[][2])(int)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy, int(*[][2])(int)>(true)) );
|
VERIFY( (test_category<has_nothrow_copy, int (ClassType::*[2][3])>(true)) );
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy,
|
VERIFY( (test_category<has_nothrow_copy,
|
||||||
int (ClassType::*[2][3])>(true)) );
|
|
||||||
VERIFY( (test_copy_property<has_nothrow_copy,
|
|
||||||
int (ClassType::*[][2][3]) (int)>(true)) );
|
int (ClassType::*[][2][3]) (int)>(true)) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
||||||
//
|
//
|
||||||
// Copyright (C) 2004 Free Software Foundation, Inc.
|
// Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
||||||
//
|
//
|
||||||
// This file is part of the GNU ISO C++ Library. This library is free
|
// 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
|
// software; you can redistribute it and/or modify it under the
|
||||||
@ -30,23 +30,21 @@ void test01()
|
|||||||
using std::tr1::has_trivial_assign;
|
using std::tr1::has_trivial_assign;
|
||||||
using namespace __gnu_test;
|
using namespace __gnu_test;
|
||||||
|
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, void>(true)) );
|
VERIFY( (test_category<has_trivial_assign, void>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, float>(true)) );
|
VERIFY( (test_category<has_trivial_assign, float>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, EnumType>(true)) );
|
VERIFY( (test_category<has_trivial_assign, EnumType>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int*>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int*>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int(*)(int)>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int(*)(int)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int (ClassType::*)>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int (ClassType::*)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign,
|
VERIFY( (test_category<has_trivial_assign, int (ClassType::*) (int)>(true)) );
|
||||||
int (ClassType::*) (int)>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int[2]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int[2]>(true)) );
|
VERIFY( (test_category<has_trivial_assign, float[][3]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, float[][3]>(true)) );
|
VERIFY( (test_category<has_trivial_assign, EnumType[2][3][4]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, EnumType[2][3][4]>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int*[3]>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int*[3]>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int(*[][2])(int)>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign, int(*[][2])(int)>(true)) );
|
VERIFY( (test_category<has_trivial_assign, int (ClassType::*[2][3])>(true)) );
|
||||||
VERIFY( (test_assign_property<has_trivial_assign,
|
VERIFY( (test_category<has_trivial_assign,
|
||||||
int (ClassType::*[2][3])>(true)) );
|
|
||||||
VERIFY( (test_assign_property<has_trivial_assign,
|
|
||||||
int (ClassType::*[][2][3]) (int)>(true)) );
|
int (ClassType::*[][2][3]) (int)>(true)) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
// 2004-12-30 Paolo Carlini <pcarlini@suse.de>
|
||||||
//
|
//
|
||||||
// Copyright (C) 2004 Free Software Foundation, Inc.
|
// Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
||||||
//
|
//
|
||||||
// This file is part of the GNU ISO C++ Library. This library is free
|
// 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
|
// software; you can redistribute it and/or modify it under the
|
||||||
@ -30,23 +30,21 @@ void test01()
|
|||||||
using std::tr1::has_trivial_copy;
|
using std::tr1::has_trivial_copy;
|
||||||
using namespace __gnu_test;
|
using namespace __gnu_test;
|
||||||
|
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, void>(true)) );
|
VERIFY( (test_category<has_trivial_copy, void>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, float>(true)) );
|
VERIFY( (test_category<has_trivial_copy, float>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, EnumType>(true)) );
|
VERIFY( (test_category<has_trivial_copy, EnumType>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int*>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int*>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int(*)(int)>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int(*)(int)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int (ClassType::*)>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int (ClassType::*)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy,
|
VERIFY( (test_category<has_trivial_copy, int (ClassType::*) (int)>(true)) );
|
||||||
int (ClassType::*) (int)>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int[2]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int[2]>(true)) );
|
VERIFY( (test_category<has_trivial_copy, float[][3]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, float[][3]>(true)) );
|
VERIFY( (test_category<has_trivial_copy, EnumType[2][3][4]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, EnumType[2][3][4]>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int*[3]>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int*[3]>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int(*[][2])(int)>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy, int(*[][2])(int)>(true)) );
|
VERIFY( (test_category<has_trivial_copy, int (ClassType::*[2][3])>(true)) );
|
||||||
VERIFY( (test_copy_property<has_trivial_copy,
|
VERIFY( (test_category<has_trivial_copy,
|
||||||
int (ClassType::*[2][3])>(true)) );
|
|
||||||
VERIFY( (test_copy_property<has_trivial_copy,
|
|
||||||
int (ClassType::*[][2][3]) (int)>(true)) );
|
int (ClassType::*[][2][3]) (int)>(true)) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user