// Copyright (C) 2007-2020 CEA/DEN, EDF R&D, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // // SMESH SMDS : implementation of Salome mesh data structure // File : SMDS_SetIterator.hxx // Created : Feb 27 2006 // Author : Edward AGAPOV (eap) // #ifndef SMDS_SetIterator_HeaderFile #define SMDS_SetIterator_HeaderFile #include "SMDS_Iterator.hxx" namespace SMDS { /////////////////////////////////////////////////////////////////////////////// /// Accessors to value pointed by iterator /////////////////////////////////////////////////////////////////////////////// template struct SimpleAccessor { static VALUE value(VALUE_SET_ITERATOR it) { return (VALUE) *it; } }; template struct KeyAccessor { static VALUE value(VALUE_SET_ITERATOR it) { return (VALUE) it->first; } }; template struct ValueAccessor { static VALUE value(VALUE_SET_ITERATOR it) { return (VALUE) it->second; } }; template struct PointerAccessor { static VALUE value(VALUE_SET_ITERATOR it) { return (VALUE) &(*it); } }; /////////////////////////////////////////////////////////////////////////////// /// Filters of value pointed by iterator /////////////////////////////////////////////////////////////////////////////// template struct PassAllValueFilter { bool operator()(const VALUE& /*t*/ ) { return true; } }; template struct NonNullFilter { bool operator()(const VALUE& t ) { return bool( t ); } }; } /////////////////////////////////////////////////////////////////////////////// /// SMDS_Iterator iterating over abstract set of values like STL containers /// /// BE CAREFUL: iterator pointed value is static_cast'ed to VALUE /// /////////////////////////////////////////////////////////////////////////////// template, typename VALUE_FILTER=SMDS::PassAllValueFilter > class SMDS_SetIterator : public SMDS_Iterator { protected: VALUE_SET_ITERATOR _beg, _end; VALUE_FILTER _filter; public: SMDS_SetIterator(const VALUE_SET_ITERATOR & begin, const VALUE_SET_ITERATOR & end, const VALUE_FILTER& filter=VALUE_FILTER()) { init ( begin, end, filter ); } /// Initialization virtual void init(const VALUE_SET_ITERATOR & begin, const VALUE_SET_ITERATOR & end, const VALUE_FILTER& filter=VALUE_FILTER()) { _beg = begin; _end = end; _filter = filter; if ( more() && !_filter( ACCESOR::value( _beg ))) next(); } /// Return true iff there are other object in this iterator virtual bool more() { return _beg != _end; } /// Return the current object and step to the next one virtual VALUE next() { VALUE ret = ACCESOR::value( _beg++ ); while ( more() && !_filter( ACCESOR::value( _beg ))) ++_beg; return ret; } }; /////////////////////////////////////////////////////////////////////////////// /// map iterators /////////////////////////////////////////////////////////////////////////////// #include /*! * \brief iterator on values of a map */ template struct SMDS_mapIterator : public SMDS_SetIterator< typename M::mapped_type, typename M::const_iterator, SMDS::ValueAccessor > { typedef SMDS_SetIterator< typename M::mapped_type, typename M::const_iterator, SMDS::ValueAccessor > parent_type; SMDS_mapIterator(const M& m):parent_type(m.begin(),m.end()) {} }; /*! * \brief reverse iterator on values of a map */ template struct SMDS_mapReverseIterator : public SMDS_SetIterator< typename M::mapped_type, typename M::const_reverse_iterator, SMDS::ValueAccessor > { typedef SMDS_SetIterator< typename M::mapped_type, typename M::const_reverse_iterator, SMDS::ValueAccessor > parent_type; SMDS_mapReverseIterator(const M& m):parent_type(m.rbegin(),m.rend()) {} }; /*! * \brief iterator on keys of a map */ template struct SMDS_mapKeyIterator : public SMDS_SetIterator< typename M::key_type, typename M::const_iterator, SMDS::KeyAccessor > { typedef SMDS_SetIterator< typename M::key_type, typename M::const_iterator, SMDS::KeyAccessor > parent_type; SMDS_mapKeyIterator(const M& m):parent_type(m.begin(),m.end()) {} }; /*! * \brief reverse iterator on keys of a map */ template struct SMDS_mapKeyReverseIterator : public SMDS_SetIterator< typename M::key_type, typename M::const_iterator, SMDS::KeyAccessor > { typedef SMDS_SetIterator< typename M::key_type, typename M::const_iterator, SMDS::KeyAccessor > parent_type; SMDS_mapKeyReverseIterator(const M& m):parent_type(m.rbegin(),m.rend()) {} }; /////////////////////////////////////////////////////////////////////////////// // useful specifications /////////////////////////////////////////////////////////////////////////////// #include class SMDS_MeshElement; class SMDS_MeshNode; typedef const SMDS_MeshElement* SMDS_pElement; typedef const SMDS_MeshNode* SMDS_pNode; // element iterators typedef SMDS_SetIterator< SMDS_pElement, std::vector< SMDS_pElement >::const_iterator> SMDS_ElementVectorIterator; typedef SMDS_SetIterator< SMDS_pElement, SMDS_pElement const *> SMDS_ElementArrayIterator; typedef SMDS_SetIterator< SMDS_pElement, std::vector< SMDS_pNode >::const_iterator> SMDS_NodeVectorElemIterator; typedef SMDS_SetIterator< SMDS_pElement, SMDS_pNode const * > SMDS_NodeArrayElemIterator; // node iterators typedef SMDS_SetIterator< SMDS_pNode, std::vector< SMDS_pNode >::const_iterator > SMDS_NodeVectorIterator; typedef SMDS_SetIterator< SMDS_pNode, SMDS_pNode const * > SMDS_NodeArrayIterator; #endif