forked from OSchip/llvm-project
parent
dd13be0bcc
commit
3fc456d826
|
@ -7,6 +7,8 @@
|
||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// UNSUPPORTED: c++98, c++03, c++11
|
||||||
|
|
||||||
// dynarray.cons
|
// dynarray.cons
|
||||||
|
|
||||||
// explicit dynarray(size_type c);
|
// explicit dynarray(size_type c);
|
||||||
|
@ -17,21 +19,20 @@
|
||||||
// ~dynarray();
|
// ~dynarray();
|
||||||
|
|
||||||
|
|
||||||
#include <__config>
|
|
||||||
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
|
||||||
|
|
||||||
#include <experimental/dynarray>
|
#include <experimental/dynarray>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <complex>
|
#include <complex>
|
||||||
|
#include <limits>
|
||||||
|
#include <new>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
|
||||||
using std::experimental::dynarray;
|
using std::experimental::dynarray;
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void test ( const std::initializer_list<T> &vals ) {
|
void testInitList( const std::initializer_list<T> &vals ) {
|
||||||
typedef dynarray<T> dynA;
|
typedef dynarray<T> dynA;
|
||||||
|
|
||||||
dynA d1 ( vals );
|
dynA d1 ( vals );
|
||||||
|
@ -41,12 +42,14 @@ void test ( const std::initializer_list<T> &vals ) {
|
||||||
|
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void test ( const T &val ) {
|
void test ( const T &val, bool DefaultValueIsIndeterminate = false) {
|
||||||
typedef dynarray<T> dynA;
|
typedef dynarray<T> dynA;
|
||||||
|
|
||||||
dynA d1 ( 4 );
|
dynA d1 ( 4 );
|
||||||
assert ( d1.size () == 4 );
|
assert ( d1.size () == 4 );
|
||||||
|
if (!DefaultValueIsIndeterminate) {
|
||||||
assert ( std::all_of ( d1.begin (), d1.end (), []( const T &item ){ return item == T(); } ));
|
assert ( std::all_of ( d1.begin (), d1.end (), []( const T &item ){ return item == T(); } ));
|
||||||
|
}
|
||||||
|
|
||||||
dynA d2 ( 7, val );
|
dynA d2 ( 7, val );
|
||||||
assert ( d2.size () == 7 );
|
assert ( d2.size () == 7 );
|
||||||
|
@ -60,26 +63,22 @@ void test ( const T &val ) {
|
||||||
void test_bad_length () {
|
void test_bad_length () {
|
||||||
try { dynarray<int> ( std::numeric_limits<size_t>::max() / sizeof ( int ) + 1 ); }
|
try { dynarray<int> ( std::numeric_limits<size_t>::max() / sizeof ( int ) + 1 ); }
|
||||||
catch ( std::bad_array_length & ) { return ; }
|
catch ( std::bad_array_length & ) { return ; }
|
||||||
|
catch (...) { assert(false); }
|
||||||
assert ( false );
|
assert ( false );
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_bad_alloc () {
|
|
||||||
try { dynarray<int> ( std::numeric_limits<size_t>::max() / sizeof ( int ) - 1 ); }
|
|
||||||
catch ( std::bad_alloc & ) { return ; }
|
|
||||||
assert ( false );
|
|
||||||
}
|
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
// test<int> ( 14 ); // ints don't get default initialized
|
test<int> ( 14, /* DefaultValueIsIndeterminate */ true ); // ints don't get default initialized
|
||||||
test<long> ( 0 );
|
test<long> ( 0, true);
|
||||||
test<double> ( 14.0 );
|
test<double> ( 14.0, true );
|
||||||
test<std::complex<double>> ( std::complex<double> ( 14, 0 ));
|
test<std::complex<double>> ( std::complex<double> ( 14, 0 ));
|
||||||
test<std::string> ( "fourteen" );
|
test<std::string> ( "fourteen" );
|
||||||
|
|
||||||
test ( { 1, 1, 2, 3, 5, 8 } );
|
testInitList( { 1, 1, 2, 3, 5, 8 } );
|
||||||
test ( { 1., 1., 2., 3., 5., 8. } );
|
testInitList( { 1., 1., 2., 3., 5., 8. } );
|
||||||
test ( { std::string("1"), std::string("1"), std::string("2"), std::string("3"),
|
testInitList( { std::string("1"), std::string("1"), std::string("2"), std::string("3"),
|
||||||
std::string("5"), std::string("8")} );
|
std::string("5"), std::string("8")} );
|
||||||
|
|
||||||
// Make sure we don't pick up the Allocator version here
|
// Make sure we don't pick up the Allocator version here
|
||||||
|
@ -88,8 +87,4 @@ int main()
|
||||||
assert ( std::all_of ( d1.begin (), d1.end (), []( long item ){ return item == 3L; } ));
|
assert ( std::all_of ( d1.begin (), d1.end (), []( long item ){ return item == 3L; } ));
|
||||||
|
|
||||||
test_bad_length ();
|
test_bad_length ();
|
||||||
test_bad_alloc ();
|
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
int main() {}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// dynarray.cons
|
||||||
|
|
||||||
|
// explicit dynarray(size_type c);
|
||||||
|
|
||||||
|
// UNSUPPORTED: c++98, c++03, c++11
|
||||||
|
|
||||||
|
// The sanitizers replace new/delete with versions that do not throw bad_alloc.
|
||||||
|
// UNSUPPORTED: sanitizer-new-delete, ubsan
|
||||||
|
|
||||||
|
|
||||||
|
#include <experimental/dynarray>
|
||||||
|
#include <limits>
|
||||||
|
#include <new>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
|
||||||
|
using std::experimental::dynarray;
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
try { dynarray<int>((std::numeric_limits<size_t>::max() / sizeof(int)) - 1); }
|
||||||
|
catch (std::bad_alloc &) { return 0; }
|
||||||
|
catch (...) { assert(false); }
|
||||||
|
assert(false);
|
||||||
|
}
|
Loading…
Reference in New Issue