mmlibs/mmfw/inc/mmf/server/mmfbuffer.h
author hgs
Tue, 02 Nov 2010 12:28:51 +0000
changeset 6 fe9d1bf55678
parent 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk46_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2002-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
// include\mmf\server\mmfbuffer.h
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
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#ifndef __MMF_SERVER_BUFFER_H__
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#define __MMF_SERVER_BUFFER_H__
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
#include <e32base.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
#include <mmf/server/mmfbuffer.hrh>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
@publishedAll
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
@released
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
Flag reflecting the current buffer status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
enum TBufferStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
	/** The buffer is available for use */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
	EAvailable,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
	/** The buffer is currently being filled */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
	EBeingFilled,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	/** The buffer is full */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	EFull,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	/** The buffer is currently being emptied */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	EBeingEmptied,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
	/** The buffer is currently unavailable */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
	EUnAvailable
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
	};
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
@publishedAll
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
@released
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
Abstract representation of a buffer to contain multimedia data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
class CMMFBuffer : public CBase
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
public:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
	IMPORT_C static TBool IsSupportedDataBuffer(TUid aUid);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
	IMPORT_C static TBool IsFileServerSafe(TUid aUid);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
	Returns the buffer type.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	@return The buffer type.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	TUid Type() const {return iType;};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	Sets the buffer's status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	@param  aStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
	        The buffer's status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	virtual void SetStatus(TBufferStatus aStatus) 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
			{iStatus = aStatus; if (iStatus == EAvailable) iPosition = 0;}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	Returns the buffer's status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	@return The buffer's status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
	TBufferStatus Status() {return iStatus;};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
	Returns the size of the data in the buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	This is a virtual function that each derived class must implement.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	@return The buffer size.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	virtual TUint BufferSize() const = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	Destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	virtual ~CMMFBuffer() {};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
	inline TTimeIntervalMicroSeconds TimeToPlay() const;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	inline void SetTimeToPlay (TTimeIntervalMicroSeconds aTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	inline TUint FrameNumber() const;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
	inline void SetFrameNumber(TUint aFrame);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	inline void NextFrame();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	inline virtual void SetPosition (TUint aPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	inline virtual TUint Position() const;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	inline virtual TInt RequestSize() const;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
	inline void SetLastBuffer(TBool aLastBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
	inline TBool LastBuffer() const;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
protected:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
	CMMFBuffer(TUid aType): iType(aType), iStatus(EAvailable) {};	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
protected:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
	The buffer type. 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	TUid iType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
	The current buffer status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	@see enum TBufferStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	TBufferStatus iStatus;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
	The buffer timestamp, in microseconds. 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
	TTimeIntervalMicroSeconds iTimeToPlay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
	Used to store the current read/write position. Required when the codec and data path
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
	may have to read and write the buffer in more than one pass.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
	TUint iPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	The frame number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
	TUint iFrameNumber;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
	Stores Request size, needed for dynamic buffer length.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
	TInt iRequestSize;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
	Indicates if this is the last buffer. ETrue if it is.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	TBool iLastBuffer; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
	};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
Returns the buffer timestamp, in microseconds.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
@return	The buffer timestamp, in microseconds.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
inline TTimeIntervalMicroSeconds CMMFBuffer::TimeToPlay() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
	return iTimeToPlay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
Sets the buffer timestamp, in microseconds.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
@param  aTime
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
        The buffer timestamp, in microseconds.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
inline void CMMFBuffer::SetTimeToPlay (TTimeIntervalMicroSeconds aTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
	iTimeToPlay = aTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
Returns the frame number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
@return The frame number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
inline TUint CMMFBuffer::FrameNumber() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
	return iFrameNumber;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
Sets the frame number. This is used for repositioning.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
@param  aFrameNumber
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
        The frame number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
inline void CMMFBuffer::SetFrameNumber (TUint aFrameNumber)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
	iFrameNumber = aFrameNumber;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
Sets the buffer as the next frame.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
inline void CMMFBuffer::NextFrame()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
	iFrameNumber++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
Sets the current buffer read/write position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
Used as read/write position on a buffer where a codec may need
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
several passes on the same buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
@param  aPosition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
        The buffer's number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
inline void CMMFBuffer::SetPosition (TUint aPosition)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
	iPosition = aPosition;
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
Returns the current buffer read/write position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
Used as read/write position on a buffer where a codec may need
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
several passes on the same buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
@return The buffer's number.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
inline TUint CMMFBuffer::Position() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
	return iPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
Tests whether the buffer is the last buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
@return A boolean indicating if the buffer is the last one. ETrue if it is the last buffer, 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
        EFalse otherwise.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
inline TBool CMMFBuffer::LastBuffer() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
	return iLastBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
Sets the buffer as the last buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
@param  aLastBuffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
        A boolean indicating if the buffer is the last buffer. ETrue if it is the last buffer, 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
        EFalse otherwise.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
inline void CMMFBuffer::SetLastBuffer(TBool aLastBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
	iLastBuffer = aLastBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
Returns the size of data processed by sink or data needed by source.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
@return The size of data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
inline TInt CMMFBuffer::RequestSize() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
	return iRequestSize;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
#endif