2010-07-06 20:23:58 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2010 cocos2d-x.org
|
|
|
|
|
2010-07-06 20:55:05 +08:00
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
2010-07-06 20:23:58 +08:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
2010-07-12 17:01:26 +08:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "NSMutableArray.h"
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <vector>
|
2010-07-14 11:02:06 +08:00
|
|
|
#include <assert.h>
|
2010-07-12 17:01:26 +08:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
NSMutableArray<T>::NSMutableArray(UINT32 uSize)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
2010-07-20 10:45:38 +08:00
|
|
|
m_array = m_array.resize(uSize);
|
2010-07-12 17:01:26 +08:00
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
NSMutableArray<T>::~NSMutableArray(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
removeAllObjects();
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
typename NSMutableArray<T>::NSMutableArrayIterator NSMutableArray<T>::begin(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
return m_array.begin();
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
typename NSMutableArray<T>::NSMutableArrayIterator NSMutableArray<T>::end(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
return m_array.end();
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::addObject(T pObject)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
// make sure the pointer is not null
|
|
|
|
if (pObject == NULL)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// add the refrence
|
|
|
|
pObject->retain();
|
|
|
|
|
|
|
|
// the array is full, push back
|
|
|
|
m_array.push_back(pObject);
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::insertObjectAtIndex(T pObject, UInt32 uIndex)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
// make sure the object is not null
|
|
|
|
if (pObject == NULL)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// add the refrence of the object
|
|
|
|
pObject->retain();
|
|
|
|
|
|
|
|
// insert the object
|
|
|
|
m_array.insert(m_array.begin() + uIndex, pObject);
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::addObjectsFromArray(NSMutableArray<T> *pArray)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (pArray && pArray->count() > 0)
|
|
|
|
{
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
for (iter = pArray->begin(); iter != pArray->end(); ++iter)
|
|
|
|
{
|
|
|
|
if (*iter)
|
|
|
|
{
|
|
|
|
m_array.push_back(*iter);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
UINT32 NSMutableArray<T>::count(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
return m_array.size();
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::removeObject(T pObject)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (m_array.empty() || (! pObject))
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
int i;
|
|
|
|
for (iter = m_array.begin(), i = 0; iter != m_array.end(); ++iter, ++i)
|
|
|
|
{
|
|
|
|
if (*iter == pObject)
|
|
|
|
{
|
|
|
|
m_array.erase(iter);
|
|
|
|
|
|
|
|
pObject->release();
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::removeAllObjects(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
for (iter = m_array.begin(); iter != m_array.end(); ++iter)
|
|
|
|
{
|
|
|
|
if (*iter)
|
|
|
|
{
|
|
|
|
(*iter)->release();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
m_array.clear();
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::removeLastObject(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
INT32 count = this->count();
|
|
|
|
|
|
|
|
if (count > 0)
|
|
|
|
{
|
|
|
|
removeObjectAtIndex(count - 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::removeObjectAtIndex(UINT32 uIndex)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (m_array.empty() || uIndex == 0)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
T pObject = m_array.at(uIndex);
|
2010-07-12 17:01:26 +08:00
|
|
|
if (pObject)
|
|
|
|
{
|
|
|
|
pObject->release();
|
|
|
|
}
|
|
|
|
|
|
|
|
m_array.erase(m_array.begin() + uIndex);
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
bool NSMutableArray<T>::containsObject(T pObject)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (m_array.empty() || (! pObject))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool bRet = false;
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
for (iter = m_array.begin(); iter != m_array.end(); ++iter)
|
|
|
|
{
|
|
|
|
if (*iter == pObject)
|
|
|
|
{
|
|
|
|
bRet = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
void NSMutableArray<T>::replaceObjectAtIndex(UINT32 uIndex, T pObject)
|
2010-07-16 14:19:21 +08:00
|
|
|
{
|
2010-07-21 10:07:46 +08:00
|
|
|
if (uIndex >= count())
|
2010-07-16 14:19:21 +08:00
|
|
|
{
|
2010-07-21 10:07:46 +08:00
|
|
|
// index out of range
|
|
|
|
assert(0);
|
2010-07-16 14:19:21 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// release the object
|
2010-07-21 10:07:46 +08:00
|
|
|
T pTmp = m_array[uIndex];
|
|
|
|
if (pTmp)
|
2010-07-16 14:19:21 +08:00
|
|
|
{
|
2010-07-21 10:07:46 +08:00
|
|
|
pTmp->release();
|
2010-07-16 14:19:21 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
m_array[uIndex] = pObject;
|
2010-07-21 10:07:46 +08:00
|
|
|
|
|
|
|
// add the ref
|
|
|
|
if (pObject)
|
|
|
|
{
|
|
|
|
pObject->retain();
|
|
|
|
}
|
2010-07-16 14:19:21 +08:00
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
UINT32 NSMutableArray<T>::getIndexOfObject(T pObject)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (m_array.empty() || (pObject == NULL))
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
UINT32 uRet = 0;
|
|
|
|
INT32 i;
|
|
|
|
for (iter = m_array.begin(), i = 0; iter != m_array.end(); ++iter, ++i)
|
|
|
|
{
|
|
|
|
if (*iter == pObject)
|
|
|
|
{
|
|
|
|
uRet = i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return uRet;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
T NSMutableArray<T>::getLastObject(void)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
2010-07-20 10:45:38 +08:00
|
|
|
T pObject = NULL;
|
2010-07-12 17:01:26 +08:00
|
|
|
INT32 count = this->count();
|
|
|
|
|
|
|
|
if (count > 0)
|
|
|
|
{
|
|
|
|
pObject = m_array[count - 1];
|
|
|
|
}
|
|
|
|
|
|
|
|
return pObject;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
NSMutableArray<T>* arrayWithObjects(T pObject1, ...)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T> *pArray = new NSMutableArray<T>();
|
2010-07-12 17:01:26 +08:00
|
|
|
|
|
|
|
va_list params;
|
|
|
|
va_start(params, pObject1);
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
T pFirst = pObject1;
|
2010-07-12 17:01:26 +08:00
|
|
|
while (pFirst)
|
|
|
|
{
|
|
|
|
pArray->addObject(pFirst);
|
2010-07-20 10:45:38 +08:00
|
|
|
pFirst = va_arg(params, T);
|
2010-07-12 17:01:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
va_end(params);
|
|
|
|
|
|
|
|
return pArray;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
NSMutableArray<T>* NSMutableArray<T>::arrayWithArray(NSMutableArray<T> *pArray)
|
2010-07-12 17:01:26 +08:00
|
|
|
{
|
|
|
|
if (pArray == NULL)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
NSMutableArray<T> *pNewArray = new NSMutableArray<T>();
|
|
|
|
NSMutableArray<T>::NSMutableArrayIterator iter;
|
2010-07-12 17:01:26 +08:00
|
|
|
for (iter = pArray->begin(); iter != pArray->end(); ++iter)
|
|
|
|
{
|
|
|
|
pNewArray->addObject(*iter);
|
|
|
|
}
|
|
|
|
|
|
|
|
return pNewArray;
|
|
|
|
}
|
2010-07-14 11:02:06 +08:00
|
|
|
|
2010-07-20 10:45:38 +08:00
|
|
|
template<class T>
|
|
|
|
T NSMutableArray<T>::getObjectAtIndex(UINT32 uIndex)
|
2010-07-14 11:02:06 +08:00
|
|
|
{
|
|
|
|
assert(uIndex < count());
|
|
|
|
|
2010-07-21 10:07:46 +08:00
|
|
|
if (uIndex >= count())
|
2010-07-14 11:02:06 +08:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return m_array[uIndex];
|
|
|
|
}
|