mirror of https://github.com/axmolengine/axmol.git
Array can be use in stl::sort() when not using vector inside
This commit is contained in:
parent
cd7773ba0e
commit
3476a843e2
|
@ -50,10 +50,10 @@ class RCPtr
|
||||||
public:
|
public:
|
||||||
//Construct using a C pointer
|
//Construct using a C pointer
|
||||||
//e.g. RCPtr< T > x = new T();
|
//e.g. RCPtr< T > x = new T();
|
||||||
RCPtr(T* ptr = NULL)
|
RCPtr(T* ptr = nullptr)
|
||||||
: _ptr(ptr)
|
: _ptr(ptr)
|
||||||
{
|
{
|
||||||
if(ptr != NULL) {ptr->retain();}
|
if(ptr != nullptr) {ptr->retain();}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Copy constructor
|
//Copy constructor
|
||||||
|
@ -69,13 +69,13 @@ public:
|
||||||
: _ptr(ptr._ptr)
|
: _ptr(ptr._ptr)
|
||||||
{
|
{
|
||||||
// printf("Array: Move Constructor: %p\n", this);
|
// printf("Array: Move Constructor: %p\n", this);
|
||||||
ptr._ptr = NULL;
|
ptr._ptr = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
~RCPtr()
|
~RCPtr()
|
||||||
{
|
{
|
||||||
// printf("Array: Destructor: %p\n", this);
|
// printf("Array: Destructor: %p\n", this);
|
||||||
if(_ptr != NULL) {_ptr->release();}
|
if(_ptr != nullptr) {_ptr->release();}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Assign a pointer
|
//Assign a pointer
|
||||||
|
@ -87,8 +87,8 @@ public:
|
||||||
//The following grab and release operations have to be performed
|
//The following grab and release operations have to be performed
|
||||||
//in that order to handle the case where ptr == _ptr
|
//in that order to handle the case where ptr == _ptr
|
||||||
//(See comment below by David Garlisch)
|
//(See comment below by David Garlisch)
|
||||||
if(ptr != NULL) {ptr->retain();}
|
if(ptr != nullptr) {ptr->retain();}
|
||||||
if(_ptr != NULL) {_ptr->release();}
|
if(_ptr != nullptr) {_ptr->release();}
|
||||||
_ptr = ptr;
|
_ptr = ptr;
|
||||||
return (*this);
|
return (*this);
|
||||||
}
|
}
|
||||||
|
@ -113,7 +113,7 @@ public:
|
||||||
T* operator->() const {return _ptr;} //x->member
|
T* operator->() const {return _ptr;} //x->member
|
||||||
T &operator*() const {return *_ptr;} //*x, (*x).member
|
T &operator*() const {return *_ptr;} //*x, (*x).member
|
||||||
explicit operator T*() const {return _ptr;} //T* y = x;
|
explicit operator T*() const {return _ptr;} //T* y = x;
|
||||||
explicit operator bool() const {return _ptr != NULL;} //if(x) {/*x is not NULL*/}
|
explicit operator bool() const {return _ptr != nullptr;} //if(x) {/*x is not NULL*/}
|
||||||
bool operator==(const RCPtr &ptr) {return _ptr == ptr._ptr;}
|
bool operator==(const RCPtr &ptr) {return _ptr == ptr._ptr;}
|
||||||
bool operator==(const T *ptr) {return _ptr == ptr;}
|
bool operator==(const T *ptr) {return _ptr == ptr;}
|
||||||
|
|
||||||
|
@ -273,7 +273,8 @@ public:
|
||||||
// Querying an Array
|
// Querying an Array
|
||||||
|
|
||||||
/** Returns element count of the array */
|
/** Returns element count of the array */
|
||||||
unsigned int count() const {
|
unsigned int count() const
|
||||||
|
{
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
return data.size();
|
return data.size();
|
||||||
#else
|
#else
|
||||||
|
@ -281,7 +282,8 @@ public:
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
/** Returns capacity of the array */
|
/** Returns capacity of the array */
|
||||||
unsigned int capacity() const {
|
unsigned int capacity() const
|
||||||
|
{
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
return data.capacity();
|
return data.capacity();
|
||||||
#else
|
#else
|
||||||
|
@ -293,7 +295,8 @@ public:
|
||||||
CC_DEPRECATED_ATTRIBUTE int indexOfObject(Object* object) const { return getIndexOfObject(object); }
|
CC_DEPRECATED_ATTRIBUTE int indexOfObject(Object* object) const { return getIndexOfObject(object); }
|
||||||
|
|
||||||
/** Returns an element with a certain index */
|
/** Returns an element with a certain index */
|
||||||
Object* getObjectAtIndex(int index) {
|
Object* getObjectAtIndex(int index)
|
||||||
|
{
|
||||||
CCASSERT(index>=0 && index < count(), "index out of range in objectAtIndex()");
|
CCASSERT(index>=0 && index < count(), "index out of range in objectAtIndex()");
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
return data[index].get();
|
return data[index].get();
|
||||||
|
@ -303,12 +306,14 @@ public:
|
||||||
}
|
}
|
||||||
CC_DEPRECATED_ATTRIBUTE Object* objectAtIndex(int index) { return getObjectAtIndex(index); }
|
CC_DEPRECATED_ATTRIBUTE Object* objectAtIndex(int index) { return getObjectAtIndex(index); }
|
||||||
/** Returns the last element of the array */
|
/** Returns the last element of the array */
|
||||||
Object* getLastObject() {
|
Object* getLastObject()
|
||||||
|
{
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
return data.back().get();
|
return data.back().get();
|
||||||
#else
|
#else
|
||||||
if( data->num > 0 )
|
if(data->num > 0)
|
||||||
return data->arr[data->num-1];
|
return data->arr[data->num-1];
|
||||||
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -331,7 +336,8 @@ public:
|
||||||
/** sets a certain object at a certain index */
|
/** sets a certain object at a certain index */
|
||||||
void setObject(Object* object, int index);
|
void setObject(Object* object, int index);
|
||||||
/** sets a certain object at a certain index without retaining. Use it with caution */
|
/** sets a certain object at a certain index without retaining. Use it with caution */
|
||||||
void fastSetObject(Object* object, int index) {
|
void fastSetObject(Object* object, int index)
|
||||||
|
{
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
setObject(object, index);
|
setObject(object, index);
|
||||||
#else
|
#else
|
||||||
|
@ -340,12 +346,13 @@ public:
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void swap( int indexOne, int indexTwo ) {
|
void swap( int indexOne, int indexTwo )
|
||||||
|
{
|
||||||
CCASSERT(indexOne >=0 && indexOne < count() && indexTwo >= 0 && indexTwo < count(), "Invalid indices");
|
CCASSERT(indexOne >=0 && indexOne < count() && indexTwo >= 0 && indexTwo < count(), "Invalid indices");
|
||||||
#if CC_USE_ARRAY_VECTOR
|
#if CC_USE_ARRAY_VECTOR
|
||||||
std::swap( data[indexOne], data[indexTwo] );
|
std::swap(data[indexOne], data[indexTwo]);
|
||||||
#else
|
#else
|
||||||
std::swap( data->arr[indexOne], data->arr[indexTwo] );
|
std::swap(data->arr[indexOne], data->arr[indexTwo]);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -398,7 +405,7 @@ public:
|
||||||
const_iterator cend() { return data.cend(); }
|
const_iterator cend() { return data.cend(); }
|
||||||
|
|
||||||
#else
|
#else
|
||||||
class ArrayIterator : public std::iterator<std::input_iterator_tag, Object>
|
class ArrayIterator : public std::iterator<std::input_iterator_tag, Object*>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ArrayIterator(int index, Array *array) : _index(index), _parent(array) {}
|
ArrayIterator(int index, Array *array) : _index(index), _parent(array) {}
|
||||||
|
@ -412,13 +419,59 @@ public:
|
||||||
ArrayIterator operator++(int dummy)
|
ArrayIterator operator++(int dummy)
|
||||||
{
|
{
|
||||||
ArrayIterator tmp(*this);
|
ArrayIterator tmp(*this);
|
||||||
(*this)++;
|
++_index;
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ArrayIterator& operator--()
|
||||||
|
{
|
||||||
|
--_index;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
ArrayIterator operator--(int dummy)
|
||||||
|
{
|
||||||
|
ArrayIterator tmp(*this);
|
||||||
|
--_index;
|
||||||
|
return tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
int operator-(const ArrayIterator& rhs) const
|
||||||
|
{
|
||||||
|
return _index - rhs._index;
|
||||||
|
}
|
||||||
|
ArrayIterator operator-(int d)
|
||||||
|
{
|
||||||
|
_index -= d;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
const ArrayIterator& operator-=(int d)
|
||||||
|
{
|
||||||
|
_index -= d;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
ArrayIterator operator+(int d)
|
||||||
|
{
|
||||||
|
_index += d;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
const ArrayIterator& operator+=(int d)
|
||||||
|
{
|
||||||
|
_index += d;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// add these function to make compiler happy when using std::sort(), it is meaningless
|
||||||
|
bool operator>=(const ArrayIterator& rhs) const { return false; }
|
||||||
|
bool operator<=(const ArrayIterator& rhs) const { return false; }
|
||||||
|
bool operator>(const ArrayIterator& rhs) const { return false; }
|
||||||
|
bool operator<(const ArrayIterator& rhs) const { return false; }
|
||||||
|
|
||||||
bool operator==(const ArrayIterator& rhs) { return _index == rhs._index; }
|
bool operator==(const ArrayIterator& rhs) { return _index == rhs._index; }
|
||||||
bool operator!=(const ArrayIterator& rhs) { return _index != rhs._index; }
|
bool operator!=(const ArrayIterator& rhs) { return _index != rhs._index; }
|
||||||
Object* operator*() { return _parent->getObjectAtIndex(_index); }
|
reference operator*() { return _parent->data->arr[_index]; }
|
||||||
Object* operator->() { return _parent->getObjectAtIndex(_index); }
|
value_type operator->() { return _parent->data->arr[_index];; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int _index;
|
int _index;
|
||||||
|
|
|
@ -24,6 +24,8 @@ THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "CCTouchDispatcher.h"
|
#include "CCTouchDispatcher.h"
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
#include "CCTouchHandler.h"
|
#include "CCTouchHandler.h"
|
||||||
#include "cocoa/CCArray.h"
|
#include "cocoa/CCArray.h"
|
||||||
#include "cocoa/CCSet.h"
|
#include "cocoa/CCSet.h"
|
||||||
|
@ -31,14 +33,13 @@ THE SOFTWARE.
|
||||||
#include "textures/CCTexture2D.h"
|
#include "textures/CCTexture2D.h"
|
||||||
#include "support/data_support/ccCArray.h"
|
#include "support/data_support/ccCArray.h"
|
||||||
#include "ccMacros.h"
|
#include "ccMacros.h"
|
||||||
#include <algorithm>
|
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used for sort
|
* Used for sort
|
||||||
*/
|
*/
|
||||||
#if 0
|
#if CC_USE_ARRAY_VECTOR
|
||||||
static int less(const RCPtr<Object>& p1, const RCPtr<Object>& p2)
|
static int less(const RCPtr<Object>& p1, const RCPtr<Object>& p2)
|
||||||
{
|
{
|
||||||
Object *o1, *o2;
|
Object *o1, *o2;
|
||||||
|
@ -306,8 +307,8 @@ TouchHandler* TouchDispatcher::findHandler(Array* pArray, TouchDelegate *pDelega
|
||||||
|
|
||||||
void TouchDispatcher::rearrangeHandlers(Array *array)
|
void TouchDispatcher::rearrangeHandlers(Array *array)
|
||||||
{
|
{
|
||||||
std::sort(array->data->arr, array->data->arr + array->data->num, less);
|
// std::sort(array->data->arr, array->data->arr + array->data->num, less);
|
||||||
// std::sort( std::begin(*array), std::end(*array), less);
|
std::sort( std::begin(*array), std::end(*array), less);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TouchDispatcher::setPriority(int nPriority, TouchDelegate *pDelegate)
|
void TouchDispatcher::setPriority(int nPriority, TouchDelegate *pDelegate)
|
||||||
|
|
Loading…
Reference in New Issue