|
PTLib
Version 2.18.8
|
This template class maps the PAbstractSortedList to a specific object type. More...
#include <lists.h>


Classes | |
| class | const_iterator |
| class | iterator |
Public Member Functions | |
Construction | |
| PSortedList () | |
| Create a new, empty, sorted list. More... | |
Overrides from class PObject | |
| virtual PObject * | Clone () const |
| Make a complete duplicate of the list. More... | |
New functions for class | |
| T & | operator[] (PINDEX index) const |
| Retrieve a reference to the object in the list. More... | |
Public Member Functions inherited from PAbstractSortedList | |
| PAbstractSortedList () | |
| Create a new, empty, sorted list. More... | |
| virtual Comparison | Compare (const PObject &obj) const |
| Get the relative rank of the two lists. More... | |
| virtual PBoolean | SetSize (PINDEX newSize) |
| This function is meaningless for lists. More... | |
| virtual PINDEX | Append (PObject *obj) |
| Add a new object to the collection. More... | |
| virtual PINDEX | Insert (const PObject &before, PObject *obj) |
| Add a new object to the collection. More... | |
| virtual PINDEX | InsertAt (PINDEX index, PObject *obj) |
| Add a new object to the collection. More... | |
| virtual PBoolean | Remove (const PObject *obj) |
| Remove the object from the collection. More... | |
| virtual PObject * | RemoveAt (PINDEX index) |
| Remove the object at the specified ordinal index from the collection. More... | |
| virtual void | RemoveAll () |
| Remove all of the elements in the collection. More... | |
| virtual PBoolean | SetAt (PINDEX index, PObject *val) |
| This method simply returns false as the list order is mantained by the class. More... | |
| virtual 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... | |
Public Member Functions inherited from PCollection | |
| 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) |
| __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... | |
Public Member Functions inherited from PContainer | |
| 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... | |
Public Member Functions inherited from PObject | |
| __inline unsigned | GetTraceContextIdentifier () const |
| Get PTRACE context identifier. More... | |
| __inline void | SetTraceContextIdentifier (unsigned id) |
| __inline void | SetTraceContextIdentifier (const PObject &obj) |
| __inline void | SetTraceContextIdentifier (const PObject *obj) |
| __inline void | CopyTraceContextIdentifier (PObject &obj) const |
| __inline void | CopyTraceContextIdentifier (PObject *obj) const |
| virtual | ~PObject () |
| __inline const char * | GetClass () const |
| __inline bool | IsClass (const char *name) const |
| __inline const PObject * | PTraceObjectInstance () const |
| 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 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 | |
| PSortedList (int dummy, const PSortedList *c) | |
Protected Member Functions inherited from PAbstractSortedList | |
| void | RemoveElement (PSortedListElement *node) |
| void | LeftRotate (PSortedListElement *node) |
| void | RightRotate (PSortedListElement *node) |
| void | DeleteSubTrees (PSortedListElement *node, bool deleteObject) |
| PSortedListElement * | FindElement (const PObject &obj, PINDEX *index) const |
| PSortedListElement * | FindElement (const PObject *obj, PINDEX *index) const |
Protected Member Functions inherited from PCollection | |
| PINLINE | PCollection (int dummy, const PCollection *coll) |
| Constructor used in support of the Clone() function. More... | |
Protected Member Functions inherited from PContainer | |
| 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... | |
Protected Member Functions inherited from PObject | |
| PObject () | |
| Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Iterators | |
| typedef T | value_type |
| iterator | begin () |
| iterator | end () |
| iterator | rbegin () |
| iterator | rend () |
| const_iterator | begin () const |
| const_iterator | end () const |
| const_iterator | rbegin () const |
| const_iterator | rend () const |
| value_type & | front () |
| value_type & | back () |
| const value_type & | front () const |
| const value_type & | back () const |
| iterator | find (const value_type &obj) |
| const_iterator | find (const value_type &obj) const |
| void | erase (const iterator &it) |
| void | erase (const const_iterator &it) |
| __inline void | insert (const value_type &value) |
| __inline void | pop_front () |
| __inline void | pop_back () |
Additional Inherited Members | |
Public Types inherited from PObject | |
| enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
Static Public Member Functions inherited from PObject | |
| static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject &from) |
| static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject *from) |
| static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject &from) |
| static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject *from) |
| static __inline const char * | Class () |
| static __inline const PObject * | PTraceObjectInstance (const char *) |
| static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
| template<typename T > | |
| static Comparison | Compare2 (T v1, T v2) |
| Compare two types, returning Comparison type. More... | |
| static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
| Internal function caled from CompareObjectMemoryDirect() More... | |
Protected Attributes inherited from PAbstractSortedList | |
| PSortedListInfo * | m_info |
Protected Attributes inherited from PContainer | |
| PContainerReference * | reference |
Protected Attributes inherited from PObject | |
| unsigned | m_traceContextIdentifier |
This template class maps the PAbstractSortedList to a specific object type.
The functions in this class primarily do all the appropriate casting of types.
Note that if templates are not used the PDECLARE_SORTED_LIST macro will simulate the template instantiation.
| typedef T PSortedList< T >::value_type |
|
inline |
Create a new, empty, sorted list.
Note that by default, objects placed into the list will be deleted when removed or when all references to the list are destroyed.
Referenced by PSortedList< PString >::Clone().
|
inlineprotected |
|
inline |
|
inline |
|
inline |
Referenced by PSortedList< PString >::front(), and PSortedList< PString >::pop_front().
|
inline |
|
inlinevirtual |
Make a complete duplicate of the list.
Note that all objects in the array are also cloned, so this will make a complete copy of the list.
Reimplemented from PObject.
|
inline |
|
inline |
|
inline |
Referenced by PSortedList< PString >::pop_back(), and PSortedList< PString >::pop_front().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Retrieve a reference to the object in the list.
If there was not an object at that ordinal position or the index was beyond the size of the array then the function asserts.
The object accessed in this way is remembered by the class and further access will be fast.
index position. | index | Index for entry |
|
inline |
|
inline |
|
inline |
Referenced by PSortedList< PString >::back(), and PSortedList< PString >::pop_back().
|
inline |
|
inline |
|
inline |