281 lines
No EOL
6.8 KiB
C++
281 lines
No EOL
6.8 KiB
C++
//========= Copyright Valve Corporation, All rights reserved. ============//
|
|
//
|
|
// Purpose:
|
|
//
|
|
// $Workfile: $
|
|
// $Date: $
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
// $Log: $
|
|
//
|
|
// $NoKeywords: $
|
|
//=============================================================================//
|
|
|
|
#ifndef ACTIVEITEMLIST_H
|
|
#define ACTIVEITEMLIST_H
|
|
#pragma once
|
|
|
|
// memdbgon must be the last include file in a .cpp file!!!
|
|
#include <tier0/memdbgon.h>
|
|
|
|
//=============================================================================
|
|
|
|
typedef int ITEM_HANDLE;
|
|
|
|
//=============================================================================
|
|
|
|
template <class T> class ActiveItemList
|
|
{
|
|
public:
|
|
|
|
ActiveItemList();
|
|
ActiveItemList( int size );
|
|
|
|
void SetSize( int size );
|
|
int GetSize( void );
|
|
|
|
int GetNumberOfItems( void );
|
|
T* GetFirstItem( void );
|
|
T* GetNextItem( void );
|
|
|
|
ITEM_HANDLE GetEmptyItemHandle( void );
|
|
|
|
T* GetItem( ITEM_HANDLE handle );
|
|
void RemoveItem( ITEM_HANDLE handle );
|
|
|
|
void SetActiveItem( ITEM_HANDLE handle );
|
|
T* GetActiveItem( void );
|
|
|
|
void Free( void );
|
|
|
|
protected:
|
|
|
|
int m_NumItems; // the number of items in the list
|
|
int m_ActiveItem; // the active item index
|
|
int m_CurrentItem;
|
|
int m_ListSize; // size of the list
|
|
T *m_pList; // the active item list
|
|
bool *m_pEmptyList; // keep an empty list
|
|
};
|
|
|
|
//=============================================================================
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> ActiveItemList<T>::ActiveItemList()
|
|
{
|
|
m_NumItems = 0;
|
|
m_ActiveItem = -1;
|
|
m_CurrentItem = -1;
|
|
m_ListSize = 0;
|
|
m_pList = NULL;
|
|
m_pEmptyList = NULL;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> ActiveItemList<T>::ActiveItemList( int size )
|
|
{
|
|
int i; // loop counter
|
|
|
|
// set the size of the list
|
|
m_ListSize = size;
|
|
|
|
//
|
|
// allocate memory for the list
|
|
//
|
|
if( !( m_pList = new T[size] ) )
|
|
return;
|
|
|
|
if( !( m_pEmptyList = new bool[size] ) )
|
|
return;
|
|
|
|
//
|
|
// initialize the active item list
|
|
//
|
|
m_NumItems = 0;
|
|
m_ActiveItem = -1;
|
|
m_CurrentItem = -1;
|
|
|
|
for( i = 0; i < size; i++ )
|
|
m_pEmptyList[i] = true;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> void ActiveItemList<T>::SetSize( int size )
|
|
{
|
|
int i; // loop counter
|
|
|
|
// set the size of the list
|
|
m_ListSize = size;
|
|
|
|
//
|
|
// allocate memory for the list
|
|
//
|
|
if( !( m_pList = new T[size] ) )
|
|
return;
|
|
|
|
if( !( m_pEmptyList = new bool[size] ) )
|
|
return;
|
|
|
|
//
|
|
// initialize the active item list
|
|
//
|
|
m_NumItems = 0;
|
|
m_ActiveItem = -1;
|
|
m_CurrentItem = -1;
|
|
|
|
for( i = 0; i < size; i++ )
|
|
m_pEmptyList[i] = true;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> int ActiveItemList<T>::GetSize( void )
|
|
{
|
|
return m_ListSize;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> int ActiveItemList<T>::GetNumberOfItems( void )
|
|
{
|
|
return m_NumItems;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> T* ActiveItemList<T>::GetFirstItem( void )
|
|
{
|
|
int i; // loop counter
|
|
|
|
// reset current item index
|
|
m_CurrentItem = -1;
|
|
|
|
//
|
|
// find the first item in the list
|
|
//
|
|
for( i = 0; i < m_ListSize; i++ )
|
|
{
|
|
if( !m_pEmptyList[i] )
|
|
{
|
|
m_CurrentItem = i;
|
|
return &m_pList[i];
|
|
}
|
|
}
|
|
|
|
// no items found
|
|
return NULL;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> T* ActiveItemList<T>::GetNextItem( void )
|
|
{
|
|
int i; // loop counter
|
|
|
|
//
|
|
// find the next item in the list
|
|
//
|
|
for( i = m_CurrentItem + 1; i < m_ListSize; i++ )
|
|
{
|
|
if( !m_pEmptyList[i] )
|
|
{
|
|
m_CurrentItem = i;
|
|
return &m_pList[i];
|
|
}
|
|
}
|
|
|
|
// no more items found
|
|
return NULL;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> ITEM_HANDLE ActiveItemList<T>::GetEmptyItemHandle( void )
|
|
{
|
|
int i; // loop counter
|
|
|
|
//
|
|
// find an empty item slot and return the handle
|
|
//
|
|
for( i = 0; i < m_ListSize; i++ )
|
|
{
|
|
if( m_pEmptyList[i] )
|
|
{
|
|
m_pEmptyList[i] = false;
|
|
m_NumItems++;
|
|
return i;
|
|
}
|
|
}
|
|
|
|
// no empty item slot
|
|
return -1;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> T* ActiveItemList<T>::GetItem( ITEM_HANDLE handle )
|
|
{
|
|
return &m_pList[handle];
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> void ActiveItemList<T>::RemoveItem( ITEM_HANDLE handle )
|
|
{
|
|
//
|
|
// set the item to empty and decrement the number of items in list
|
|
//
|
|
m_pEmptyList[handle] = true;
|
|
m_NumItems--;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> void ActiveItemList<T>::SetActiveItem( ITEM_HANDLE handle )
|
|
{
|
|
// set the active item
|
|
m_ActiveItem = handle;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> T* ActiveItemList<T>::GetActiveItem( void )
|
|
{
|
|
if( m_ActiveItem == -1 )
|
|
return NULL;
|
|
|
|
return &m_pList[m_ActiveItem];
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//-----------------------------------------------------------------------------
|
|
template <class T> void ActiveItemList<T>::Free( void )
|
|
{
|
|
//
|
|
// clean up lists
|
|
//
|
|
if( m_pList )
|
|
delete [] m_pList;
|
|
|
|
if( m_pEmptyList )
|
|
delete [] m_pEmptyList;
|
|
}
|
|
|
|
|
|
#endif // ACTIVEITEMLIST_H
|