mmlibs/mmfw/src/server/BaseClasses/mmfdatabuffer.cpp
author hgs
Tue, 02 Nov 2010 12:13:59 +0000
changeset 5 b220a9341636
parent 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk46_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
// source\mmf\server\baseclasses\mmfdatabuffer.cpp
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
#include <mmf/server/mmfdatabuffer.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
Method to instantiate a CMMFDataBuffer defaults to a CMMFDescriptorBuffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
to maintain buffer compatiblity with MFAD ie. instantiating a CMMFDataBuffer defaults to creating 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
a CMMFDescriptorBuffer. This NewL creates a CMMFDescriptorBuffer with a default size of 32 bytes.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
@return	A pointer to a new CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
EXPORT_C CMMFDataBuffer* CMMFDataBuffer::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
	return CMMFDescriptorBuffer::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
Method to instantiate a CMMFDataBuffer defaults to a CMMFDescriptorBuffer by default
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
to maintain buffer compatiblity with MFAD ie. instantiating a CMMFDataBuffer defaults to
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
creating a CMMFDescriptorBuffer. This NewL creates a CMMFDescriptorBuffer with a size of 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
aMaxBufferSize bytes.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
@param  aMaxBufferSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
        The size in bytes of the descriptor buffer to be created.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
@return A pointer to a new CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
EXPORT_C CMMFDataBuffer* CMMFDataBuffer::NewL(TInt aMaxBufferSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
	return CMMFDescriptorBuffer::NewL(aMaxBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
Method to instantiate a CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
Defaults to a CMMFDescriptorBuffer automatically. This NewL creates a CMMFDescriptorBuffer with a 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
default size of 32 bytes.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
@return A pointer to a new CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
EXPORT_C CMMFDescriptorBuffer* CMMFDescriptorBuffer::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
	CMMFDescriptorBuffer* self = new(ELeave) CMMFDescriptorBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
	self->ConstructL(KMMFDataBufferDefaultBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	CleanupStack::Pop(); // self
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
Method to instantiate a CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
This NewL creates a CMMFDescriptorBuffer with a size of aMaxBufferSize bytes.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
@param  aMaxBufferSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
        The size in bytes of the descriptor buffer to be created.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
@return A pointer to a new CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
EXPORT_C CMMFDescriptorBuffer* CMMFDescriptorBuffer::NewL(TInt aMaxBufferSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
	CMMFDescriptorBuffer* self = new(ELeave) CMMFDescriptorBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	self->ConstructL(aMaxBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
	CleanupStack::Pop(); // self
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
@internalTechnology
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
Internal.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
@param  aMaxBufferSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
        The size in bytes of the descriptor buffer to be created.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
void CMMFDescriptorBuffer::ConstructL(TInt aMaxBufferSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	iData = new(ELeave) TUint8[aMaxBufferSize];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
	iPtr.Set(iData, 0, aMaxBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
Destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
Destructor also deletes the buffer contained in the CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
EXPORT_C CMMFDescriptorBuffer::~CMMFDescriptorBuffer()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
	delete[] iData;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
Reallocates the max size in bytes of a CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
@param  aMaxBufferSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
        The new size in bytes of the descriptor buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
EXPORT_C void CMMFDescriptorBuffer::ReAllocBufferL(TInt aMaxBufferSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	TUint8* tmp = new(ELeave) TUint8[aMaxBufferSize];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	delete[] iData;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	iData = tmp;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
	iPtr.Set(iData, 0, aMaxBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
Returns a descriptor to the data contained in the CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
@return A reference to a TPtr containing the CMMFDescriptorBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
TDes8& CMMFDescriptorBuffer::Data()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	return iPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
Returns a descriptor to the data contained in the CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
@return A const reference to a TPtr containing the CMMFDescriptorBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
const TDesC8& CMMFDescriptorBuffer::Data() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
	return iPtr;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
Returns the actual data size (ie. not the maximum length) of the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
data contained in the CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
@return	The size in bytes of the data contained in the CMMFDescriptorBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
TUint CMMFDescriptorBuffer::BufferSize() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
	return iPtr.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
Sets the position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
This method is used by components (eg codecs) which read data from a buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
and wish to store a read position marker for further reads.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
Note: The position cannot exceed the size of the actual data not the max length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
@param  aPosition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
        The position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
void CMMFDescriptorBuffer::SetPosition (TUint aPosition)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
	{//used for repositioning
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
	if (aPosition <= (TUint)iPtr.Length()) 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
		iPosition = aPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
	else 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
		iPosition = (TUint)iPtr.Length();//tried to position beyond end of data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
Sets the request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
This function is used in cases where a component (eg a data source) may not be able
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
or be desirable to write to the entire max length of the buffer (eg variable bit rate codecs).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
In which case the SetRequestSizeL() can be set which can be read by the RequestSize()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
function in the component so that it knows to only write data upto the request size
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
and not fill the buffer up to its max length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
@param  aSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
        The request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
void CMMFDescriptorBuffer::SetRequestSizeL(TInt aSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
	if (aSize < 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
		User::Leave(KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
	else if (aSize > iPtr.MaxLength())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
		User::Leave(KErrOverflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
		iRequestSize = aSize;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
Overriden method to set the status and resets the data size to 0 when the buffer becomes available.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
@param  aStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
        The buffer status. See TBufferStatus for possible options.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
void CMMFDescriptorBuffer::SetStatus(TBufferStatus aStatus)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
	CMMFBuffer::SetStatus(aStatus);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
	if ((iStatus == EAvailable)&&iData)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
		{//need to set size to 0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
		iPtr.Zero();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
This function is not supported under EKA2.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
Method to instantiate a CMMFTransferBuffer. This NewL creates a CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
@param  aTransferWindow
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
        This is a valid RTransferWindow that has an RTransferBuffer mapped in.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
@param  aDataLength
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
        This parameter sets the length of the actual data present in the transferbuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
        This is because the length of actual data may be less than the length of the mapped in
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
        transfer buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
@return A pointer to a new CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
EXPORT_C CMMFTransferBuffer* CMMFTransferBuffer::NewL(RTransferWindow& aTransferWindow, TUint aDataLength)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
//this method is not supported under EKA2
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
	User::Panic(_L("Not supported!"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
	aTransferWindow = aTransferWindow;	//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
	aDataLength =  aDataLength;			//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
	return NULL;			//can't construct anything useful
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
@internalTechnology
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
This method is not supported under EKA2.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
Internal ConstructL.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
Note this method checks if a transfer buffer has been mapped in and
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
will leave with KErrNotReady if the RTransferWindow does not have a mapped
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
in RTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
@param  aTransferWindow
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
        This is a reference to a valid RTransferWindow that has an RTransferBuffer mapped in.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
@param  aDataLength
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
        The length of the data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
void CMMFTransferBuffer::ConstructL(RTransferWindow& aTransferWindow, TUint aDataLength)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
//this method is not supported under EKA2
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
	aTransferWindow = aTransferWindow;	//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
	aDataLength =  aDataLength;			//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
CMMFTransferBuffer destructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
Destructor maps out RTransferBuffer and closes RTransferWindow.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
EXPORT_C CMMFTransferBuffer::~CMMFTransferBuffer()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
Returns a descriptor to the data contained in the CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
@return	A reference to a TPtr containing the CMMFTransferBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
TDes8& CMMFTransferBuffer::Data()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
	return iPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
Returns a descriptor to the data contained in the CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
@return	A const reference to a TPtr containing the CMMFTransferBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
const TDesC8& CMMFTransferBuffer::Data() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
	return iPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
Returns the actual data size (ie. not the max length) of the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
data contained in the CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
@return	The size in bytes of the data contained in the CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
TUint CMMFTransferBuffer::BufferSize() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
	return iPtr.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
Sets the position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
This method is used by components (eg codecs) which read data from a buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
and wish to store a read position marker for further reads.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
Note: The position cannot exceed the size of the actual data not the max length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
@param  aPosition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
        The position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
void CMMFTransferBuffer::SetPosition (TUint aPosition)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
	{//used for repositioning
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
	aPosition = aPosition; //suppress compiler warning
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
Sets the request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
This function is used in cases where a component (eg. a data source) may not be able
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
or be desirable to write to the entire max length of the buffer (eg. variable bit rate codecs).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
In this case, the SetRequestSizeL can be set which can be read by the RequestSize()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
function in the component so that it knows to only write data upto the request size
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
and not fill the buffer up to its max length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
@param  aSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
        The request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
void CMMFTransferBuffer::SetRequestSizeL(TInt aSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
	aSize = aSize; //suppress compiler warning
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
This function is not supported under EKA2.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
Returns a reference to the transfer window currently used
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341
by the CMMFtransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   342
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   343
@return	A reference to the current RTransferWindow.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   344
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   345
EXPORT_C RTransferWindow& CMMFTransferBuffer::TransferWindow()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   346
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   347
	return iTransferWindow;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   348
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   349
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   350
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   351
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   352
This method is not supported under EKA2.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   353
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   354
Modifies the CMMFTransferBuffer by updating the RTransferWindow.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   355
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   356
This method is used if the same CMMFTransferBuffer is used throughout
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   357
eg. if a single CMMFTransferBuffer is created upfront but a different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   358
transfer window (or the same transfer window with a different buffer mapped in
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   359
is used). That is the same CMMFTransferBuffer but the actrual buffer may be different.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   360
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   361
Note: If the updated RTransferWindow is new, then the old buffer must
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   362
be mapped out first by a call to CMMFTransferBuffer::MapOutBuffer() and the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   363
RtransferWindow handle closed outside the CMMFTransferBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   364
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   365
@param  aTransferWindow
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   366
        The RTransferWindow to update - can be a new RTransferWindow
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   367
        or the same RTransferWindow with a new RTransferBuffer mapped in.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   368
@param  aDataLength
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   369
        The length of the data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   370
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   371
@return An error code indicating if the function call was successful. KErrNone on success, otherwise
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   372
        another of the system-wide error codes.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   373
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   374
EXPORT_C TInt CMMFTransferBuffer::UpdateTransferWindow(RTransferWindow& aTransferWindow, TUint aDataLength)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   375
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   376
//this method is not supported under EKA2
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   377
	aTransferWindow = aTransferWindow;	//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   378
	aDataLength =  aDataLength;			//suppressed unused argument warnings
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   379
	return KErrNotSupported;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   380
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   381
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   382
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   383
Maps the buffer out of the transfer window.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   384
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   385
This method should be called in preference to
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   386
calling MapOutBuffer directly on the RtransferWindow
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   387
so that the CMMFTransferBuffer knows that it is no longer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   388
available.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   389
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   390
EXPORT_C void CMMFTransferBuffer::MapOutBuffer()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   391
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   392
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   393
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   394
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   395
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   396
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   397
Function to instantiate a CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   398
This NewL creates an unititalised CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   399
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   400
@return A pointer to a new CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   401
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   402
EXPORT_C CMMFPtrBuffer* CMMFPtrBuffer::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   403
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   404
	CMMFPtrBuffer* self = new(ELeave) CMMFPtrBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   405
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   406
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   407
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   408
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   409
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   410
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   411
Function to instantiate a CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   412
This NewL creates a CMMFPtrBuffer which owns a TPtr8.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   413
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   414
@param  aPtr
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   415
        A reference to a TPtr containing the CMMFPtrBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   416
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   417
@return A pointer to a new CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   418
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   419
EXPORT_C CMMFPtrBuffer* CMMFPtrBuffer::NewL(const TPtr8& aPtr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   420
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   421
	CMMFPtrBuffer* self = new(ELeave) CMMFPtrBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   422
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   423
	self->ConstructL(aPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   424
	CleanupStack::Pop(self); // self
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   425
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   426
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   427
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   428
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   429
 * ConstructL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   430
 *
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   431
 * Internal ConstructL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   432
 * @internalTechnology
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   433
 * @param	"aPtr"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   434
 *			Reference to a TPtr containing the CMMFPtrBuffer data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   435
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   436
void CMMFPtrBuffer::ConstructL(const TPtr8& aPtr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   437
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   438
	iPtr.Set(aPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   439
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   440
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   441
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   442
Destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   443
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   444
Destructor does no deletion, as this buffer class does not own the memory.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   445
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   446
EXPORT_C CMMFPtrBuffer::~CMMFPtrBuffer()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   447
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   448
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   449
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   450
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   451
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   452
Returns a descriptor to the data contained in the CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   453
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   454
@return	A reference to a TPtr containing the CMMFPtrBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   455
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   456
TDes8& CMMFPtrBuffer::Data()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   457
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   458
	return iPtr;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   459
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   460
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   461
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   462
Returns a descriptor to the data contained in the CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   463
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   464
@return	A const reference to a TPtr containing the CMMFPtrBuffer data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   465
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   466
const TDesC8& CMMFPtrBuffer::Data() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   467
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   468
	return iPtr;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   469
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   470
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   471
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   472
Returns the actual data size (ie. not the max length) of the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   473
data contained in the CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   474
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   475
@return	The size in bytes of the data contained in the CMMFPtrBuffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   476
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   477
TUint CMMFPtrBuffer::BufferSize() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   478
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   479
	return iPtr.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   480
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   481
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   482
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   483
Sets the position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   484
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   485
This function is used by components (eg. codecs) which read data from a buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   486
and wish to store a read position marker for further reads.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   487
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   488
Note: The position cannot exceed the size of the actual data not the maximum length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   489
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   490
@param  aPosition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   491
        The position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   492
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   493
void CMMFPtrBuffer::SetPosition (TUint aPosition)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   494
	{//used for repositioning
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   495
	if (aPosition <= (TUint)iPtr.Length()) 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   496
		iPosition = aPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   497
	else 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   498
		iPosition = (TUint)iPtr.Length();//tried to position beyond end of data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   499
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   500
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   501
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   502
Sets the request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   503
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   504
This method is used in cases where a component (eg. a data source) may not be able
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   505
or be desirable to write to the entire max length of the buffer (eg. variable bit rate codecs).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   506
In this case, the SetRequestSizeL() can be set which can be read by the RequestSize()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   507
function in the component so that it knows to only write data upto the requested size
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   508
and not fill the buffer up to its maximum length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   509
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   510
@param  aSize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   511
        The request size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   512
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   513
void CMMFPtrBuffer::SetRequestSizeL(TInt aSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   514
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   515
	if (aSize < 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   516
		User::Leave(KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   517
	else if (aSize > iPtr.MaxLength())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   518
		User::Leave(KErrOverflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   519
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   520
		iRequestSize = aSize;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   521
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   522
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   523
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   524
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   525
Overriden method to set the status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   526
Resets the data size to 0 when the buffer becomes available.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   527
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   528
@param  aStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   529
        The buffer status. See enum TBufferStatus.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   530
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   531
void CMMFPtrBuffer::SetStatus(TBufferStatus aStatus)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   532
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   533
	CMMFBuffer::SetStatus(aStatus);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   534
	if (iStatus == EAvailable)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   535
		{//need to set size to 0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   536
		iPtr.Zero();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   537
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   538
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   539
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   540
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   541
/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   542
Takes a TPtr8 to pre-allocated memory.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   543
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   544
@param  aPtr
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   545
		The pointer refernce.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   546
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   547
EXPORT_C void CMMFPtrBuffer::SetPtr(const TPtr8& aPtr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   548
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   549
	iPtr.Set(aPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   550
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   551
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   552
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   553
//This functions needs updating
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   554
//should more CMMFDataBuffers be supported in future
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   555
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   556
Static method which returns ETrue if the buffer UID is a supported
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   557
CMMFDataBuffer type.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   558
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   559
Note:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   560
If the buffer is not a CMMFDataBuffer this method should
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   561
return EFalse.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   562
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   563
@param  aUid
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   564
        The UID of the CMMFBuffer to be checked for support.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   565
@return The buffer size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   566
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   567
EXPORT_C TBool CMMFBuffer::IsSupportedDataBuffer(TUid aUid)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   568
	{ 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   569
	return((aUid == KUidMmfDescriptorBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   570
		|| (aUid == KUidMmfTransferBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   571
		|| (aUid == KUidMmfPtrBuffer));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   572
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   573
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   574
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   575
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   576
Static method which returns ETrue if the buffer UID is a buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   577
that is safe to be used with the file server.  If the buffer type
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   578
is not safe to be used with the file server, then the client would
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   579
need to copy the contents of the buffer, prior to passing it onto
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   580
the file server.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   581
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   582
This implementation assumes the CMMFPtrBuffer is safe for file server copy. If this is not the case 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   583
then remove the PtrBuffer set to ETrue.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   584
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   585
@param  aUid
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   586
        The UID of the CMMFBuffer to be checked for support.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   587
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   588
@return The buffer size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   589
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   590
EXPORT_C TBool CMMFBuffer::IsFileServerSafe(TUid aUid)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   591
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   592
	TBool isFileServerSafe = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   593
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   594
	if (aUid == KUidMmfDescriptorBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   595
		isFileServerSafe = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   596
	if (aUid == KUidMmfPtrBuffer) //remove this if target CMMFPtrBuffers
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   597
		isFileServerSafe = ETrue; //are not safe for file server copy
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   598
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   599
	return isFileServerSafe;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   600
	}