Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/llvm/llvm-project.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'libcxxabi/test/test_vector1.cpp')
-rw-r--r--libcxxabi/test/test_vector1.cpp262
1 files changed, 0 insertions, 262 deletions
diff --git a/libcxxabi/test/test_vector1.cpp b/libcxxabi/test/test_vector1.cpp
deleted file mode 100644
index b8bf45c50c27..000000000000
--- a/libcxxabi/test/test_vector1.cpp
+++ /dev/null
@@ -1,262 +0,0 @@
-//===---------------------------- test_vector.cpp -------------------------===//
-//
-// 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.
-//
-//===----------------------------------------------------------------------===//
-
-#include "cxxabi.h"
-
-#include <iostream>
-#include <cstdlib>
-
-// Wrapper routines
-void *my_alloc2 ( size_t sz ) {
- void *p = std::malloc ( sz );
-// std::printf ( "Allocated %ld bytes at %lx\n", sz, (unsigned long) p );
- return p;
- }
-
-void my_dealloc2 ( void *p ) {
-// std::printf ( "Freeing %lx\n", (unsigned long) p );
- std::free ( p );
- }
-
-void my_dealloc3 ( void *p, size_t sz ) {
-// std::printf ( "Freeing %lx (size %ld)\n", (unsigned long) p, sz );
- std::free ( p );
- }
-
-void my_construct ( void *p ) {
-// std::printf ( "Constructing %lx\n", (unsigned long) p );
- }
-
-void my_destruct ( void *p ) {
-// std::printf ( "Destructing %lx\n", (unsigned long) p );
- }
-
-int gCounter;
-void count_construct ( void *p ) { ++gCounter; }
-void count_destruct ( void *p ) { --gCounter; }
-
-
-int gConstructorCounter;
-int gConstructorThrowTarget;
-int gDestructorCounter;
-int gDestructorThrowTarget;
-void throw_construct ( void *p ) { if ( gConstructorCounter == gConstructorThrowTarget ) throw 1; ++gConstructorCounter; }
-void throw_destruct ( void *p ) { if ( ++gDestructorCounter == gDestructorThrowTarget ) throw 2; }
-
-#if __cplusplus >= 201103L
-# define CAN_THROW noexcept(false)
-#else
-# define CAN_THROW
-#endif
-
-struct vec_on_stack {
- void *storage;
- vec_on_stack () : storage ( __cxxabiv1::__cxa_vec_new ( 10, 40, 8, throw_construct, throw_destruct )) {}
- ~vec_on_stack () CAN_THROW {__cxxabiv1::__cxa_vec_delete ( storage, 40, 8, throw_destruct ); }
- };
-
-// Test calls with empty constructors and destructors
-int test_empty ( ) {
- void *one, *two, *three;
-
-// Try with no padding and no con/destructors
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 0, NULL, NULL );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 0, NULL, NULL, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 0, NULL, NULL, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 0, NULL );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 0, NULL, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 0, NULL, my_dealloc3 );
-
-// Try with no padding
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 0, my_construct, my_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 0, my_construct, my_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 0, my_construct, my_destruct, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 0, my_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 0, my_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 0, my_destruct, my_dealloc3 );
-
-// Padding and no con/destructors
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 8, NULL, NULL );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 8, NULL, NULL, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 8, NULL, NULL, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 8, NULL );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 8, NULL, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 8, NULL, my_dealloc3 );
-
-// Padding with con/destructors
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 8, my_construct, my_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 8, my_construct, my_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 8, my_construct, my_destruct, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 8, my_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 8, my_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 8, my_destruct, my_dealloc3 );
-
- return 0;
- }
-
-// Make sure the constructors and destructors are matched
-int test_counted ( ) {
- int retVal = 0;
- void *one, *two, *three;
-
-// Try with no padding
- gCounter = 0;
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 0, count_construct, count_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 0, count_construct, count_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 0, count_construct, count_destruct, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 0, count_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 0, count_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 0, count_destruct, my_dealloc3 );
-
-// Since there was no padding, the # of elements in the array are not stored
-// and the destructors are not called.
- if ( gCounter != 30 ) {
- std::cerr << "Mismatched Constructor/Destructor calls (1)" << std::endl;
- std::cerr << " Expected 30, got " << gCounter << std::endl;
- retVal = 1;
- }
-
- gCounter = 0;
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 8, count_construct, count_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 8, count_construct, count_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 8, count_construct, count_destruct, my_alloc2, my_dealloc3 );
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 8, count_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 8, count_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 8, count_destruct, my_dealloc3 );
-
- if ( gCounter != 0 ) {
- std::cerr << "Mismatched Constructor/Destructor calls (2)" << std::endl;
- std::cerr << " Expected 0, got " << gCounter << std::endl;
- retVal = 1;
- }
-
- return retVal;
- }
-
-// Make sure the constructors and destructors are matched
-int test_exception_in_constructor ( ) {
- int retVal = 0;
- void *one, *two, *three;
-
-// Try with no padding
- gConstructorCounter = gDestructorCounter = 0;
- gConstructorThrowTarget = 15;
- gDestructorThrowTarget = -1;
- try {
- one = two = three = NULL;
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 0, throw_construct, throw_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 0, throw_construct, throw_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 0, throw_construct, throw_destruct, my_alloc2, my_dealloc3 );
- }
- catch ( int i ) {}
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 0, throw_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 0, throw_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 0, throw_destruct, my_dealloc3 );
-
-// Since there was no padding, the # of elements in the array are not stored
-// and the destructors are not called.
-// Since we threw after 15 calls to the constructor, we should see 5 calls to
-// the destructor from the partially constructed array.
- if ( gConstructorCounter - gDestructorCounter != 10 ) {
- std::cerr << "Mismatched Constructor/Destructor calls (1C)" << std::endl;
- std::cerr << gConstructorCounter << " constructors, but " <<
- gDestructorCounter << " destructors" << std::endl;
- retVal = 1;
- }
-
- gConstructorCounter = gDestructorCounter = 0;
- gConstructorThrowTarget = 15;
- gDestructorThrowTarget = -1;
- try {
- one = two = three = NULL;
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 8, throw_construct, throw_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 8, throw_construct, throw_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 8, throw_construct, throw_destruct, my_alloc2, my_dealloc3 );
- }
- catch ( int i ) {}
-
- __cxxabiv1::__cxa_vec_delete ( one, 40, 8, throw_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 8, throw_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 8, throw_destruct, my_dealloc3 );
-
- if ( gConstructorCounter != gDestructorCounter ) {
- std::cerr << "Mismatched Constructor/Destructor calls (2C)" << std::endl;
- std::cerr << gConstructorCounter << " constructors, but " <<
- gDestructorCounter << " destructors" << std::endl;
- retVal = 1;
- }
-
- return retVal;
- }
-
-// Make sure the constructors and destructors are matched
-int test_exception_in_destructor ( ) {
- int retVal = 0;
- void *one, *two, *three;
-
-// Throw from within a destructor
- gConstructorCounter = gDestructorCounter = 0;
- gConstructorThrowTarget = -1;
- gDestructorThrowTarget = 15;
- try {
- one = two = three = NULL;
- one = __cxxabiv1::__cxa_vec_new ( 10, 40, 8, throw_construct, throw_destruct );
- two = __cxxabiv1::__cxa_vec_new2( 10, 40, 8, throw_construct, throw_destruct, my_alloc2, my_dealloc2 );
- three = __cxxabiv1::__cxa_vec_new3( 10, 40, 8, throw_construct, throw_destruct, my_alloc2, my_dealloc3 );
- }
- catch ( int i ) {}
-
- try {
- __cxxabiv1::__cxa_vec_delete ( one, 40, 8, throw_destruct );
- __cxxabiv1::__cxa_vec_delete2( two, 40, 8, throw_destruct, my_dealloc2 );
- __cxxabiv1::__cxa_vec_delete3( three, 40, 8, throw_destruct, my_dealloc3 );
- }
- catch ( int i ) {}
-
-// We should have thrown in the middle of cleaning up "two", which means that
-// there should be 20 calls to the destructor, and "three" was not cleaned up.
- if ( gConstructorCounter != 30 || gDestructorCounter != 20 ) {
- std::cerr << "Unexpected Constructor/Destructor calls (1D)" << std::endl;
- std::cerr << "Expected (30, 20), but got (" << gConstructorCounter << ", " <<
- gDestructorCounter << ")" << std::endl;
- retVal = 1;
- }
-
-// Try throwing from a destructor - should be fine.
- gConstructorCounter = gDestructorCounter = 0;
- gConstructorThrowTarget = -1;
- gDestructorThrowTarget = 5;
- try { vec_on_stack v; }
- catch ( int i ) {}
-
- if ( gConstructorCounter != gDestructorCounter ) {
- std::cerr << "Mismatched Constructor/Destructor calls (2D)" << std::endl;
- std::cerr << gConstructorCounter << " constructors, but " <<
- gDestructorCounter << " destructors" << std::endl;
- retVal = 1;
- }
-
- return retVal;
- }
-
-int main ( int argc, char *argv [] ) {
- int retVal = 0;
- retVal += test_empty ();
- retVal += test_counted ();
- retVal += test_exception_in_constructor ();
- retVal += test_exception_in_destructor ();
- return retVal;
- }