/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2025, Open Design Alliance (the "Alliance"). // All rights reserved. // // This software and its documentation and related materials are owned by // the Alliance. The software may only be incorporated into application // programs owned by members of the Alliance, subject to a signed // Membership Agreement and Supplemental Software License Agreement with the // Alliance. The structure and organization of this software are the valuable // trade secrets of the Alliance and its suppliers. The software is also // protected by copyright law and international treaty provisions. Application // programs incorporating this software must include the following statement // with their copyright notices: // // This application incorporates Open Design Alliance software pursuant to a license // agreement with Open Design Alliance. // Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance. // All rights reserved. // // By use of this software, its documentation or related materials, you // acknowledge and accept the above terms. /////////////////////////////////////////////////////////////////////////////// #ifndef _ODRXITERATOR_H_ #define _ODRXITERATOR_H_ #include "RxObject.h" #include "SmartPtr.h" #ifndef SWIG #include #endif #include "TD_PackPush.h" /** \details This class is the abstract base class for OdDbDictionaryIterator and OdRxDictionaryIterator objects. \sa TD_Db \sa */ class FIRSTDLL_EXPORT OdRxIterator : public OdRxObject { public: OdRxIterator() {} ODRX_DECLARE_MEMBERS(OdRxIterator); /** \details Returns true if and only if the traversal by this iterator object is completed. */ virtual bool done() const = 0; /** \details Sets the iterator object to the next element of the container. \remarks Returns true if and only if not at the end of the list. */ virtual bool next() = 0; /** \details Returns the non-typified smart pointer to the object on which the iterator object refers. */ virtual OdRxObjectPtr object() const = 0; }; /** \details The typified smart pointer for the OdRxIterator object. */ typedef OdSmartPtr OdRxIteratorPtr; #ifndef SWIG /** \details This class is an iterator wrapper to be used to implement "range-based for" loop support in collections using OdRxIterator and its descendants like OdDbDictionaryIterator. When the wrapper iterator `done()` function returns true, it is released and becomes equal to the null iterator representing collection end. */ template class OdDbNextIteratorWrap { protected: OdSmartPtr m_pIterator; public: using difference_type = ptrdiff_t; using value_type = const I*; using pointer = void; using reference = const I*; using iterator_category = std::input_iterator_tag; /** \details Default constructor */ OdDbNextIteratorWrap(const OdSmartPtr& i) { m_pIterator = i; if (!!m_pIterator && m_pIterator->done()) m_pIterator.release(); } /** \details Dereference operator \returns Wrapped iterator. */ reference operator*() const { return m_pIterator.get(); } /** \details Natural comparison operator. */ bool operator ==(const OdDbNextIteratorWrap& other) const { return m_pIterator == other.m_pIterator; } /** \details Natural comparison operator. */ bool operator !=(const OdDbNextIteratorWrap& other) const { return m_pIterator != other.m_pIterator; } /** \details Increment operator. Moves iterator forward. */ const OdDbNextIteratorWrap& operator++() { if (!!m_pIterator) { m_pIterator->next(); if (m_pIterator->done()) m_pIterator.release(); } return *this; } }; #endif #include "TD_PackPop.h" #endif // _ODRXITERATOR_H_