PTLib
Version 2.14.3
|
This template class maps the PAbstractList to a specific object type, and adds functionality that allows the list to be used as a last in first out stack. More...
#include <lists.h>
Public Member Functions | |
Construction | |
PStack () | |
Create a new, empty, stack. More... | |
Overrides from class PObject | |
virtual PObject * | Clone () const |
Make a complete duplicate of the stack. More... | |
New functions for class | |
virtual void | Push (T *obj) |
Add an object to the stack. More... | |
__inline void | push (T *obj) |
virtual T * | Pop () |
Remove the last object pushed onto the stack. More... | |
__inline void | pop () |
virtual T & | Top () |
Get the element that is currently on top of the stack without removing it. More... | |
__inline T & | front () |
![]() | |
virtual Comparison | Compare (const PObject &obj) const |
Get the relative rank of the two lists. More... | |
PINLINE | PAbstractList () |
Create a new, empty, list. More... | |
virtual PBoolean | SetSize (PINDEX newSize) |
This function is meaningless for lists. More... | |
virtual PINDEX | Append (PObject *obj) |
Append a new object to the collection. More... | |
virtual void | Prepend (PObject *obj) |
Append a new object to the collection. More... | |
virtual PINDEX | Insert (const PObject &before, PObject *obj) |
Insert a new object immediately before the specified object. More... | |
virtual P_DEPRECATED PINDEX | InsertAt (PINDEX index, PObject *obj) |
Insert a new object at the specified ordinal index. More... | |
virtual PBoolean | Remove (const PObject *obj) |
Remove the object from the collection. More... | |
virtual PObject * | RemoveHead () |
Remove the head object from the list. More... | |
virtual PObject * | RemoveTail () |
Remove the tail object from the list. More... | |
virtual P_DEPRECATED PObject * | RemoveAt (PINDEX index) |
Remove the object at the specified ordinal index from the collection. More... | |
virtual P_DEPRECATED PBoolean | SetAt (PINDEX index, PObject *val) |
Set the object at the specified ordinal position to the new value. More... | |
virtual P_DEPRECATED PBoolean | ReplaceAt (PINDEX index, PObject *val) |
Set the object at the specified ordinal position to the new value. More... | |
virtual P_DEPRECATED PObject * | GetAt (PINDEX index) const |
Get the object at the specified ordinal position. More... | |
virtual PINDEX | GetObjectsIndex (const PObject *obj) const |
Search the collection for the specific instance of the object. More... | |
virtual PINDEX | GetValuesIndex (const PObject &obj) const |
Search the collection for the specified value of the object. More... | |
![]() | |
PCollection (PINDEX initialSize=0) | |
Create a new collection. More... | |
virtual void | PrintOn (ostream &strm) const |
Print the collection on the stream. More... | |
__inline void | remove (const PObject *obj) |
virtual void | RemoveAll () |
Remove all of the elements in the collection. More... | |
__inline void | clear () |
PINLINE void | AllowDeleteObjects (PBoolean yes=true) |
Allow or disallow the deletion of the objects contained in the collection. More... | |
void | DisallowDeleteObjects () |
Disallow the deletion of the objects contained in the collection. More... | |
![]() | |
PContainer (PINDEX initialSize=0) | |
Create a new unique container. More... | |
PContainer (const PContainer &cont) | |
Create a new refernce to container. More... | |
PContainer & | operator= (const PContainer &cont) |
Assign one container reference to another. More... | |
virtual | ~PContainer () |
Destroy the container class. More... | |
virtual PINDEX | GetSize () const |
Get the current size of the container. More... | |
__inline size_t | size () const |
PBoolean | SetMinSize (PINDEX minSize) |
Set the minimum size of container. More... | |
virtual PBoolean | IsEmpty () const |
Determine if the container is empty. More... | |
__inline bool | empty () const |
PBoolean | IsUnique () const |
Determine if container is unique reference. More... | |
virtual PBoolean | MakeUnique () |
Make this instance to be the one and only reference to the container contents. More... | |
![]() | |
unsigned | GetTraceContextIdentifier () const |
Get PTRACE context identifier. More... | |
void | SetTraceContextIdentifier (unsigned id) |
void | GetTraceContextIdentifier (PObject &obj) |
void | GetTraceContextIdentifier (PObject *obj) |
void | SetTraceContextIdentifier (const PObject &obj) |
void | SetTraceContextIdentifier (const PObject *obj) |
virtual | ~PObject () |
template<class CLS > | |
CLS * | CloneAs () const |
As for Clone() but converts to specified type. More... | |
virtual PINDEX | HashFunction () const |
This function yields a hash value required by the PDictionary class. More... | |
virtual const char * | GetClass (unsigned ancestor=0) const |
Get the current dynamic type of the object instance. More... | |
PBoolean | IsClass (const char *cls) const |
virtual PBoolean | InternalIsDescendant (const char *clsName) const |
Determine if the dynamic type of the current instance is a descendent of the specified class. More... | |
__inline const PObject * | PTraceObjectInstance () const |
virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
Determine the byte wise comparison of two objects. More... | |
bool | operator== (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator!= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator< (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator> (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator<= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator>= (const PObject &obj) const |
Compare the two objects. More... | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
Protected Member Functions | |
PStack (int dummy, const PStack *c) | |
![]() | |
PINLINE PObject & | GetReferenceAt (PINDEX index) const |
PListElement * | FindElement (PINDEX index) const |
PListElement * | FindElement (const PObject &obj, PINDEX *index) const |
void | InsertElement (PListElement *element, PObject *obj) |
PObject * | RemoveElement (PListElement *element) |
![]() | |
PINLINE | PCollection (int dummy, const PCollection *coll) |
Constructor used in support of the Clone() function. More... | |
![]() | |
PContainer (int dummy, const PContainer *cont) | |
Constructor used in support of the Clone() function. More... | |
PContainer (PContainerReference &reference) | |
Construct using static PContainerReference. More... | |
virtual void | DestroyContents ()=0 |
Destroy the container contents. More... | |
virtual void | AssignContents (const PContainer &c) |
Copy the container contents. More... | |
void | CopyContents (const PContainer &c) |
Copy the container contents. More... | |
void | CloneContents (const PContainer *src) |
Create a duplicate of the container contents. More... | |
void | Destruct () |
Internal function called from container destructors. More... | |
virtual void | DestroyReference () |
Destroy the PContainerReference instance. More... | |
![]() | |
PObject () | |
Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Additional Inherited Members | |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
![]() | |
static const char * | Class () |
Get the name of the class as a C string. More... | |
static __inline const PObject * | PTraceObjectInstance (const char *) |
static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
Internal function caled from CompareObjectMemoryDirect() More... | |
![]() | |
typedef PListElement | Element |
![]() | |
PListInfo * | info |
![]() |
This template class maps the PAbstractList to a specific object type, and adds functionality that allows the list to be used as a last in first out stack.
The functions in this class primarily do all the appropriate casting of types.
By default, objects placed into the set will not be deleted when removed or when all references to the set are destroyed. This is different from the default on most collection classes.
Note that if templates are not used the PDECLARE_STACK
macro will simulate the template instantiation.
Create a new, empty, stack.
Note that by default, objects placed into the stack will not be deleted when removed or when all references to the stack are destroyed. This is different from the default on most collection classes.
References PCollection::DisallowDeleteObjects().
Referenced by PStack< T >::Clone().
References PContainerReference::deleteObjects, and PContainer::reference.
Make a complete duplicate of the stack.
Note that all objects in the array are also cloned, so this will make a complete copy of the stack.
Reimplemented from PObject.
References PNEW, and PStack< T >::PStack().
|
inline |
References PStack< T >::Top().
|
inlinevirtual |
Remove the last object pushed onto the stack.
References PAbstractList::RemoveHead().
Referenced by PStack< T >::pop().
|
inline |
References PStack< T >::Pop().
|
inlinevirtual |
Add an object to the stack.
This object will be on "top" of the stack and will be the object returned by the Pop()
function.
obj | Object to add to the stack. |
References PAbstractList::Prepend().
Referenced by PStack< T >::push().
|
inline |
References PStack< T >::Push().
|
inlinevirtual |
Get the element that is currently on top of the stack without removing it.
References PListElement::data, PContainer::GetSize(), PListInfo::head, PAbstractList::info, PAssert, and PStackEmpty.
Referenced by PStack< T >::front().