Serious-Engine/Sources/Engine/Templates/StaticArray.h

98 lines
2.6 KiB
C
Raw Normal View History

2016-03-12 01:20:51 +01:00
/* Copyright (c) 2002-2012 Croteam Ltd.
This program is free software; you can redistribute it and/or modify
it under the terms of version 2 of the GNU General Public License as published by
the Free Software Foundation
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */
2016-03-11 14:57:17 +01:00
#ifndef SE_INCL_STATICARRAY_H
#define SE_INCL_STATICARRAY_H
#ifdef PRAGMA_ONCE
#pragma once
#endif
/*
* Template class for array with static allocation of objects.
*/
template<class Type>
class CStaticArray {
public:
INDEX sa_Count; // number of objects in array
Type *sa_Array; // objects
public:
/* Default constructor. */
inline CStaticArray(void)
{
sa_Count=0;
sa_Array=NULL;
}
2016-03-11 14:57:17 +01:00
/* Destructor. */
inline ~CStaticArray(void)
{
// if some objects were allocated
if (sa_Count!=0) {
// destroy them
Delete();
}
}
2016-03-11 14:57:17 +01:00
void operator=(const CStaticArray<Type> &arOriginal);
/* Create a given number of objects. */
inline void New(INDEX iCount);
/* Expand stack size but keep old objects. */
inline void Expand(INDEX iNewCount);
/* Destroy all objects. */
inline void Delete(void)
{
ASSERT(this!=NULL);
ASSERT(sa_Count!=0 && sa_Array!=NULL);
delete[] sa_Array;
sa_Count = 0;
sa_Array = NULL;
}
2016-03-11 14:57:17 +01:00
/* Destroy all objects, and reset the array to initial (empty) state. */
2019-08-17 15:53:53 +02:00
inline void Clear(void) {
if (sa_Count!=0) Delete();
}
2016-03-11 14:57:17 +01:00
/* Random access operator. */
inline Type &operator[](INDEX iObject)
{
ASSERT(this!=NULL);
ASSERT(iObject>=0 && iObject<sa_Count); // check bounds
return sa_Array[iObject];
}
inline const Type &operator[](INDEX iObject) const
{
ASSERT(this!=NULL);
ASSERT(iObject>=0 && iObject<sa_Count); // check bounds
return sa_Array[iObject];
}
2016-03-11 14:57:17 +01:00
/* Get number of objects in array. */
inline INDEX Count(void) const { return sa_Count; }
2016-03-11 14:57:17 +01:00
/* Get index of a object from it's pointer. */
INDEX Index(Type *ptObject);
/* Copy all elements of another array into this one. */
void CopyArray(const CStaticArray<Type> &arOriginal);
/* Move all elements of another array into this one. */
void MoveArray(CStaticArray<Type> &arOther);
};
#endif /* include-once check. */