From 98f0516f158fbcacdc50e4e3f9e25f9ee6651d09 Mon Sep 17 00:00:00 2001 From: Bjoern Michaelsen Date: Tue, 2 Dec 2014 10:13:57 +0100 Subject: ring docs Change-Id: Ie26b98bb2e2946f326de6ff58677e33539db70b6 --- sw/inc/ring.hxx | 63 +++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 57 insertions(+), 6 deletions(-) (limited to 'sw') diff --git a/sw/inc/ring.hxx b/sw/inc/ring.hxx index 33bc069bdfba..e587ad3f73a7 100644 --- a/sw/inc/ring.hxx +++ b/sw/inc/ring.hxx @@ -30,9 +30,14 @@ namespace sw class Ring_node_traits; template class RingIterator; + /** + * An intrusive container class double linking the contained nodes + * @example sw/qa/core/uwriter.cxx + */ template class Ring { + /** internal implementation class -- not for external use */ struct Ring_node_traits { typedef T node; @@ -46,33 +51,79 @@ namespace sw friend struct Ring_node_traits; typedef boost::intrusive::circular_list_algorithms algo; T* pNext; - T* pPrev; ///< In order to speed up inserting and deleting. + T* pPrev; protected: + /** + * Creates a new item in a ring container all by itself. + * Note: Ring instances can newer be outside a container. At most, they + * are alone in one. + */ Ring() { algo::init_header(static_cast< T* >(this)); } - Ring( T* ); + /** + * Creates a new item and add it to an existing ring container. + * Note: the newly created item will be inserted just before item pRing. + * @param pRing ring container to add the created item to + */ + Ring( T* pRing ); public: typedef RingIterator iterator; typedef RingIterator const_iterator; virtual ~Ring() { algo::unlink(static_cast< T* >(this)); }; + /** + * Removes this item from its current ring container and adds it to + * another ring container. If the item was not alone in the original + * ring container, the other items in the ring will stay in the old + * ring container. + * Note: the newly created item will be inserted just before item pDestRing. + * @param pDestRing the container to add this item to + */ void MoveTo( T* pDestRing ); + /** + * Merges two ring containers. All item from both ring containers will + * be in the same ring container in the end. + * Note: The items of this ring container will be inserted just before + * item pDestRing + * @param pDestRing the container to merge this container with + */ void MoveRingTo( T* pDestRing ); - T* GetNext() const { return pNext; } - T* GetPrev() const { return pPrev; } - // unfortunately we cant name these STL-conforming, as some derived classes - // also derive from other STL containers (which is bad anyway, but ...) + /** @return the next item in the ring container */ + T* GetNext() const + { return pNext; } + /** @return the previous item in the ring container */ + T* GetPrev() const + { return pPrev; } + /** + * iterator access + * @code + * for(Ring::iterator ppRing = pPaM->beginRing(); ppRing != pPaM->endRing(); ++ppRing) + * do_stuff(*ppRing); + * @endcode + * @TODO: unfortunately we cant name these STL-conforming, as some derived classes + * also derive from other STL containers. This should be fixed though. + * That should allow this to be used directly with C++11s for( : ) + * iteration statement. + */ iterator beginRing(); iterator endRing(); const_iterator beginRing() const; const_iterator endRing() const; + /** + * simplified iteration with BOOST_FOREACH (example for Ring): + * @code + * BOOST_FOREACH(SwPaM& rPaM, pPaM->rangeRing()) + * do_stuff(rPaM); + * @endcode + */ std::pair rangeRing() { return std::make_pair(beginRing(), endRing()); } std::pair rangeRing() const { return std::make_pair(beginRing(), endRing()); } + /** @return the number of elements in the container */ sal_uInt32 numberOf() const { return algo::count(static_cast< const T* >(this)); } }; -- cgit