2020-09-30 16:53:55 +02:00

70 lines
1.9 KiB
C++

/*==========================================================================
*
* Copyright (C) 1995 - 2000 Microsoft Corporation. All Rights Reserved.
*
* File: BagArray.inl
* Content: CBagArray methods
*
* History:
* Date By Reason
* ====== == ======
* 12-12-2001 simonpow Created
***************************************************************************/
template <class T>
BOOL CBagArray<T>::AddElements(const T * pElems, DWORD dwNumElem)
{
//ensure pointer passed isn't into this bags contents!
DNASSERT(!(pElems>=m_data.GetAllElements() && pElems<m_data.GetAllElements()+m_data.GetCurrentSize()));
if (!m_data.AllocAtLeast(m_dwTopFreeSlot+dwNumElem))
return FALSE;
for (DWORD dwLoop=0; dwLoop<dwNumElem; dwLoop++)
m_data.SetExistingElement(dwLoop+m_dwTopFreeSlot, pElems[dwLoop]);
m_dwTopFreeSlot+=dwNumElem;
return TRUE;
}
template <class T>
BOOL CBagArray<T>::AddElements(const CBagArray<T>& bag)
{
//ensure bag supplied isn't this bag
DNASSERT(this!=&bag);
if (!m_data.AllocAtLeast(m_dwTopFreeSlot+bag.GetNumElements()))
return FALSE;
for (DWORD dwLoop=0; dwLoop<bag.GetNumElements(); dwLoop++)
m_data.SetExistingElement(dwLoop+m_dwTopFreeSlot, bag.GetElementRef(dwLoop));
m_dwTopFreeSlot+=bag.GetNumElements();
return TRUE;
}
template <class T>
BOOL CBagArray<T>::RemoveElementByValue(const T& elem)
{
for (DWORD dwLoop=0; dwLoop<m_dwTopFreeSlot; dwLoop++)
{
if (m_data.GetElementRef(dwLoop)==elem)
{
m_dwTopFreeSlot--;
if (dwLoop!=m_dwTopFreeSlot)
m_data.SetExistingElement(dwLoop, m_data.GetElementRef(m_dwTopFreeSlot));
return TRUE;
}
}
return FALSE;
}
template <class T>
BOOL CBagArray<T>::FindElement(const T& elem, DWORD * pdwIndex) const
{
for (DWORD dwLoop=0; dwLoop<m_dwTopFreeSlot; dwLoop++)
{
if (m_data.GetElementRef(dwLoop)==elem)
{
*pdwIndex=dwLoop;
return TRUE;
}
}
return FALSE;
}