Logo Search packages:      
Sourcecode: blender version File versions  Download package

FTList.h

#ifndef    __FTList__
#define    __FTList__

#include "FTGL.h"

/**
* Provides a non-STL alternative to the STL list
 */
template <typename FT_LIST_ITEM_TYPE>
00010 class FTGL_EXPORT FTList
{
    public:
        typedef FT_LIST_ITEM_TYPE value_type;
        typedef value_type& reference;
        typedef const value_type& const_reference;
        typedef size_t size_type;

        /**
         * Constructor
         */
00021         FTList()
        :   listSize(0),
            tail(0)
        {
            tail = NULL;
            head = new Node;
        }

        /**
         * Destructor
         */
00032         ~FTList()
        {
            Node* next;
            
            for( Node *walk = head; walk; walk = next)
            {
                next = walk->next;
                delete walk;
            }
        }

        /**
         * Get the number of items in the list
         */
00046         size_type size() const
        {
            return listSize;
        }

        /**
         * Add an item to the end of the list
         */
00054         void push_back( const value_type& item)
        {
            Node* node = new Node( item);
            
            if( head->next == NULL)
            {
                head->next = node;
            }

            if( tail)
            {
                tail->next = node;
            }
            tail = node;
            ++listSize;
        }
        
        /**
         * Get the item at the front of the list
         */
00074         reference front() const
        {
            return head->next->payload;
        }

        /**
         * Get the item at the end of the list
         */
00082         reference back() const
        {
            return tail->payload;
        }

    private:
        struct Node
        {
            Node()
            :     next(NULL)
            {}

            Node( const value_type& item)
            :     next(NULL)
            {
                payload = item;
            }
            
            Node* next;
            
            value_type payload;
        };
        
        size_type listSize;

        Node* head;
        Node* tail;
};

#endif // __FTList__


Generated by  Doxygen 1.6.0   Back to index