#include <safecoll.h>
Inheritance diagram for PSafeDictionaryBase< Coll, Key, Base >:
Public Member Functions | |
Construction | |
PSafeDictionaryBase () | |
Create a safe dictionary wrapper around the real collection. | |
PSafeDictionaryBase (const PSafeDictionaryBase &other) | |
Copy constructor for safe collection. | |
PSafeDictionaryBase & | operator= (const PSafeDictionaryBase &other) |
Assign one safe collection to another. | |
Operations | |
virtual void | SetAt (const Key &key, Base *obj) |
Add an object to the collection. | |
virtual PBoolean | RemoveAt (const Key &key) |
Remove an object to the collection. | |
virtual PBoolean | Contains (const Key &key) |
Determine of the dictionary contains an entry for the key. | |
virtual PSafePtr< Base > | GetAt (PINDEX idx, PSafetyMode mode=PSafeReadWrite) |
Get the instance in the collection of the index. | |
virtual PSafePtr< Base > | FindWithLock (const Key &key, PSafetyMode mode=PSafeReadWrite) |
Find the instance in the collection of an object with the same value. |
This is part of a set of classes to solve the general problem of a collection (eg a PList or PDictionary) of objects that needs to be a made thread safe. Any thread can add, read, write or remove an object with both the object and the database of objects itself kept thread safe.
See the PSafeObject class for more details. Especially in regard to enumeration of collections.
PSafeDictionaryBase< Coll, Key, Base >::PSafeDictionaryBase | ( | ) | [inline] |
Create a safe dictionary wrapper around the real collection.
PSafeDictionaryBase< Coll, Key, Base >::PSafeDictionaryBase | ( | const PSafeDictionaryBase< Coll, Key, Base > & | other | ) | [inline] |
Copy constructor for safe collection.
Note the left hand side will always have DisallowDeleteObjects() set.
virtual PBoolean PSafeDictionaryBase< Coll, Key, Base >::Contains | ( | const Key & | key | ) | [inline, virtual] |
Determine of the dictionary contains an entry for the key.
virtual PSafePtr<Base> PSafeDictionaryBase< Coll, Key, Base >::FindWithLock | ( | const Key & | key, | |
PSafetyMode | mode = PSafeReadWrite | |||
) | [inline, virtual] |
Find the instance in the collection of an object with the same value.
The returned safe pointer will increment the reference count on the PSafeObject and lock to the object in the mode specified. The lock will remain until the PSafePtr goes out of scope.
virtual PSafePtr<Base> PSafeDictionaryBase< Coll, Key, Base >::GetAt | ( | PINDEX | idx, | |
PSafetyMode | mode = PSafeReadWrite | |||
) | [inline, virtual] |
Get the instance in the collection of the index.
The returned safe pointer will increment the reference count on the PSafeObject and lock to the object in the mode specified. The lock will remain until the PSafePtr goes out of scope.
PSafeDictionaryBase& PSafeDictionaryBase< Coll, Key, Base >::operator= | ( | const PSafeDictionaryBase< Coll, Key, Base > & | other | ) | [inline] |
Assign one safe collection to another.
Note the left hand side will always have DisallowDeleteObjects() set.
virtual PBoolean PSafeDictionaryBase< Coll, Key, Base >::RemoveAt | ( | const Key & | key | ) | [inline, virtual] |
Remove an object to the collection.
This function removes the object from the collection itself, but does not actually delete the object. It simply moves the object to a list of objects to be garbage collected at a later time.
As for Append() full mutual exclusion locking on the collection itself is maintained.
key | Key to fund object to delete |
virtual void PSafeDictionaryBase< Coll, Key, Base >::SetAt | ( | const Key & | key, | |
Base * | obj | |||
) | [inline, virtual] |
Add an object to the collection.
This uses the PCollection::Append() function to add the object to the collection, with full mutual exclusion locking on the collection.