Data Structures | Public Types | Public Member Functions | Static Public Member Functions | Data Fields | Private Member Functions | Private Attributes | Friends
FixedList Class Reference

A 1D vector of objects of type <T> with a fixed size <Size>. More...

Inheritance diagram for FixedList:
Inheritance graph
[legend]

Data Structures

class  Hash
 Hashing function class. More...
 

Public Types

typedef T value_type
 Type of values the FixedList contains. More...
 
typedef Treference
 Type that can be used for storing into. More...
 
typedef label difference_type
 The type that can represent the difference between any two. More...
 
typedef label size_type
 The type that can represent the size of a FixedList. More...
 
typedef Titerator
 Random access iterator for traversing FixedList. More...
 
typedef Treverse_iterator
 Reverse iterator for reverse traversal of FixedList. More...
 

Public Member Functions

 FixedList ()
 Null constructor. More...
 
 FixedList (const T v[Size])
 Construct from C-array. More...
 
 FixedList (const T &)
 Construct from value. More...
 
 FixedList (const UList< T > &)
 Construct from UList. More...
 
 FixedList (const SLList< T > &)
 Construct from SLList. More...
 
 FixedList (const FixedList< T, Size > &)
 Copy constructor. More...
 
 FixedList (Istream &)
 Construct from Istream. More...
 
autoPtr< FixedList< T, Size > > clone () const
 Clone. More...
 
label fcIndex (const label i) const
 Return the forward circular index, i.e. the next index. More...
 
label rcIndex (const label i) const
 Return the reverse circular index, i.e. the previous index. More...
 
const Tcdata () const
 Return a const pointer to the first data element,. More...
 
Tdata ()
 Return a pointer to the first data element,. More...
 
Tfirst ()
 Return the first element of the list. More...
 
const Tfirst () const
 Return first element of the list. More...
 
Tlast ()
 Return the last element of the list. More...
 
const Tlast () const
 Return the last element of the list. More...
 
void checkStart (const label start) const
 Check start is within valid range (0 ... size-1). More...
 
void checkSize (const label size) const
 Check size is within valid range (0 ... size). More...
 
void checkIndex (const label i) const
 Check index i is within valid range (0 ... size-1). More...
 
void resize (const label)
 Dummy resize function. More...
 
void setSize (const label)
 Dummy setSize function. More...
 
void transfer (const FixedList< T, Size > &)
 Copy (not transfer) the argument contents. More...
 
void writeEntry (Ostream &) const
 Write the FixedList as a dictionary entry. More...
 
void writeEntry (const word &keyword, Ostream &) const
 Write the FixedList as a dictionary entry with keyword. More...
 
Toperator[] (const label)
 Return element of FixedList. More...
 
const Toperator[] (const label) const
 Return element of constant FixedList. More...
 
void operator= (const T v[Size])
 Assignment from array operator. Takes linear time. More...
 
void operator= (const UList< T > &)
 Assignment from UList operator. Takes linear time. More...
 
void operator= (const SLList< T > &)
 Assignment from SLList operator. Takes linear time. More...
 
void operator= (const T &)
 Assignment of all entries to the given value. More...
 
iterator begin ()
 Return an iterator to begin traversing the FixedList. More...
 
iterator end ()
 Return an iterator to end traversing the FixedList. More...
 
const_iterator cbegin () const
 Return const_iterator to begin traversing the constant FixedList. More...
 
const_iterator cend () const
 Return const_iterator to end traversing the constant FixedList. More...
 
const_iterator begin () const
 Return const_iterator to begin traversing the constant FixedList. More...
 
const_iterator end () const
 Return const_iterator to end traversing the constant FixedList. More...
 
reverse_iterator rbegin ()
 Return reverse_iterator to begin reverse traversing the FixedList. More...
 
reverse_iterator rend ()
 Return reverse_iterator to end reverse traversing the FixedList. More...
 
const_reverse_iterator crbegin () const
 Return const_reverse_iterator to begin reverse traversing FixedList. More...
 
const_reverse_iterator crend () const
 Return const_reverse_iterator to end reverse traversing FixedList. More...
 
const_reverse_iterator rbegin () const
 Return const_reverse_iterator to begin reverse traversing FixedList. More...
 
const_reverse_iterator rend () const
 Return const_reverse_iterator to end reverse traversing FixedList. More...
 
label size () const
 Return the number of elements in the FixedList. More...
 
label max_size () const
 Return size of the largest possible FixedList. More...
 
bool empty () const
 Return true if the FixedList is empty (ie, size() is zero). More...
 
void swap (FixedList< T, Size > &)
 Swap two FixedLists of the same type in constant time. More...
 
bool operator== (const FixedList< T, Size > &) const
 Equality operation on FixedLists of the same type. More...
 
bool operator!= (const FixedList< T, Size > &) const
 The opposite of the equality operation. Takes linear time. More...
 
bool operator< (const FixedList< T, Size > &) const
 Compare two FixedLists lexicographically. Takes linear time. More...
 
bool operator> (const FixedList< T, Size > &) const
 Compare two FixedLists lexicographically. Takes linear time. More...
 
bool operator<= (const FixedList< T, Size > &) const
 Return true if !(a > b). Takes linear time. More...
 
bool operator>= (const FixedList< T, Size > &) const
 Return true if !(a < b). Takes linear time. More...
 

Static Public Member Functions

static const FixedList< T, Size > & null ()
 Return a null FixedList. More...
 

Data Fields

const typedef Tconst_reference
 Type that can be used for storing into. More...
 
const typedef Tconst_iterator
 Random access iterator for traversing FixedList. More...
 
const typedef Tconst_reverse_iterator
 Reverse iterator for reverse traversal of constant FixedList. More...
 

Private Member Functions

 StaticAssert (Size &&Size<=INT_MAX)
 Size must be positive (non-zero) and also fit as a signed value. More...
 

Private Attributes

T v_ [Size]
 Vector of values of type T of size Size. More...
 

Friends

Istreamoperator>> (Istream &, FixedList< T, Size > &)
 Read List from Istream, discarding contents of existing List. More...
 
Ostreamoperator (Ostream &, const FixedList< T, Size > &)
 

Detailed Description

A 1D vector of objects of type <T> with a fixed size <Size>.

Source files

Definition at line 53 of file FixedList.H.

Member Typedef Documentation

◆ value_type

typedef T value_type

Type of values the FixedList contains.

Definition at line 225 of file FixedList.H.

◆ reference

typedef T& reference

Type that can be used for storing into.

FixedList::value_type objects.

Definition at line 229 of file FixedList.H.

◆ difference_type

The type that can represent the difference between any two.

FixedList iterator objects.

Definition at line 237 of file FixedList.H.

◆ size_type

typedef label size_type

The type that can represent the size of a FixedList.

Definition at line 240 of file FixedList.H.

◆ iterator

typedef T* iterator

Random access iterator for traversing FixedList.

Definition at line 246 of file FixedList.H.

◆ reverse_iterator

typedef T* reverse_iterator

Reverse iterator for reverse traversal of FixedList.

Definition at line 276 of file FixedList.H.

Constructor & Destructor Documentation

◆ FixedList() [1/7]

FixedList ( )
inline

Null constructor.

Definition at line 33 of file FixedListI.H.

◆ FixedList() [2/7]

FixedList ( const T  v[Size])
inlineexplicit

Construct from C-array.

Definition at line 38 of file FixedListI.H.

◆ FixedList() [3/7]

FixedList ( const T )
inlineexplicit

Construct from value.

◆ FixedList() [4/7]

FixedList ( const UList< T > &  )
inlineexplicit

Construct from UList.

◆ FixedList() [5/7]

FixedList ( const SLList< T > &  )
inlineexplicit

Construct from SLList.

◆ FixedList() [6/7]

FixedList ( const FixedList< T, Size > &  )
inline

Copy constructor.

◆ FixedList() [7/7]

FixedList ( Istream )

Construct from Istream.

Member Function Documentation

◆ StaticAssert()

StaticAssert ( Size &&Size<=  INT_MAX)
private

Size must be positive (non-zero) and also fit as a signed value.

◆ null()

const Foam::FixedList< T, Size > & null ( )
inlinestatic

Return a null FixedList.

Definition at line 108 of file FixedListI.H.

◆ clone()

Foam::autoPtr< Foam::FixedList< T, Size > > clone ( ) const
inline

Clone.

Definition at line 99 of file FixedListI.H.

◆ fcIndex()

Foam::label fcIndex ( const label  i) const
inline

◆ rcIndex()

Foam::label rcIndex ( const label  i) const
inline

Return the reverse circular index, i.e. the previous index.

which returns to the last at the beginning of the list

Definition at line 122 of file FixedListI.H.

Referenced by isoSurfaceCell::findCommonPoints(), isoSurfaceCell::genPointTris(), surfaceNeiOp::operator()(), and intersectedSurface::sameEdgeOrder().

Here is the caller graph for this function:

◆ cdata()

const T * cdata ( ) const
inline

Return a const pointer to the first data element,.

similar to the STL front() method and the string::data() method This can be used (with caution) when interfacing with C code.

Definition at line 196 of file FixedListI.H.

◆ data()

T * data ( )
inline

Return a pointer to the first data element,.

similar to the STL front() method and the string::data() method This can be used (with caution) when interfacing with C code.

Definition at line 204 of file FixedListI.H.

◆ first() [1/2]

T & first ( )
inline

Return the first element of the list.

Definition at line 211 of file FixedListI.H.

Referenced by LangmuirHinshelwoodReactionRate::LangmuirHinshelwoodReactionRate(), and LangmuirHinshelwoodReactionRate::write().

Here is the caller graph for this function:

◆ first() [2/2]

const T & first ( ) const
inline

Return first element of the list.

Definition at line 218 of file FixedListI.H.

◆ last() [1/2]

T & last ( )
inline

Return the last element of the list.

Definition at line 225 of file FixedListI.H.

◆ last() [2/2]

const T & last ( ) const
inline

Return the last element of the list.

Definition at line 232 of file FixedListI.H.

◆ checkStart()

void checkStart ( const label  start) const
inline

Check start is within valid range (0 ... size-1).

Definition at line 130 of file FixedListI.H.

◆ checkSize()

void checkSize ( const label  size) const
inline

Check size is within valid range (0 ... size).

Definition at line 143 of file FixedListI.H.

◆ checkIndex()

void checkIndex ( const label  i) const
inline

Check index i is within valid range (0 ... size-1).

Definition at line 157 of file FixedListI.H.

◆ resize()

void resize ( const label  s)
inline

Dummy resize function.

needed to make FixedList consistent with List

Definition at line 169 of file FixedListI.H.

◆ setSize()

void setSize ( const label  s)
inline

Dummy setSize function.

needed to make FixedList consistent with List

Definition at line 177 of file FixedListI.H.

Referenced by edgeExtractor::faceEvaluator::bestPatchTopological(), edgeExtractor::checkFacePatchesTopology(), shellSurfaces::findHigherGapLevel(), refinementHistory::refinementHistory(), and refinementSurfaces::refinementSurfaces().

Here is the caller graph for this function:

◆ transfer()

void transfer ( const FixedList< T, Size > &  lst)
inline

Copy (not transfer) the argument contents.

needed to make FixedList consistent with List

Definition at line 185 of file FixedListI.H.

Referenced by isoSurface::trimToBox().

Here is the caller graph for this function:

◆ writeEntry() [1/2]

void writeEntry ( Ostream ) const

Write the FixedList as a dictionary entry.

◆ writeEntry() [2/2]

void writeEntry ( const word keyword,
Ostream  
) const

Write the FixedList as a dictionary entry with keyword.

◆ operator[]() [1/2]

T& operator[] ( const  label)
inline

Return element of FixedList.

◆ operator[]() [2/2]

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

Return element of constant FixedList.

◆ operator=() [1/4]

void operator= ( const T  v[Size])
inline

Assignment from array operator. Takes linear time.

◆ operator=() [2/4]

void operator= ( const UList< T > &  )
inline

Assignment from UList operator. Takes linear time.

◆ operator=() [3/4]

void operator= ( const SLList< T > &  )
inline

Assignment from SLList operator. Takes linear time.

◆ operator=() [4/4]

void operator= ( const T )
inline

Assignment of all entries to the given value.

◆ begin() [1/2]

Foam::FixedList< T, Size >::iterator begin ( )
inline

Return an iterator to begin traversing the FixedList.

Definition at line 313 of file FixedListI.H.

◆ end() [1/2]

Foam::FixedList< T, Size >::iterator end ( )
inline

Return an iterator to end traversing the FixedList.

Definition at line 337 of file FixedListI.H.

◆ cbegin()

Foam::FixedList< T, Size >::const_iterator cbegin ( ) const
inline

Return const_iterator to begin traversing the constant FixedList.

Definition at line 329 of file FixedListI.H.

Referenced by FixedList< bool, Foam::pTraits< Type >::nComponents >::operator<().

Here is the caller graph for this function:

◆ cend()

Foam::FixedList< T, Size >::const_iterator cend ( ) const
inline

Return const_iterator to end traversing the constant FixedList.

Definition at line 353 of file FixedListI.H.

Referenced by FixedList< bool, Foam::pTraits< Type >::nComponents >::operator<().

Here is the caller graph for this function:

◆ begin() [2/2]

Foam::FixedList< T, Size >::const_iterator begin ( ) const
inline

Return const_iterator to begin traversing the constant FixedList.

Definition at line 321 of file FixedListI.H.

◆ end() [2/2]

Foam::FixedList< T, Size >::const_iterator end ( ) const
inline

Return const_iterator to end traversing the constant FixedList.

Definition at line 345 of file FixedListI.H.

◆ rbegin() [1/2]

Foam::FixedList< T, Size >::iterator rbegin ( )
inline

Return reverse_iterator to begin reverse traversing the FixedList.

Definition at line 361 of file FixedListI.H.

◆ rend() [1/2]

Foam::FixedList< T, Size >::iterator rend ( )
inline

Return reverse_iterator to end reverse traversing the FixedList.

Definition at line 385 of file FixedListI.H.

◆ crbegin()

Foam::FixedList< T, Size >::const_iterator crbegin ( ) const
inline

Return const_reverse_iterator to begin reverse traversing FixedList.

Definition at line 377 of file FixedListI.H.

◆ crend()

Foam::FixedList< T, Size >::const_iterator crend ( ) const
inline

Return const_reverse_iterator to end reverse traversing FixedList.

Definition at line 401 of file FixedListI.H.

◆ rbegin() [2/2]

Foam::FixedList< T, Size >::const_iterator rbegin ( ) const
inline

Return const_reverse_iterator to begin reverse traversing FixedList.

Definition at line 369 of file FixedListI.H.

◆ rend() [2/2]

Foam::FixedList< T, Size >::const_iterator rend ( ) const
inline

Return const_reverse_iterator to end reverse traversing FixedList.

Definition at line 393 of file FixedListI.H.

◆ size()

Foam::label size ( ) const
inline

◆ max_size()

Foam::label max_size ( ) const
inline

Return size of the largest possible FixedList.

Definition at line 415 of file FixedListI.H.

◆ empty()

bool empty ( ) const
inline

Return true if the FixedList is empty (ie, size() is zero).

Definition at line 422 of file FixedListI.H.

◆ swap()

void swap ( FixedList< T, Size > &  a)

Swap two FixedLists of the same type in constant time.

Definition at line 32 of file FixedList.C.

Referenced by main().

Here is the caller graph for this function:

◆ operator==()

bool operator== ( const FixedList< T, Size > &  a) const

Equality operation on FixedLists of the same type.

Returns true when the FixedLists are elementwise equal (using FixedList::value_type::operator==). Takes linear time.

Definition at line 48 of file FixedList.C.

◆ operator!=()

bool operator!= ( const FixedList< T, Size > &  a) const

The opposite of the equality operation. Takes linear time.

Definition at line 64 of file FixedList.C.

◆ operator<()

bool operator< ( const FixedList< T, Size > &  a) const

Compare two FixedLists lexicographically. Takes linear time.

Definition at line 71 of file FixedList.C.

◆ operator>()

bool operator> ( const FixedList< T, Size > &  a) const

Compare two FixedLists lexicographically. Takes linear time.

Definition at line 102 of file FixedList.C.

◆ operator<=()

bool operator<= ( const FixedList< T, Size > &  a) const

Return true if !(a > b). Takes linear time.

Definition at line 109 of file FixedList.C.

◆ operator>=()

bool operator>= ( const FixedList< T, Size > &  a) const

Return true if !(a < b). Takes linear time.

Definition at line 116 of file FixedList.C.

Friends And Related Function Documentation

◆ operator>>

Istream& operator>> ( Istream ,
FixedList< T, Size > &   
)
friend

Read List from Istream, discarding contents of existing List.

◆ operator

Ostream& operator ( Ostream ,
const FixedList< T, Size > &   
)
friend

Field Documentation

◆ const_reference

const typedef T& const_reference

Type that can be used for storing into.

constant FixedList::value_type objects

Definition at line 233 of file FixedList.H.

◆ const_iterator

const typedef T* const_iterator

Random access iterator for traversing FixedList.

Definition at line 258 of file FixedList.H.

◆ const_reverse_iterator

const typedef T* const_reverse_iterator

Reverse iterator for reverse traversal of constant FixedList.

Definition at line 288 of file FixedList.H.

◆ v_

T v_[Size]
private

Vector of values of type T of size Size.

Definition at line 78 of file FixedList.H.

Referenced by FixedList::Hash< HashT >::operator()().


The documentation for this class was generated from the following files: