piprofiler/piprofiler_plat/inc/SamplerPluginInterface.inl
author hgs
Thu, 13 May 2010 23:59:27 +0300
changeset 20 a71a3e32a2ae
permissions -rw-r--r--
201019
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// LITERALS
hgs
parents:
diff changeset
    20
_LIT8(KTrue, "true");
hgs
parents:
diff changeset
    21
_LIT8(KFalse, "false");
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
inline CSamplerPluginInterface::CSamplerPluginInterface()
hgs
parents:
diff changeset
    24
    : iOrder( KSamplerPluginNotIndexed )
hgs
parents:
diff changeset
    25
    {
hgs
parents:
diff changeset
    26
    iBuffer = 0;
hgs
parents:
diff changeset
    27
    iStream = 0;
hgs
parents:
diff changeset
    28
    }
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    31
// CSamplerPluginInterface::~CSamplerPluginInterface()
hgs
parents:
diff changeset
    32
// Destructor.
hgs
parents:
diff changeset
    33
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    34
//
hgs
parents:
diff changeset
    35
inline CSamplerPluginInterface::~CSamplerPluginInterface()
hgs
parents:
diff changeset
    36
    {
hgs
parents:
diff changeset
    37
    iBuffer = 0;
hgs
parents:
diff changeset
    38
    REComSession::DestroyedImplementation(iDtor_ID_Key);
hgs
parents:
diff changeset
    39
    }
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
inline CSamplerPluginInterface* CSamplerPluginInterface::NewL(const TUid aImplementationUid, TAny* aInitParams)
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    // Define options, how the default resolver will find appropriate
hgs
parents:
diff changeset
    45
    // implementation.
hgs
parents:
diff changeset
    46
    return REINTERPRET_CAST(CSamplerPluginInterface*, 
hgs
parents:
diff changeset
    47
                            REComSession::CreateImplementationL(aImplementationUid,
hgs
parents:
diff changeset
    48
                                                                _FOFF( CSamplerPluginInterface, iDtor_ID_Key ),
hgs
parents:
diff changeset
    49
                                                                aInitParams)); 
hgs
parents:
diff changeset
    50
    }
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
inline void CSamplerPluginInterface::ListAllImplementationsL(RImplInfoPtrArray& aImplInfoArray)
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
    REComSession::ListImplementationsL(KSamplerPluginInterfaceUid, aImplInfoArray);
hgs
parents:
diff changeset
    55
    }
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
inline void CSamplerPluginInterface::SetOrder( TInt aOrder )
hgs
parents:
diff changeset
    58
    {
hgs
parents:
diff changeset
    59
    iOrder = aOrder;
hgs
parents:
diff changeset
    60
    }
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
inline TInt CSamplerPluginInterface::Flush() 
hgs
parents:
diff changeset
    63
    {
hgs
parents:
diff changeset
    64
	// complete the header
hgs
parents:
diff changeset
    65
	TUint32 header;
hgs
parents:
diff changeset
    66
	header = (iBuffer->iDataSize & 0x00ffffff) - 4;
hgs
parents:
diff changeset
    67
	header += (iSamplerId << 24);
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
	// flush the header info
hgs
parents:
diff changeset
    70
	iBuffer->iBuffer[0] = header;
hgs
parents:
diff changeset
    71
	iBuffer->iBuffer[1] = header >> 8;
hgs
parents:
diff changeset
    72
	iBuffer->iBuffer[2] = header >> 16;
hgs
parents:
diff changeset
    73
	iBuffer->iBuffer[3] = header >> 24;
hgs
parents:
diff changeset
    74
	
hgs
parents:
diff changeset
    75
    // write data to filled buffers
hgs
parents:
diff changeset
    76
    iStream->AddToFilledBuffers(iBuffer);
hgs
parents:
diff changeset
    77
    // notify selected writer plugin to write data to output
hgs
parents:
diff changeset
    78
    iStream->NotifyWriter();
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    iBuffer = 0;
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
	return KErrNone;
hgs
parents:
diff changeset
    83
}
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
inline TInt CSamplerPluginInterface::AddSample(TUint8* aSample, TUint32 aLength, TInt aLimitSize)
hgs
parents:
diff changeset
    87
    {
hgs
parents:
diff changeset
    88
    LOGTEXT(_L("CSamplerPluginInterface::AddSample - entry"));
hgs
parents:
diff changeset
    89
	if(iBuffer == 0) 
hgs
parents:
diff changeset
    90
	    {
hgs
parents:
diff changeset
    91
	    // get next free buffer where to write data
hgs
parents:
diff changeset
    92
		iBuffer = iStream->GetNextFreeBuffer();
hgs
parents:
diff changeset
    93
		iBuffer->iBufDes->Zero();
hgs
parents:
diff changeset
    94
		
hgs
parents:
diff changeset
    95
		// get space for the header
hgs
parents:
diff changeset
    96
		TUint32 header = 0;
hgs
parents:
diff changeset
    97
		iBuffer->iBufDes->Append((TUint8*)&header, 4);	
hgs
parents:
diff changeset
    98
		iBuffer->iDataSize += 4;
hgs
parents:
diff changeset
    99
	    }
hgs
parents:
diff changeset
   100
		
hgs
parents:
diff changeset
   101
	// add data to the buffer...
hgs
parents:
diff changeset
   102
	// if all data fit to the current buffer
hgs
parents:
diff changeset
   103
	if(iBuffer->iBufferSize - iBuffer->iDataSize >= (TInt)aLength)
hgs
parents:
diff changeset
   104
	    {
hgs
parents:
diff changeset
   105
		iBuffer->iBufDes->Append(aSample, (TInt)aLength);
hgs
parents:
diff changeset
   106
		iBuffer->iDataSize += (TInt)aLength;
hgs
parents:
diff changeset
   107
	    }
hgs
parents:
diff changeset
   108
	else 
hgs
parents:
diff changeset
   109
	    {	
hgs
parents:
diff changeset
   110
		// fill in the buffer
hgs
parents:
diff changeset
   111
		TUint32 rest = iBuffer->iBufferSize - iBuffer->iDataSize;
hgs
parents:
diff changeset
   112
		iBuffer->iBufDes->Append(aSample, rest);
hgs
parents:
diff changeset
   113
		iBuffer->iDataSize += (TInt)rest;
hgs
parents:
diff changeset
   114
		
hgs
parents:
diff changeset
   115
		// The buffer is full now, complete the header
hgs
parents:
diff changeset
   116
		TUint32 header;
hgs
parents:
diff changeset
   117
		header = (iBuffer->iDataSize & 0x00ffffff) - 4;
hgs
parents:
diff changeset
   118
		header += (iSamplerId << 24);
hgs
parents:
diff changeset
   119
		iBuffer->iBuffer[0] = header;
hgs
parents:
diff changeset
   120
		iBuffer->iBuffer[1] = header >> 8;
hgs
parents:
diff changeset
   121
		iBuffer->iBuffer[2] = header >> 16;
hgs
parents:
diff changeset
   122
		iBuffer->iBuffer[3] = header >> 24;
hgs
parents:
diff changeset
   123
		
hgs
parents:
diff changeset
   124
		// write data to filled buffers
hgs
parents:
diff changeset
   125
		iStream->AddToFilledBuffers(iBuffer);
hgs
parents:
diff changeset
   126
	    // notify selected writer plugin to write data to output
hgs
parents:
diff changeset
   127
	    iStream->NotifyWriter();
hgs
parents:
diff changeset
   128
		
hgs
parents:
diff changeset
   129
		// Fetch an empty buffer and reserve space for the header
hgs
parents:
diff changeset
   130
		iBuffer = iStream->GetNextFreeBuffer();
hgs
parents:
diff changeset
   131
		iBuffer->iBufDes->Zero();
hgs
parents:
diff changeset
   132
		header = 0;
hgs
parents:
diff changeset
   133
		iBuffer->iBufDes->Append((TUint8*)&header, 4);	
hgs
parents:
diff changeset
   134
		iBuffer->iDataSize += 4;
hgs
parents:
diff changeset
   135
			
hgs
parents:
diff changeset
   136
		// copy the rest of data to the new buffer
hgs
parents:
diff changeset
   137
		iBuffer->iBufDes->Append(aSample+rest, aLength-rest);
hgs
parents:
diff changeset
   138
		iBuffer->iDataSize += (TInt)aLength-rest;
hgs
parents:
diff changeset
   139
	    }
hgs
parents:
diff changeset
   140
	
hgs
parents:
diff changeset
   141
	// Once iBuffer->dataSize reaches the limitSize, data from iBuffer is flushed to file/debug port.
hgs
parents:
diff changeset
   142
	// If limitSize is set to zero, buffer is not changed until iBuffer gets full.
hgs
parents:
diff changeset
   143
	if(aLimitSize != 0) 
hgs
parents:
diff changeset
   144
	    {
hgs
parents:
diff changeset
   145
		if(iBuffer->iDataSize >= aLimitSize) 
hgs
parents:
diff changeset
   146
		    {
hgs
parents:
diff changeset
   147
			// The buffer is full now, complete the header
hgs
parents:
diff changeset
   148
			TUint32 header;
hgs
parents:
diff changeset
   149
			header = (iBuffer->iDataSize & 0x00ffffff) - 4;
hgs
parents:
diff changeset
   150
			header += (iSamplerId << 24);
hgs
parents:
diff changeset
   151
			iBuffer->iBuffer[0] = header;
hgs
parents:
diff changeset
   152
			iBuffer->iBuffer[1] = header >> 8;
hgs
parents:
diff changeset
   153
			iBuffer->iBuffer[2] = header >> 16;
hgs
parents:
diff changeset
   154
			iBuffer->iBuffer[3] = header >> 24;
hgs
parents:
diff changeset
   155
	
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
            // write data to filled buffers
hgs
parents:
diff changeset
   158
            iStream->AddToFilledBuffers(iBuffer);
hgs
parents:
diff changeset
   159
            // notify selected writer plugin to write data to output
hgs
parents:
diff changeset
   160
            iStream->NotifyWriter();
hgs
parents:
diff changeset
   161
		    
hgs
parents:
diff changeset
   162
			// Fetch an empty buffer and reserve space for the header
hgs
parents:
diff changeset
   163
			iBuffer = iStream->GetNextFreeBuffer();
hgs
parents:
diff changeset
   164
			iBuffer->iBufDes->Zero();
hgs
parents:
diff changeset
   165
			header = 0;
hgs
parents:
diff changeset
   166
			iBuffer->iBufDes->Append((TUint8*)&header, 4);	
hgs
parents:
diff changeset
   167
			iBuffer->iDataSize += 4;
hgs
parents:
diff changeset
   168
		    }
hgs
parents:
diff changeset
   169
	    }
hgs
parents:
diff changeset
   170
	return KErrNone;
hgs
parents:
diff changeset
   171
    }
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   174
// Converts given descriptor into TBool value.
hgs
parents:
diff changeset
   175
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   176
//
hgs
parents:
diff changeset
   177
inline void CSamplerPluginInterface::Str2Bool(const TDesC8& aBuf, TBool& aValue)
hgs
parents:
diff changeset
   178
    {
hgs
parents:
diff changeset
   179
    if (aBuf.CompareF(KFalse) == 0)
hgs
parents:
diff changeset
   180
        aValue = EFalse;
hgs
parents:
diff changeset
   181
    else
hgs
parents:
diff changeset
   182
        aValue = ETrue;
hgs
parents:
diff changeset
   183
    }
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   186
// Converts given descriptor into TInt value.
hgs
parents:
diff changeset
   187
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   188
//
hgs
parents:
diff changeset
   189
inline void CSamplerPluginInterface::Str2Int(const TDesC8& aBuf, TInt& aValue)
hgs
parents:
diff changeset
   190
    {
hgs
parents:
diff changeset
   191
    TLex8 conv;
hgs
parents:
diff changeset
   192
    conv.Assign(aBuf);
hgs
parents:
diff changeset
   193
    
hgs
parents:
diff changeset
   194
    if (conv.Val(aValue) != KErrNone)
hgs
parents:
diff changeset
   195
        aValue = 0;
hgs
parents:
diff changeset
   196
    }
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   199
// Converts given descriptor into TInt value.
hgs
parents:
diff changeset
   200
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   201
//
hgs
parents:
diff changeset
   202
inline void CSamplerPluginInterface::Str2Int(const TDesC8& aBuf, TUint32& aValue)
hgs
parents:
diff changeset
   203
    {
hgs
parents:
diff changeset
   204
    TInt temp(0);
hgs
parents:
diff changeset
   205
    
hgs
parents:
diff changeset
   206
    TLex8 conv;
hgs
parents:
diff changeset
   207
    conv.Assign(aBuf);
hgs
parents:
diff changeset
   208
    
hgs
parents:
diff changeset
   209
    if (conv.Val(temp) != KErrNone)
hgs
parents:
diff changeset
   210
        aValue = 0;
hgs
parents:
diff changeset
   211
    else
hgs
parents:
diff changeset
   212
        aValue = (TUint32)temp;
hgs
parents:
diff changeset
   213
    }
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
// End of file