| // This file is part of Eigen, a lightweight C++ template library |
| // for linear algebra. |
| // |
| // Copyright (C) 2011 Gael Guennebaud <gael.guennebaud@inria.fr> |
| // |
| // This Source Code Form is subject to the terms of the Mozilla |
| // Public License v. 2.0. If a copy of the MPL was not distributed |
| // with this file, You can obtain one at http://mozilla.org/MPL/2.0/. |
| |
| |
| // Various sanity tests with exceptions and non trivially copyable scalar type. |
| // - no memory leak when a custom scalar type trow an exceptions |
| // - todo: complete the list of tests! |
| |
| #define EIGEN_STACK_ALLOCATION_LIMIT 100000000 |
| |
| #include "main.h" |
| #include "AnnoyingScalar.h" |
| |
| #define CHECK_MEMLEAK(OP) { \ |
| AnnoyingScalar::countdown = 100; \ |
| int before = AnnoyingScalar::instances; \ |
| bool exception_thrown = false; \ |
| try { OP; } \ |
| catch (my_exception) { \ |
| exception_thrown = true; \ |
| VERIFY(AnnoyingScalar::instances==before && "memory leak detected in " && EIGEN_MAKESTRING(OP)); \ |
| } \ |
| VERIFY( (AnnoyingScalar::dont_throw) || (exception_thrown && " no exception thrown in " && EIGEN_MAKESTRING(OP)) ); \ |
| } |
| |
| EIGEN_DECLARE_TEST(exceptions) |
| { |
| typedef Eigen::Matrix<AnnoyingScalar,Dynamic,1> VectorType; |
| typedef Eigen::Matrix<AnnoyingScalar,Dynamic,Dynamic> MatrixType; |
| |
| { |
| AnnoyingScalar::dont_throw = false; |
| int n = 50; |
| VectorType v0(n), v1(n); |
| MatrixType m0(n,n), m1(n,n), m2(n,n); |
| v0.setOnes(); v1.setOnes(); |
| m0.setOnes(); m1.setOnes(); m2.setOnes(); |
| CHECK_MEMLEAK(v0 = m0 * m1 * v1); |
| CHECK_MEMLEAK(m2 = m0 * m1 * m2); |
| CHECK_MEMLEAK((v0+v1).dot(v0+v1)); |
| } |
| VERIFY(AnnoyingScalar::instances==0 && "global memory leak detected in " && EIGEN_MAKESTRING(OP)); |
| } |