| // 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)); |
| } |