Update contrib.
     1 // Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
 
     2 // All rights reserved.
 
     3 // This component and the accompanying materials are made available
 
     4 // under the terms of "Eclipse Public License v1.0"
 
     5 // which accompanies this distribution, and is available
 
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
 
     8 // Initial Contributors:
 
     9 // Nokia Corporation - initial contribution.
 
    14 // T_StreamInStore.inl
 
    15 // Demonstrates performance assesment of stream creation in non persistent store
 
    16 // Create CStreamStoreA object and CStreamStoreB object, externalize them to
 
    17 // a non-persistent store and then destroy the CStreamStoreA object
 
    21 LOCAL_C void doStoreL(CStreamStore& aStore,TStreamId& anId);
 
    23 // Create an "empty" CStreamStoreA and CStreamStoreB objects and
 
    24 // restore them from the in-memory store
 
    25 LOCAL_C void doRestoreL(CStreamStore& aStore,const TStreamId& anId);
 
    27 #define STREAMSTORERUNSIZE	121
 
    29 // Declare example class CStreamStoreA
 
    30 class CStreamStoreA : public CBase
 
    33 	static CStreamStoreA* NewLC();
 
    35 	void     SetTextL(const TDesC& aData);
 
    36 	void     ExternalizeL(RWriteStream& aStream) const;
 
    37 	void     InternalizeL(RReadStream& aStream);
 
    44 // Declare example class CStreamStoreB
 
    45 class CStreamStoreB : public CBase
 
    48 	static CStreamStoreB* NewLC();
 
    50 	void ExternalizeL(RWriteStream& aStream) const;
 
    51 	void InternalizeL(RReadStream& aStream);
 
    59 	CArrayFixFlat<TElement>* iArray;
 
    63 @SYMTestCaseID          SYSLIB-STORE-PT-1370
 
    64 @SYMTestCaseDesc	CR MRLM-6A9DF7. Tests the impact of RFileBuf cache size on CBufStore performance. RFileBuf cache size must be set at a build time in EStor_Template.mmh file, DEFAULT_FILE_BUF_SIZE macro definition.
 
    66 @SYMTestActions  	The test creates a set of test objects, externalizes them STREAMRUNSIZE times and prints the execution time. Then internalizes them STREAMSTORERUNSIZE times and prints the execution time. STREAMSTORERUNSIZE is a constant, defined in the source file.
 
    67 @SYMTestExpectedResults Test must show a performance improvement
 
    71 LOCAL_C void doStoreStreamsL()
 
    73 	// Stream id, kept in memory and used to access the 
 
    74 	// (one and only stream) in non-persistent store
 
    77 	// construct a CBufStore, an in-memory non-persistent store.
 
    78 	CStreamStore* store = CBufStore::NewLC(228 /*granularity*/);
 
    81 	for(int i=0; i < STREAMSTORERUNSIZE; i++)
 
    83 		doStoreL(*store,theId);
 
    87 	TTimeIntervalMicroSeconds us = end.MicroSecondsFrom(start);
 
    88 	TheTest.Printf(_L("CBufStore, %d 'write' tests. Time=%ld us\r\n"), STREAMSTORERUNSIZE, us.Int64());
 
    91 	for(int i=0; i < STREAMSTORERUNSIZE; i++)
 
    93 		doRestoreL(*store,theId);
 
    96 	us = end.MicroSecondsFrom(start);
 
    97 	TheTest.Printf(_L("CBufStore, %d 'read' tests.  Time=%ld us\r\n"), STREAMSTORERUNSIZE, us.Int64());
 
    99 	// destroy the CBufStore object
 
   100 	CleanupStack::PopAndDestroy();
 
   103 LOCAL_C void doStoreL(CStreamStore& aStore,TStreamId& anId)
 
   105 	// Create CStreamStoreA and put some data into it
 
   106 	_LIT(KTxtForClassA,"Text for CStreamStoreA");
 
   107 	CStreamStoreA* theA = CStreamStoreA::NewLC();
 
   108 	theA->SetTextL(KTxtForClassA);
 
   109 	theA->iIntValue  = -1;
 
   110 	theA->iUintValue = 2;
 
   112 	// Create CStreamStoreB and put some data into it
 
   113 	_LIT(KTxtForClassB,"Text for CStreamStoreB");
 
   114 	CStreamStoreB* theB = CStreamStoreB::NewLC();
 
   115 	theB->iFixBuffer = KTxtForClassB;
 
   116 	theB->iIntValue  = -3;
 
   117 	theB->iUintValue = 4; 
 
   118 	theB->iRealValue = 5.6;
 
   121 	_LIT(KFormatTxt,"BenchMarkingStreamStore%4u");
 
   122 	TBuf<256> str(KFormatTxt);
 
   124 	for (TInt index = 0; index < STREAMSTORERUNSIZE; index++)
 
   126 		theElement.iData.Format(KFormatTxt,index);
 
   127 		theB->iArray->AppendL(theElement);
 
   130 	// Create the output stream. Stream id (the only one) is kept in memory.
 
   131 	RStoreWriteStream outstream;
 
   132 	anId = outstream.CreateLC(aStore);
 
   140 	CleanupStack::PopAndDestroy(3);
 
   143 LOCAL_C void doRestoreL(CStreamStore& aStore,const TStreamId& anId)
 
   146 	// Create  an "empty" CStreamStoreA and CStreamStoreB objects
 
   147 	CStreamStoreA* theA = CStreamStoreA::NewLC();
 
   148 	CStreamStoreB* theB = CStreamStoreB::NewLC();
 
   150 	// Create/open the input stream. Access the one and only stream from in-memory store.
 
   151 	RStoreReadStream instream;
 
   152 	instream.OpenLC(aStore,anId);
 
   154 	// Stream in CStreamStoreA object first and then stream in the CStreamStoreB object. 
 
   155 	// This is the order in which the objects were streamed out.
 
   160 	CleanupStack::PopAndDestroy(3); // theA 
 
   164 //***************************************************************
 
   165 CStreamStoreA* CStreamStoreA::NewLC()
 
   167 	CStreamStoreA* self = new (ELeave) CStreamStoreA;
 
   168 	CleanupStack::PushL(self);
 
   172 CStreamStoreA::~CStreamStoreA()
 
   177 void CStreamStoreA::SetTextL(const TDesC& aData)
 
   179 	iVarBuffer = aData.AllocL();	
 
   182 void CStreamStoreA::ExternalizeL(RWriteStream& aStream) const
 
   184 	aStream.WriteInt32L(iVarBuffer->Des().MaxLength());
 
   185 	aStream << *iVarBuffer;
 
   186 	aStream.WriteInt32L(iIntValue);
 
   187 	aStream.WriteUint32L(iUintValue);
 
   190 void CStreamStoreA::InternalizeL(RReadStream& aStream)
 
   193 	maxlen     = aStream.ReadInt32L();
 
   194 	iVarBuffer = HBufC::NewL(aStream,maxlen);
 
   195 	iIntValue  = aStream.ReadInt32L();
 
   196 	iUintValue = aStream.ReadUint32L();
 
   199 //***************************************************************
 
   200 CStreamStoreB* CStreamStoreB::NewLC()
 
   202 	CStreamStoreB* self = new (ELeave) CStreamStoreB;
 
   203 	CleanupStack::PushL(self);
 
   208 CStreamStoreB::~CStreamStoreB()
 
   213 void CStreamStoreB::ConstructL()
 
   215 	iArray = new (ELeave) CArrayFixFlat<TElement> (STREAMSTORERUNSIZE);
 
   218 void CStreamStoreB::ExternalizeL(RWriteStream& aStream) const
 
   220 	aStream << iFixBuffer;
 
   221 	aStream.WriteInt32L(iIntValue);
 
   222 	aStream.WriteUint32L(iUintValue);
 
   223 	aStream.WriteReal64L(iRealValue);
 
   226 	TInt count = iArray->Count();
 
   227 	for (TInt index = 0; index < count; index++)
 
   229 		theElement =((*iArray)[index]);
 
   230 		aStream.WriteL(theElement.iData, 27);
 
   234 void CStreamStoreB::InternalizeL(RReadStream& aStream)
 
   236 	aStream >> iFixBuffer;
 
   237 	iIntValue  = aStream.ReadInt32L();
 
   238 	iUintValue = aStream.ReadUint32L();
 
   239 	iRealValue = aStream.ReadReal64L();
 
   243 	for (TInt index = 0; index <STREAMSTORERUNSIZE; index++)
 
   245 		aStream.ReadL(theElement.iData, 27);
 
   246 		iArray->AppendL(theElement);