/*-*- c++ -*-********************************************************
* kbList.h : a double linked list *
* *
- * (C) 1998 by Karsten Ballüder (Ballueder@usa.net) *
+ * (C) 1998-1999 by Karsten Ballüder (karsten@phy.hw.ac.uk) *
* *
* $Id$
*
*******************************************************************/
+
+
#ifndef KBLIST_H
# define KBLIST_H
-#ifdef __GNUG__
-# pragma interface "kbList.h"
-#endif
-
#ifndef NULL
# define NULL 0
#endif
*/
operator void*() const { return node == NULL ? (void*)0 : (void*)(-1); }
+
/** Increment operator - prefix, goes to next node in list.
@return itself
*/
deleted by list. See the constructor for more details.
@param ownsflag if true, list will own entries
*/
- void ownsObjects(bool ownsflag = true)
+ void ownsObjects(bool ownsflag)
{ ownsEntries = ownsflag; }
/** Query whether list owns entries.
bool ownsObjects(void)
{ return ownsEntries; }
+ // This must be protected to disallow insertion of wrong elements.
+protected:
/** Add an entry at the end of the list.
@param element pointer to data
*/
*/
void push_front(void *element);
+ /** Insert an element into the list.
+ @param i an iterator pointing to the element, before which the new one should be inserted
+ @param element the element data
+ */
+ void insert(iterator & i, void *element);
+
+public:
/** Get element from end of the list and delete it.
NOTE: In this case the element's data will not get deleted by
the list. It is the responsibility of the caller to free it.
@return the element data
*/
- void *pop_back(void);
+ void * pop_back(void);
/** Get element from head of the list and delete it.
NOTE: In this case the element's data will not get deleted by
the list. It is the responsibility of the caller to free it.
@return the element data
*/
- void *pop_front(void);
-
- /** Insert an element into the list.
- @param i an iterator pointing to the element, before which the new one should be inserted
- @param element the element data
- */
- void insert(iterator & i, void *element);
+ void * pop_front(void);
/** Remove an element from the list _without_ deleting the object.
@param i iterator pointing to the element to be deleted
param iterator i
*/
inline void deleteContent(iterator i)
- { if(ownsEntries) delete *i; }
+ {
+ iterator *i_ptr = &i;
+ if(ownsEntries) delete i_ptr;
+ }
private:
/* the cast is needed for MS VC++ 5.0 */ \
{ return (type *)((kbList::iterator *)this)->operator*() ; } \
}; \
- inline name(bool ownsEntriesFlag = TRUE) \
+ inline name(bool ownsEntriesFlag = true) \
: kbList(ownsEntriesFlag) {} \
\
inline type *pop_back(void) \
\
inline type *pop_front(void) \
{ return (type *) kbList::pop_front(); } \
- \
+ inline void push_back(type *element) \
+ { kbList::push_back( (void *) element); } \
+ void push_front(type *element) \
+ { kbList::push_front( (void *) element); } \
+ void insert(iterator & i, void *element) \
+ { kbList::insert( i, (void *) element); } \
type *remove(iterator& i) \
{ return (type *)kbList::remove(i); } \
inline void erase(iterator & i) \
KBLIST_DEFINE(kbStringList, String);
#endif
//@}
+
#endif // KBLIST_H