|
||
class CStoreMap : public CBase, public MExternalizer< TStreamRef >;
Store map used when externalising swizzled in-memory objects.
It has three main characteristics:
it acts as an in-memory repository of stream ids and associated swizzles
it acts as an externaliser for swizzles
it offers cleanup support
MExternalizer< TStreamRef >
- No description.
CBase
-
Base class for all classes to be instantiated on the heap.
CStoreMap
-
Store map used when externalising swizzled in-memory objects.
Defined in CStoreMap
:
At(TSwizzleC< TAny >)const
Returns the stream id of the first entry the store map matching the specified sw...Begin()const
BindL(TSwizzleC< TAny >,TStreamId)
Creates an entry in the store map to contain the specified stream id and an asso...CStoreMap(CStreamStore &)
End()const
ExternalizeL(const TStreamRef &,RWriteStream &)const
Performs externalisation.Forget(TStreamId)
Deletes an entry from the store map. The entry selected is the first one whose s...Label(TStreamId)const
Returns the swizzle in the store map assocated with the specified stream id.NewL(CStreamStore &)
Allocates and constructs a store map associated with the specified store and ret...NewLC(CStreamStore &)
Allocates and constructs a store map associated with the specified store, return...Reset()
Deletes all entries from the store map.ResetAndDestroy()
Deletes all streams whose ids are held within the store map, and then empties th...TEntry
TIterator
Unbind(TSwizzleC< TAny >)
Deletes the first entry from the store map corresponding to the specified swizzl...~CStoreMap()
Frees resources owned by the object, prior to its destruction.Inherited from CBase
:
Delete(CBase *)
Deletes the specified object.Extension_(TUint,TAny *&,TAny *)
Extension function operator new(TUint)
Allocates the object from the heap and then initialises its contents to binary z...operator new(TUint,TAny *)
Initialises the object to binary zeroes.operator new(TUint,TLeave)
Allocates the object from the heap and then initialises its contents to binary z...operator new(TUint,TLeave,TUint)
Allocates the object from the heap and then initialises its contents to binary z...operator new(TUint,TUint)
Allocates the object from the heap and then initialises its contents to binary z...IMPORT_C static CStoreMap* NewL(CStreamStore &aStore);
Allocates and constructs a store map associated with the specified store and returns a pointer to that store map.
The function leaves if it cannot complete successfully.
|
|
IMPORT_C static CStoreMap* NewLC(CStreamStore &aStore);
Allocates and constructs a store map associated with the specified store, returns a pointer to that store map and puts the pointer onto the cleanup stack.
The function leaves if it cannot complete successfully.
Placing a pointer to this object onto the cleanup stack allows the object and allocated resources to be cleaned up if a subsequent leave occurs.
|
|
IMPORT_C ~CStoreMap();
Frees resources owned by the object, prior to its destruction.
In particular, the destructor deletes all streams whose stream ids are currently held within the store map and then empties the store map.
IMPORT_C void BindL(TSwizzleC< TAny > aSwizzle, TStreamId anId);
Creates an entry in the store map to contain the specified stream id and an associated swizzle. On return from this function, the stream id is said to be bound to the swizzle.
If the store map already contains an entry with the same swizzle, then the new entry replaces the existing entry; in effect, knowledge of the original stream id associated with aSwizzle, is lost.
Callers of this function can pass any type of swizzle as the first parameter, i.e. any swizzle derived from TSwizzleCBase
. The required TSwizzleC< TAny >
object is constructed from the swizzle passed by the caller.
Note that in most applications, callers pass a general swizzle, i.e. an object of type TSwizzle<class T>, where T is the type of object represented by that swizzle.
|
IMPORT_C void Unbind(TSwizzleC< TAny > aSwizzle);
Deletes the first entry from the store map corresponding to the specified swizzle.
On return from this function, the swizzle is said to be unbound and knowledge of the associated stream id is lost.
Callers of this function can pass any type of swizzle as the parameter, i.e. any swizzle derived from TSwizzleCBase
. The required TSwizzleC< TAny >
object is constructed from the swizzle passed by the caller.
Notes:
In most applications, callers pass a general swizzle, i.e. an object of type TSwizzle
<class T>, where T is the type of object represented by that swizzle.
If no matching entry can be found in the store map, then the store map remains unaltered.
|
IMPORT_C void Forget(TStreamId anId);
Deletes an entry from the store map. The entry selected is the first one whose stream id matches the specified stream id.
On return from this function, the stream id is said to be forgotten and knowledge of that stream id is lost.
|
IMPORT_C void Reset();
Deletes all entries from the store map.
It is important that this function is called before deleting the store map, as the destructor attempts to delete all streams whose stream ids are held within the map.
IMPORT_C void ResetAndDestroy();
Deletes all streams whose ids are held within the store map, and then empties the store map.
IMPORT_C TStreamId At(TSwizzleC< TAny > aSwizzle) const;
Returns the stream id of the first entry the store map matching the specified swizzle.
Callers of this function can pass any type of swizzle as the first parameter, i.e. any swizzle derived from TSwizzleCBase
. The required TSwizzleC< TAny >
object is constructed from the swizzle passed by the caller.
|
|
IMPORT_C TSwizzleC< TAny > Label(TStreamId anId) const;
Returns the swizzle in the store map assocated with the specified stream id.
|
|
private: virtual void ExternalizeL(const TStreamRef &aRef, RWriteStream &aStream) const;
Performs externalisation.
The function is called by operator().
|
struct TEntry;
Defined in CStoreMap::TEntry
:
swizzle
TSwizzleC< TAny > swizzle;
id
TStreamId id;
typedef const TEntry* CStoreMap::TIterator;