|  | #include "main.h" | 
|  |  | 
|  | #include <exception>  // std::exception | 
|  |  | 
|  | struct Foo | 
|  | { | 
|  | static Index object_count; | 
|  | static Index object_limit; | 
|  | int dummy; | 
|  |  | 
|  | Foo() : dummy(0) | 
|  | { | 
|  | #ifdef EIGEN_EXCEPTIONS | 
|  | // TODO: Is this the correct way to handle this? | 
|  | if (Foo::object_count > Foo::object_limit) { std::cout << "\nThrow!\n"; throw Foo::Fail(); } | 
|  | #endif | 
|  | std::cout << '+'; | 
|  | ++Foo::object_count; | 
|  | } | 
|  |  | 
|  | ~Foo() | 
|  | { | 
|  | std::cout << '-'; | 
|  | --Foo::object_count; | 
|  | } | 
|  |  | 
|  | class Fail : public std::exception {}; | 
|  | }; | 
|  |  | 
|  | Index Foo::object_count = 0; | 
|  | Index Foo::object_limit = 0; | 
|  |  | 
|  | #undef EIGEN_TEST_MAX_SIZE | 
|  | #define EIGEN_TEST_MAX_SIZE 3 | 
|  |  | 
|  | EIGEN_DECLARE_TEST(ctorleak) | 
|  | { | 
|  | typedef Matrix<Foo, Dynamic, Dynamic> MatrixX; | 
|  | typedef Matrix<Foo, Dynamic, 1> VectorX; | 
|  |  | 
|  | Foo::object_count = 0; | 
|  | for(int i = 0; i < g_repeat; i++) { | 
|  | Index rows = internal::random<Index>(2,EIGEN_TEST_MAX_SIZE), cols = internal::random<Index>(2,EIGEN_TEST_MAX_SIZE); | 
|  | Foo::object_limit = rows*cols; | 
|  | { | 
|  | MatrixX r(rows, cols); | 
|  | Foo::object_limit = r.size()+internal::random<Index>(0, rows*cols - 2); | 
|  | std::cout << "object_limit =" << Foo::object_limit << std::endl; | 
|  | #ifdef EIGEN_EXCEPTIONS | 
|  | try | 
|  | { | 
|  | #endif | 
|  | if(internal::random<bool>()) { | 
|  | std::cout <<       "\nMatrixX m(" << rows << ", " << cols << ");\n"; | 
|  | MatrixX m(rows, cols); | 
|  | } | 
|  | else { | 
|  | std::cout <<       "\nMatrixX m(r);\n"; | 
|  | MatrixX m(r); | 
|  | } | 
|  | #ifdef EIGEN_EXCEPTIONS | 
|  | VERIFY(false);  // not reached if exceptions are enabled | 
|  | } | 
|  | catch (const Foo::Fail&) { /* ignore */ } | 
|  | #endif | 
|  | } | 
|  | VERIFY_IS_EQUAL(Index(0), Foo::object_count); | 
|  |  | 
|  | { | 
|  | Foo::object_limit = (rows+1)*(cols+1); | 
|  | MatrixX A(rows, cols); | 
|  | VERIFY_IS_EQUAL(Foo::object_count, rows*cols); | 
|  | VectorX v=A.row(0); | 
|  | VERIFY_IS_EQUAL(Foo::object_count, (rows+1)*cols); | 
|  | v = A.col(0); | 
|  | VERIFY_IS_EQUAL(Foo::object_count, rows*(cols+1)); | 
|  | } | 
|  | VERIFY_IS_EQUAL(Index(0), Foo::object_count); | 
|  | } | 
|  | std::cout << "\n"; | 
|  | } |