From 890057ee06c3f4db2f7832f7d1f9d02067a4d238 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20Gr=C3=BCninger?= <gruenich@dune-project.org> Date: Fri, 30 Oct 2015 07:19:04 +0100 Subject: [PATCH] [cleanup] Remove deprecated fassign.hh --- dune/common/CMakeLists.txt | 1 - dune/common/Makefile.am | 1 - dune/common/fassign.hh | 299 ------------------------------------ dune/common/test/.gitignore | 11 -- 4 files changed, 312 deletions(-) delete mode 100644 dune/common/fassign.hh diff --git a/dune/common/CMakeLists.txt b/dune/common/CMakeLists.txt index d74e8a8bb..2772d1978 100644 --- a/dune/common/CMakeLists.txt +++ b/dune/common/CMakeLists.txt @@ -45,7 +45,6 @@ install(FILES dynvector.hh enumset.hh exceptions.hh - fassign.hh float_cmp.cc float_cmp.hh fmatrix.hh diff --git a/dune/common/Makefile.am b/dune/common/Makefile.am index 6fddb5f26..4f4a502b5 100644 --- a/dune/common/Makefile.am +++ b/dune/common/Makefile.am @@ -39,7 +39,6 @@ commoninclude_HEADERS = \ dynmatrixev.hh \ enumset.hh \ exceptions.hh \ - fassign.hh \ float_cmp.cc \ float_cmp.hh \ fmatrix.hh \ diff --git a/dune/common/fassign.hh b/dune/common/fassign.hh deleted file mode 100644 index 1ed7c5ee0..000000000 --- a/dune/common/fassign.hh +++ /dev/null @@ -1,299 +0,0 @@ -// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- -// vi: set et ts=4 sw=2 sts=2: -#ifndef DUNE_ASSIGN_HH -#define DUNE_ASSIGN_HH - -#warning The header <dune/common/fassign.hh> is deprecated and will be removed after the\ - release of dune-common-2.4. Please use C++11 initializer lists instead. - -#include <dune/common/fvector.hh> -#include <dune/common/fmatrix.hh> -#include <dune/common/unused.hh> - -namespace Dune { - - /** - * @file - * @brief Classes for implementing an assignment to FieldVector from a comma-separated list - */ - /** @addtogroup Common - * - * @{ - */ - - /** - * Emtpy namespace make this class and the object local to one object file - */ - namespace { - - /** - * @brief Initializer class for - * - * overload operator <<= for FieldVector assignment from Dune::Zero - */ - struct Zero { - explicit Zero (int) {}; - /** \brief Conversion operator to double */ - operator double () { return 0.0; } - /** \brief Conversion operator to int */ - operator int () { return 0; } - } zero(0); - - /** - * @brief Marker class for next row - * - * overload operator <<= for FieldMatrix assignment - */ - struct NextRow { - explicit NextRow (int) {}; - } nextRow(0); - } // end empty namespace - - /** - * @brief fvector assignment operator - * - * overload operator <<= for fvector assignment from Dune::Zero - * - * after including fassing.hh you can easily assign data to a FieldVector - * using - * - * @code - * FieldVector<double, 4> x; x <<= 1.0, 4.0, 10.0, 11.0; - * @endcode - * - * The operator checks that the whole vector is initalized. - * In case you know that all following entries will be zero padded, you can use - * - * @code - * FieldVector<double, 40> x; x <<= 1.0, 4.0, 10.0, 11.0, zero; - * @endcode - * - */ - template <class T, int s> - class fvector_assigner - { - private: - FieldVector<T,s> & v; - int c; - bool temporary; - fvector_assigner(); - public: - /*! @brief Copy Constructor */ - fvector_assigner(fvector_assigner & a) : v(a.v), c(a.c), temporary(false) - {} - /*! @brief Constructor from vector and temporary flag - \param _v vector which should be initialized - \param t bool indicating, that this is a temporary object (see ~fvector_assigner) - */ - fvector_assigner(FieldVector<T,s> & _v, bool t) : v(_v), c(0), temporary(t) - {}; - /*! @brief Destructor - checks for complete initialization of the vector. - The check is skipped, if this object is marked temporary. - */ - ~fvector_assigner() - { - if (!temporary && c!=s) - DUNE_THROW(MathError, "Trying to assign " << c << - " entries to a FieldVector of size " << s); - } - /*! @brief append data to this vector */ - fvector_assigner & append (const T & t) - { - v[c++] = t; - return *this; - } - /*! @brief append zeros to this vector - */ - fvector_assigner & append (Zero z) - { - DUNE_UNUSED_PARAMETER(z); - while (c!=s) v[c++] = 0; - return *this; - } - /*! @brief append data to this vector - the overloaded comma operator is used to assign a comma separated list - of values to the vector - */ - fvector_assigner & operator , (const T & t) - { - return append(t); - } - /*! @brief append zeros to this vector - the overloaded comma operator is used to stop the assign of values - to the vector, all remaining entries are assigned 0. - */ - fvector_assigner & operator , (Zero z) - { - return append(z); - } - }; - - /** - * @brief fvector assignment operator - * - * overload operator <<= for fvector assignment - * from comma separated list of values - */ - template <class T, class K, int s> - fvector_assigner<T,s> operator <<= (FieldVector<T,s> & v, const K & t) - { - return fvector_assigner<T,s>(v,true).append(t); - } - - /** - * @brief fvector assignment operator - * - * overload operator <<= for fvector assignment from Dune::Zero - */ - template <class T, int s> - fvector_assigner<T,s> operator <<= (FieldVector<T,s> & v, Zero z) - { - return fvector_assigner<T,s>(v,true).append(z); - } - - /** - * @brief fmatrix assignment operator - * - * overload operator <<= for fmatrix assignment from Dune::Zero - * - * after including fassing.hh you can easily assign data to a FieldMatrix - * using - * - * @code - * FieldMatrix<double, 2,2> x; x <<= 1.0, 4.0, nextRow, 10.0, 11.0; - * @endcode - * - * The operator checks that the whole matrix is initalized. - * In case you know that all following entries of a row will be zero padded, you can use - * - * @code - * FieldMatrix<double, 4, 4> x; x <<= 1.0, zero, nextRow, 10.0, 11.0; - * @endcode - * - */ - template <class T, int n, int m> - class fmatrix_assigner - { - private: - FieldMatrix<T,n,m> & A; - int c; - int r; - bool temporary; - bool thrown; - - void end_row() - { - if (!temporary && c!=m && !thrown) { - thrown=true; - DUNE_THROW(MathError, "Trying to assign " << c << - " entries to a FieldMatrix row of size " << m); - } - c=0; - } - public: - /*! @brief Copy Constructor */ - fmatrix_assigner(fmatrix_assigner & a) : A(a.A), c(a.c), r(a.r), temporary(false), thrown(a.thrown) - {} - /*! @brief Constructor from matrix and temporary flag - \param _A matrix which should be initialized - \param t bool indicating, that this is a temporary object (see ~fmatrix_assigner) - */ - fmatrix_assigner(FieldMatrix<T,n,m> & _A, bool t) : A(_A), c(0), r(0), temporary(t), - thrown(false) - {}; - /*! @brief Destructor - checks for complete initialization of the matrix. - The check is skipped, if this object is marked temporary. - */ - ~fmatrix_assigner() - { - end_row(); - if (!temporary && r!=n-1 && !thrown) { - thrown=true; - DUNE_THROW(MathError, "Trying to assign " << r << - " rows to a FieldMatrix of size " << n << " x " << m); - } - } - /*! @brief append data to this matrix */ - fmatrix_assigner & append (const T & t) - { - // Check whether we have passed the last row - if(r>=m) { - thrown=true; - DUNE_THROW(MathError, "Trying to assign more than " << m << - " rows to a FieldMatrix of size " << n << " x " << m); - } - A[r][c++] = t; - return *this; - } - /*! @brief append zeros to this matrix - */ - fmatrix_assigner & append (Zero z) - { - DUNE_UNUSED_PARAMETER(z); - while (c!=m) A[r][c++] = 0; - return *this; - } - /*! @brief move to next row of the matrix - */ - fmatrix_assigner & append (NextRow nr) - { - DUNE_UNUSED_PARAMETER(nr); - end_row(); - r++; - return *this; - } - /*! @brief append data to this matrix - the overloaded comma operator is used to assign a comma separated list - of values to the matrix - */ - fmatrix_assigner & operator , (const T & t) - { - return append(t); - } - /*! @brief append zeros to this matrix - the overloaded comma operator is used to stop the assign of values - to the matrix, all remaining entries are assigned 0. - */ - fmatrix_assigner & operator , (Zero z) - { - return append(z); - } - /*! @brief append zeros to this matrix - the overloaded comma operator is used to stop the assign of values - to the current row, it will be checked whether all entries have been - assigned values. - */ - fmatrix_assigner & operator , (NextRow nr) - { - return append(nr); - } - }; - - /** - * @brief FieldMatrix assignment operator - * - * overload operator <<= for FieldMatrix assignment - * from comma separated list of values - */ - template <class T, class K, int n, int m> - fmatrix_assigner<T,n,m> operator <<= (FieldMatrix<T,n,m> & v, const K & t) - { - return fmatrix_assigner<T,n,m>(v,true).append(t); - } - - /** - * @brief FieldMatrix assignment operator - * - * overload operator <<= for FieldMatrix row assignment from Dune::Zero - */ - template <class T, int n, int m> - fmatrix_assigner<T,n,m> operator <<= (FieldMatrix<T,n,m> & v, Zero z) - { - return fmatrix_assigner<T,n,m>(v,true).append(z); - } - -} // end namespace Dune - -#endif // DUNE_ASSIGN_HH diff --git a/dune/common/test/.gitignore b/dune/common/test/.gitignore index 87b88ce45..fe060b378 100644 --- a/dune/common/test/.gitignore +++ b/dune/common/test/.gitignore @@ -12,7 +12,6 @@ /dynvectortest /eigenvaluestest /enumsettest -/fassigntest /fmatrixtest /fvectortest /gcdlcmtest @@ -43,16 +42,6 @@ /testdebugallocator_fail3 /testdebugallocator_fail4 /testdebugallocator_fail5 -/testfassign1 -/testfassign2 -/testfassign3 -/testfassign4 -/testfassign_fail1 -/testfassign_fail2 -/testfassign_fail3 -/testfassign_fail4 -/testfassign_fail5 -/testfassign_fail6 /testfconstruct /testfloatcmp /timing_flt -- GitLab