TFixedArray Class Reference

#include <e32std.h>

class TFixedArray
Protected Attributes
T iRep
Public Member Functions
TFixedArray()
TFixedArray(const T *, TInt)
TArray< T >Array()
T &At(TInt)
const T &At(TInt)
T *Begin()
const T *Begin()
voidCopy(const T *, TInt)
TInt Count()
voidDeleteAll()
T *End()
const T *End()
TInt Length()
voidReset()
T &operator[](TInt)
const T &operator[](TInt)
Protected Member Functions
const TAny *AtFunctionR(const CBase *, TInt)
TInt CountFunctionR(const CBase *)
TBool InRange(TInt)

Detailed Description

A thin wrapper class for C++ arrays allowing automatic checking of index values to ensure that all accesses are legal.

The class also supports the deletion of objects.

The class is templated, based on a class type and an integer value. The class type defines the type of object contained in the array; the integer value defines the size (dimension) of the array.

A wrapper object can be:

1. embedded in objects allocated on the heap.

2. used on the program stack.

Member Attribute Documentation

iRep

T iRep[protected]

Constructor & Destructor Documentation

TFixedArray ( )

TFixedArray()[inline]

Default constructor.

Constructs an uninitialised C++ array.

TFixedArray ( const T *, TInt )

TFixedArray(const T *aList,
TIntaLength
)[inline]

Constructs a C++ array initialised with the specified objects.

Parameters
aListA pointer to a set of contiguous objects.
aLengthThe number of contiguous objects to be copied. This value must not be negative and must not be greater than the size of the array as defined by the integer template parameter.
Panic Codes
USER133, in a debug build only, if aLength is negative or is greater than the size of the array as defined by the integer template parameter.

Member Function Documentation

Array ( )

TArray< T >Array()const [inline]

Creates and returns a generic array for this C++ array.

Return Value
A generic array for this C++ array.

At ( TInt )

T &At(TIntaIndex)[inline]

Gets a reference to the specified element within the C++ array.

Parameters
aIndexThe position of the element within the array. This is an offset value; a zero value refers to the first element in the array. This value must be greater than or equal to zero and less than the size of the array.
Return Value
A reference to an element of the array.
Panic Codes
USER133, if aIndex is negative or greater than or equal to the size of the array as defined by the integer template parameter.

At ( TInt )

const T &At(TIntaIndex)const [inline]

Gets a const reference to the specified element within the C++ array.

Parameters
aIndexThe position of the element within the array. This is an offset value; a zero value refers to the first element in the array. This value must be greater than or equal to zero and less than the size of the array.
Return Value
A const reference to an element of the array; the element cannot be changed through this reference.
Panic Codes
USER133, in a debug build only, if aIndex is negative or greater than or equal to the size of the array as defined by the integer template parameter.

AtFunctionR ( const CBase *, TInt )

const TAny *AtFunctionR(const CBase *aThis,
TIntaIndex
)[protected, static, inline]

Begin ( )

T *Begin()[inline]

Gets a pointer to the first element of the array.

Return Value
A pointer to the first element of the array.

Begin ( )

const T *Begin()const [inline]

Gets a pointer to the first element of the array.

Return Value
A pointer to a const element of the array.

Copy ( const T *, TInt )

voidCopy(const T *aList,
TIntaLength
)[inline]

Copies the specified set of contiguous objects into the C++ array.

The copy operation starts at the beginning of the array, replacing any existing data.

Parameters
aListA pointer to a set of contiguous objects.
aLengthThe number of contiguous objects to be copied. This value must not be negative and must not be greater than the size of the array as defined by the integer template parameter.
Panic Codes
USER133, in a debug build only, if aLength is negative or is greater than the size of the array as defined by the integer template parameter.

Count ( )

TInt Count()const [inline]

Gets the size of the array.

For any instance of this class, the array size is fixed and has the same value as the integer template parameter.

Return Value
The size of the array.

CountFunctionR ( const CBase * )

TInt CountFunctionR(const CBase *aThis)[protected, static, inline]

DeleteAll ( )

voidDeleteAll()[inline]

Invokes the delete operator on every member of the array.

The function can only be used for arrays of pointers to CBase derived objects.

If the array is to be used after a call to this function, it is good practice to call TFixedArray<class T,TInt S>::Reset() to set all array elements to NULL.

End ( )

T *End()[inline]

Gets a pointer to the first byte following the end of the array.

Return Value
A pointer to the first byte following the end of the array.

End ( )

const T *End()const [inline]

Gets a pointer to the first byte following the end of the array.

Return Value
A pointer to the const first byte following the end of the array.

InRange ( TInt )

TBool InRange(TIntaIndex)[protected, static, inline]

Length ( )

TInt Length()const [inline]

Gets the size of an array element, in bytes.

Return Value
The size of an array element, in bytes.

Reset ( )

voidReset()[inline]

Fills every element of the array with binary zeroes.

operator[] ( TInt )

T &operator[](TIntaIndex)[inline]

Gets a reference to the specified element within the C++ array.

Parameters
aIndexThe position of the element within the array. This is an offset value; a zero value refers to the first element in the array. This value must be greater than or equal to zero and less than the size of the array.
Return Value
A reference to an element of the array.
Panic Codes
USER133, in a debug build only, if aIndex is negative or greater than or equal to the size of the array as defined by the integer template parameter.

operator[] ( TInt )

const T &operator[](TIntaIndex)const [inline]

Gets a const reference to the specified element within the C++ array.

Parameters
aIndexThe position of the element within the array. This is an offset value; a zero value refers to the first element in the array. This value must be greater than or equal to zero and less than the size of the array.
Return Value
A const reference to an element of the array; the element cannot be changed through this reference.
Panic Codes
USER133, in a debug build only, if aIndex is negative or greater than or equal to the size of the array as defined by the integer template parameter.