mmlibs/mmfw/inc/mmf/server/MmfCodec.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\common\mmfcodec.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
#ifndef MMFCODEC_H
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#define MMFCODEC_H
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
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 <ecom/ecom.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include <mmf/common/mmfutilities.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
#include <mmf/plugin/mmfplugininterfaceuids.hrh>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
 * This UID is the INTERFACE_UID for CMMFCodec.  It is used to search for codec plugins in plugin DLLs.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
 * All codec plugin DLLs must include interface_uid = KMmfUidPluginInterfaceCodec in their .rss files.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
@publishedAll
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
@released
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
Indicates the result of processing data from the source buffer to a destination buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
and provides functions to compare the result code.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
class TCodecProcessResult
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
public:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	Flag to track the codec's processing status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
	enum TCodecProcessResultStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
	The codec successfully has completed its processing.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	A codec should return this code when it has fully processed the source buffer, and is finished
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	with the destination buffer. The codec should finish with the destination buffer when it has 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
	been filled. The EProcessComplete return code indicates that the codec has finished
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	with the destination buffer. This informs the data path that the destination buffer may now be 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
	passed onto the data sink. If the codec returns EProcessComplete this means that the codec is
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
	expecting a new source buffer and a new destination buffer the next time it's ProcessL() method
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
	is called.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	EProcessComplete,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
	Could not empty the source buffer because the destination buffer became full.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
	A codec should return this code when it has not been able to fully process the source buffer. 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
	This would usually be the case if the codec has filled the destination buffer (or the remaining 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
	space available in the destination buffer is insufficient to perform any further useful 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	processing) before the source buffer has been processed. The EProcessIncomplete return code 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	indicates that the codec has finished with the destination buffer. This informs the data path 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	that the destination buffer may now be passed onto the data sink. If the codec returns 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
	EProcessIncomplete this means that the codec is expecting the same source buffer but a new 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	destination buffer the next time it's ProcessL() method is called.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	EProcessIncomplete,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	Codec came across an end of data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	This can be returned if a codec is able to determine that there is no more source data. It is
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	not necessary for the codec to return this however as in most cases the codec will not be able
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	to determine when the end of data has been reached.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	EEndOfData,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	Could not fill the destination buffer because the source buffer has been emptied 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	A codec should return this code when is has fully processed the source buffer and there is still
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	sufficient space available in the destination buffer for the codec to continue using the same
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
	destination buffer. The EDstNotFilled return code indicates that the codec has not finished with
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	the destination buffer. If the codec returns EDstNotFilled this means that the codec is
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	expecting a new source buffer but the same destination buffer the next time its ProcessL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	method is called.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	EDstNotFilled,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	An error occured.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	This is no longer required as if an error occurs in the codec's ProcessL()function, it should 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	leave. When used with a datapath, returning EProcessError has the same effect as leaving with 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
	KErrCorrupt.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	EProcessError,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
	@deprecated
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
	As 'EFrameIncomplete' but also requests a call to GetNewDataPosition.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	EProcessIncompleteRepositionRequest,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
	@deprecated
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	As 'EFrameComplete' but also requests a call to GetNewDataPosition.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
	EProcessCompleteRepositionRequest
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
	};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	Overloaded operator to test equality.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	@param  aStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	        The status to compare the result of the process function.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	@return A boolean indicating if the two status codes are the same. ETrue if they are, EFalse
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
	        otherwise.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
	TBool operator==(const TCodecProcessResultStatus aStatus) const {return (iStatus == aStatus);}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
	Overloaded operator to test inequality.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	@param  aStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	        The status to compare the result of the process function.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	@return A boolean indicating if the two status codes are not the same. ETrue if they are not, 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	        EFalse otherwise.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
	TBool operator!=(const TCodecProcessResultStatus aStatus) const {return (iStatus != aStatus);}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
	The codec's processing status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
	@see enum TCodecProcessResultStatus
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
	TCodecProcessResultStatus iStatus;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
	The number of source bytes processed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
	The number of bytes of source data that have been processed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
	A codec should set this, and iDstBytesAdded, to indicate the source bytes processed for a 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
	particular call (i.e. not the total number of source bytes processed or destination bytes 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	added). The codec should also ensure that the length of the destination buffer matches the 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
	length of the processed data in the destination buffer. Note that the codec should not 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
	reallocate the maximum length of the destination buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
	TUint iSrcBytesProcessed;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
	/** 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
	The number of bytes added to the destination buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
	A codec should set this, and iSrcBytesProcessed, to indicate the source bytes processed for a 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
	particular call (i.e. not the total number of source bytes processed or destination bytes 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
	added). The codec should also ensure that the length of the destination buffer matches the 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
	length of the processed data in the destination buffer. Note that the codec should not 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
	reallocate the maximum length of the destination buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
	TUint iDstBytesAdded;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
public:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
	Default constructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
	TCodecProcessResult()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
		:iStatus(EProcessError), iSrcBytesProcessed(0), iDstBytesAdded(0) {};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
private:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
	This member is internal and not intended for use.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
	TInt iReserved1;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
	TInt iReserved2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
	TInt iReserved3;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
	};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
class TFourCC; //forward reference
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
class CMMFBuffer; //forward reference
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
@publishedAll
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
@released
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
ECom plugin class for a codec that processes source data in a certain fourCC coding type and
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
converts it to a destination buffer of another fourCC coding type.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
The function is synchronous as it is expected that the codec will be operating in its own thread
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
of execution - usually via a CMMFDataPath or CMMFDataPathProxy
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
The codec can be instantiated in 3 different ways:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
1.	NewL(const TFourCC& aSrcDatatype, const TFourCC& aDstDataType).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
This instantiate a codec that can convert the aSrcDatatype to a aDstDataType.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
2.	NewL(const TFourCC& aSrcDatatype, const TFourCC& aDstDataType, const TDesC& aPreferredSupplier).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
This is similar to the above but is used where there may be multiple codecs that
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
perform the same conversion - the idea is that a 3rd party deveoper may develop there own
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
controller and codecs and can ensure the controller uses their codecs by setting the preferredSupplier
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
to themselves.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
3.	NewL(TUid aUid).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
This is used to explicitly instantiated a codec where the uid is known.  This might be used by
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
controlers that only support one codec type.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
The processing of the data is handled by the codecs ProcessL() member.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
The intention is that the source buffer for conversion is converted to the appropriate coding type
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
in the destination buffer.  The buffers can be of any size.  Since the buffers can be of any size there is no
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
guarantee that all the source buffer can be processed to fill the destination buffer or that the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
all the source buffer may be processed before the destination is full.  Therefore the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
ProcessL needs to return a TCodecProcessResult returing the number of source bytes processed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
and the number of destination bytes processed along with a process result code defined thus:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
- EProcessComplete: the codec processed all the source data into the sink buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
- EProcessIncomplete: the codec filled sink buffer before all the source buffer was processed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
- EDstNotFilled: the codec processed the source buffer but the sink buffer was not filled
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
- EEndOfData: the codec detected the end data - all source data in processed but sink may not be full
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
- EProcessError: the codec process error condition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
The ProcessL should start processing the source buffer from the iPosition data member of the source data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
and start filling the destination buffer from its iPosition.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
class CMMFCodec  : public CBase
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
public:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
	//The function which instantiates an object of this type
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
	// using the TFourCC codes as the resolver parameters.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
	IMPORT_C static CMMFCodec* NewL(const TFourCC& aSrcDatatype, const TFourCC& aDstDataType);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
	IMPORT_C static CMMFCodec* NewL(const TFourCC& aSrcDatatype, const TFourCC& aDstDataType, const TDesC& aPreferredSupplier);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
	IMPORT_C static CMMFCodec* NewL(TUid aUid);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
	static void SelectByPreference( RImplInfoPtrArray& aPlugInArray, const TDesC& aPreferredSupplier ) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
	inline virtual void ConfigureL(TUid aConfigType, const TDesC8& aConfigData);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
	Codec reset.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
	Used to flush out status information when a reposition occurs. This is a virtual function that 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
	is provided should the codec require resetting prior to use.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
	virtual void ResetL() {}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
	//Standardised destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
	inline virtual ~CMMFCodec();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
	Processes the data in the specified source buffer and writes the processed data to the specified 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
	destination buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
	This function is synchronous, when the function returns the data has been processed. The source 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
	buffer is converted to the appropriate coding type in the destination buffer. The buffers can be 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
	of any size, therefore there is no guarantee that all the source buffer can be processed to fill 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
	the destination buffer or that all the source buffer may be processed before the destination is 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
	full. This function therefore returns the number of source, and destination, bytes processed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
	along with a process result code indicating completion status.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
	The aSource and aSink buffers passed in are derived from CMMFBuffer. The buffer type (e.g. a 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
	CMMFDataBuffer) passed in should be supported by the codec otherwise this function should leave 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
	with KErrNotSupported. The position of the source buffer should be checked by calling the source 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
	buffer's Position() member which indicates the current source read position in bytes. The codec 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
	should start processing from the current source buffer read position. The position of the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
	destination buffer should be checked by calling the destination buffer's Position() method which 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
	indicates the current destination write position in bytes. The codec should start writing to the 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
	destination buffer at the current destination buffer write position.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
	This is a virtual function that each derived class must implement.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
	@see enum TCodecProcessResult
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
	@param  aSource
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
	        The source buffer containing data to encode or decode.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
	@param  aDestination
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
	        The destination buffer to hold the data after encoding or decoding.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
	@return The result of the processing.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
	virtual TCodecProcessResult ProcessL(const CMMFBuffer& aSource, CMMFBuffer& aDestination) = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
	@internalComponent
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
	Gets a pointer to the extension specified by an identifier. The extension can be either an
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
	interface or function. If the extension is not supported NULL value is given and returns
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
	KErrExtensionNotSupported.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
	@param	aExtensionId
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
		Extension identifier.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
	@param	aExtPtr
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
		Pointer to get the extension.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
	@return	If successful returns KErrNone otherwise KErrExtensionNotSupported.		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
	TInt ExtensionInterface(TUint aExtensionId, TAny*& aExtPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
private:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
	TUid iDtor_ID_Key;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
Destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
Destroys any variables then informs ECom that this specific instance of the interface has been
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
destroyed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
inline CMMFCodec::~CMMFCodec()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
	// Destroy any instance variables and then
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
	// inform ecom that this specific 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
	// instance of the interface has been destroyed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
	REComSession::DestroyedImplementation(iDtor_ID_Key);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
Sets codec configuration.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
This is a virtual function which does not need to be implemented
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
by a codec, but may be if required. This function provides additional configuration
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
information for the codec. The configuration is passed in as a descriptor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
The default version leaves with KErrNotSupported.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
@param  aConfigType
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
        The UID of the configuration data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
@param  aConfigData
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
        The configuration information.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
inline void CMMFCodec::ConfigureL(TUid /*aConfigType*/, const TDesC8& /*aConfigData*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
	User::Leave(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341