PTLib
Version 2.18.8
|
This is a dictionary collection class of PString
objects, keyed by another string.
More...
#include <pstring.h>
Classes | |
struct | Initialiser |
Structure for static array initialiser for class. More... | |
Public Member Functions | |
Construction | |
PStringToString (PINDEX count, const Initialiser *init, PBoolean caselessKeys=false, PBoolean caselessValues=false) | |
Initialise the string dictionary of strings from the static array. More... | |
PStringToString (const PString &str) | |
Initialise the string dictionary from the string. More... | |
Overrides from class PObject | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
![]() | |
PStringDictionary () | |
Create a new, empty, dictionary. More... | |
virtual PObject * | Clone () const |
Make a complete duplicate of the dictionary. More... | |
PString | operator() (const K &key, const char *dflt=NULL) const |
Get the string contained in the dictionary at the key position. More... | |
virtual PBoolean | SetAt (const K &key, const PString &str) |
Add a new object to the collection. More... | |
![]() | |
PDictionary () | |
Create a new, empty, dictionary. More... | |
const PString & | operator[] (const K &key) const |
Get the object contained in the dictionary at the key position. More... | |
PString & | operator[] (const K &key) |
PBoolean | Contains (const K &key) const |
Determine if the value of the object is contained in the hash table. More... | |
virtual PString * | RemoveAt (const K &key) |
Remove an object at the specified key . More... | |
virtual PBoolean | SetAt (const K &key, PString *obj) |
Add a new object to the collection. More... | |
virtual PString * | GetAt (const K &key) const |
Get the object at the specified key position. More... | |
const K & | GetKeyAt (PINDEX index) const |
Get the key in the dictionary at the ordinal index position. More... | |
PString & | GetDataAt (PINDEX index) const |
Get the data in the dictionary at the ordinal index position. More... | |
PArray< K > | GetKeys () const |
Get an array containing all the keys for the dictionary. More... | |
iterator | begin () |
const_iterator | begin () const |
iterator | end () |
const_iterator | end () const |
iterator | find (const K &key) |
const_iterator | find (const K &k) const |
void | erase (const iterator &it) |
void | erase (const const_iterator &it) |
![]() | |
PINLINE | PAbstractDictionary () |
Create a new, empty, dictionary. More... | |
virtual void | PrintOn (ostream &strm) const |
Output the contents of the object to the stream. More... | |
virtual PINDEX | Insert (const PObject &key, PObject *obj) |
Insert a new object into the dictionary. More... | |
virtual PINDEX | InsertAt (PINDEX index, PObject *obj) |
Insert a new object at the specified index. More... | |
virtual PObject * | RemoveAt (PINDEX index) |
Remove an object at the specified index. More... | |
virtual PBoolean | SetAt (PINDEX index, PObject *val) |
Set the object at the specified index to the new value. More... | |
virtual PObject * | GetAt (PINDEX index) const |
Get the object at the specified index 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... | |
virtual P_DEPRECATED PBoolean | SetDataAt (PINDEX index, PObject *obj) |
Set the data at the specified ordinal index position in the dictionary. More... | |
virtual PObject * | AbstractSetAt (const PObject &key, PObject *obj) |
Add a new object to the collection. More... | |
virtual PObject & | GetRefAt (const PObject &key) const |
Get the object at the specified key position. More... | |
virtual PObject * | AbstractGetAt (const PObject &key) const |
Get the object at the specified key position. More... | |
virtual void | AbstractGetKeys (PArrayObjects &keys) const |
Get an array containing all the keys for the dictionary. More... | |
![]() | |
PHashTable () | |
Create a new, empty, hash table. More... | |
virtual Comparison | Compare (const PObject &obj) const |
Get the relative rank of the two hash tables. More... | |
virtual PBoolean | SetSize (PINDEX newSize) |
This function is meaningless for hash table. More... | |
PINLINE PBoolean | AbstractContains (const PObject &key) const |
Determine if the value of the object is contained in the hash table. More... | |
virtual const PObject & | AbstractGetKeyAt (PINDEX index) const |
Get the key in the hash table at the ordinal index position. More... | |
virtual PObject & | AbstractGetDataAt (PINDEX index) const |
Get the data in the hash table at the ordinal index position. 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... | |
![]() | |
__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... | |
New functions for class | |
enum | MergeAction { e_MergeOverwrite, e_MergeIgnore, e_MergeAppend } |
Actions to take when doing a PStringToString::Merge() More... | |
void | Merge (const PStringToString &merge, MergeAction action) |
Merge string dictionary into this dictionary. More... | |
char ** | ToCharArray (bool withEqualSign, PCharArray *storage=NULL) const |
Create an array of C strings. More... | |
void | FromString (const PString &str) |
Set dictionary from string. More... | |
Additional Inherited Members | |
![]() | |
typedef K | key_type |
typedef PString | data_type |
typedef PDictionary< K, PString > | dict_type |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
![]() | |
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... | |
![]() | |
PHashTableInfo * | hashTable |
![]() | |
PStringDictionary (int dummy, const PStringDictionary *c) | |
![]() | |
PDictionary (int dummy, const PDictionary *c) | |
![]() | |
PINLINE | PAbstractDictionary (int dummy, const PAbstractDictionary *c) |
![]() | |
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... | |
![]() | |
PContainerReference * | reference |
![]() | |
unsigned | m_traceContextIdentifier |
This is a dictionary collection class of PString
objects, keyed by another string.
It has all the usual functions for a collection, with the object types set to PString
pointers.
In addition some addition functions are added that take a const PString
reference instead of a pointer as most standard collection functions do. This is more convenient for when string expressions are used as parameters to function in the collection.
See the PAbstractDictionary
and PStringDictionary
classes and PDECLARE_DICTIONARY
and PDECLARE_STRING_DICTIONARY
macros for more information.
Actions to take when doing a PStringToString::Merge()
Enumerator | |
---|---|
e_MergeOverwrite |
Overwrite destination keys value. |
e_MergeIgnore |
Ignore new value, leave desstination as is. |
e_MergeAppend |
Append to existing key value, separated by ' |
PStringToString::PStringToString | ( | PINDEX | count, |
const Initialiser * | init, | ||
PBoolean | caselessKeys = false , |
||
PBoolean | caselessValues = false |
||
) |
Initialise the string dictionary of strings from the static array.
count | Count of strings in initialiser array |
init | Array of Initialiser structures |
caselessKeys | New keys are to be PCaselessStrings |
caselessValues | New values are to be PCaselessStrings |
|
inlineexplicit |
Initialise the string dictionary from the string.
The string is expected to be of the form "key=value\\nkey=value".
str | String to read dictionary from |
References FromString().
void PStringToString::FromString | ( | const PString & | str | ) |
Set dictionary from string.
The string is expected to be of the form "key=value\\nkey=value". If there are more than one line with the same key they dictionary entry is is appended to with '
' separator.
str | String to read dictionary from |
Referenced by PStringToString().
void PStringToString::Merge | ( | const PStringToString & | merge, |
MergeAction | action | ||
) |
Merge string dictionary into this dictionary.
If unique
is true, then if the merge value for a key is the same
merge | Strings to merge |
|
virtual |
Input the contents of the object from the stream.
This is primarily used by the standard operator>>
function.
The default behaviour reads input of the form "key=value\\nkey=value" until !strm.good()
.
If there are more than one line with the same key they dictionary entry is is appended to with '
' separator.
Reimplemented in PMIMEInfo.
char** PStringToString::ToCharArray | ( | bool | withEqualSign, |
PCharArray * | storage = NULL |
||
) | const |
Create an array of C strings.
If withEqualSign is true then array is GetSize()+1 strings of the form key=value. If false then the array is GetSize()*2+1 strings where consecutive pointers are the key and option respecitively of each entry in the dictionary.
If storage is NULL then this returns a single pointer that must be disposed of using free(). Note that each of the strings are part of the same memory allocation so only one free() is required.
If storage is not null then that is used to allocate the memory.