devsound/a3fdevsound/src/a3ffourcclookup/a3ffourcclookup.cpp
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
//a3ffourcclookup.cpp
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
#include <a3f/a3ffourcclookup.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#include "a3ffourcclookup.hrh"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#include <a3f/a3f_trace_utils.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
#include <mm/mmcleanup.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
#ifdef SYMBIAN_ENABLE_SPLIT_HEADERS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include <a3f/a3f_trace_ctxt_def.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
_LIT8(KHexPrefix, "0x");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
_LIT8(KHexPrefix2, "0X");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
_LIT8(uTag,"<u>");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
_LIT8(mTag,"<m>");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
_LIT8(fTag,"<f>");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
const TInt KUidLength = 10;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
const TInt KTagLength = 3;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
const TInt KFourCCLength = 4;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
// Function to compute Hash value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
TUint32 TIntegerHash(const TUint32& aInt)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	return DefaultHash::Integer(aInt);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
// Function to Check similar identities from Hash Table
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
TBool TIntegerIdent(const TUint32& /*aL*/, const TUint32& /*aR*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	return ETrue;
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
// Destructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
CFourCCConvertor::~CFourCCConvertor()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	if(iHashFourCCToFormat)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
		iHashFourCCToFormat->Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
		delete iHashFourCCToFormat;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
		iHashFourCCToFormat = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
	if(iHashFormatToFourCC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
		iHashFormatToFourCC->Close();	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
		delete iHashFormatToFourCC;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
		iHashFormatToFourCC = NULL;
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
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
// Default constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
CFourCCConvertor::CFourCCConvertor()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	TRACE_CREATE();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	DP_CONTEXT(CFourCCConvertor::CFourCCConvertor *CD1*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	DP_OUT();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
// CFourCCConvertor::NewL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
EXPORT_C CFourCCConvertor* CFourCCConvertor::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
	DP_STATIC_CONTEXT(CFourCCConvertor::NewL *CD0*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	CFourCCConvertor* self = new(ELeave) CFourCCConvertor();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	self->ConstructL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	CleanupStack::Pop(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	DP0_RET(self, "0x%x");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
// Second Phase Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
void CFourCCConvertor::ConstructL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	DP_CONTEXT(CCFourCCConvertor::ConstructL *CD1*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	iHashFourCCToFormat = new(ELeave) RHashMap<TUint32,TUint32>(&TIntegerHash,&TIntegerIdent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
	iHashFormatToFourCC = new(ELeave) RHashMap<TUint32,TUint32>(&TIntegerHash,&TIntegerIdent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
	LoadL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
	DP_OUT();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
// CFourCCConvertor::LoadL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
void CFourCCConvertor::LoadL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
	DP_CONTEXT(CCFourCCConvertor::LoadL *CD1*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
	TUid KFourCCInterfaceDefinitionUid = {KUidA3fFourCCConvertorPlugin};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	RImplInfoPtrArray ecomArray;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	REComSession::ListImplementationsL(KFourCCInterfaceDefinitionUid, ecomArray);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	CleanupResetAndDestroyPushL(ecomArray);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	ASSERT(iHashFourCCToFormat);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
	ASSERT(iHashFormatToFourCC);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
	TInt index;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
	index = ecomArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
	if(index == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
		User::Leave(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	TInt tagPosition=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	TUint32 formatIdValue = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	// Construct the hash map
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
	for (TInt i=0; i<index; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
		// Get opaque data field
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
		const TPtrC8 opaquedata(ecomArray[i]->OpaqueData());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
		TInt length = opaquedata.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
				
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
		// Extracting format uid
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
		tagPosition = opaquedata.Find(uTag);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
		if( (tagPosition >= 0) && ( (length-tagPosition) >= (KUidLength + KTagLength) ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
			// Format Uid
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
			if(((((opaquedata).Mid(tagPosition + KTagLength, KUidLength) ).Length()) == KUidLength) &&
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
				((((opaquedata).Mid(tagPosition + KTagLength, KUidLength)).Find(KHexPrefix)) ==0) ||
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
				((((opaquedata).Mid(tagPosition + KTagLength, KUidLength)).Find(KHexPrefix2)) ==0))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
				TLex8 lexFormatUid(((opaquedata).Mid(tagPosition + KTagLength, KUidLength)).Right(8));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
				User::LeaveIfError(lexFormatUid.Val(formatIdValue,EHex));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
			// Check if this is master FourCC
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
			TInt tagMasterFourCC=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
			tagMasterFourCC= (opaquedata).Find(mTag);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
			// Extract fourCC
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
			tagPosition = (opaquedata).Find(fTag);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
			if((tagPosition >=0) && (length-tagPosition>=(KFourCCLength + KTagLength)))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
				TFourCC tempFourCC((opaquedata).Mid(tagPosition + KTagLength, KFourCCLength));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
				if(tempFourCC.FourCC() != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
					iHashFourCCToFormat->InsertL(tempFourCC.FourCC(),formatIdValue); 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
				// Only fourCC master should be inserted
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
				if(tagMasterFourCC >= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
					iHashFormatToFourCC->InsertL(formatIdValue, tempFourCC.FourCC());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
				DP0(DLINFO,"CCFourCCConvertor::<f> tag not found or <f> tag should have four characters entry in resource file ");	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
			DP0(DLINFO,"CCFourCCConvertor::<u> tag not found or <u> tag should have ten characters e.g. 0X12122121 entry in resource file");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
	CleanupStack::PopAndDestroy(&ecomArray);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
	DP_OUT();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
// CFourCCConvertor::FormatToFourCC
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
EXPORT_C TInt CFourCCConvertor::FormatToFourCC(TUid aFormat,TFourCC &aFourCC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
	DP_CONTEXT(CCFourCCConvertor::FormatToFourCC *CD1*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
	ASSERT(iHashFormatToFourCC);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
	TUint32 *mime = iHashFormatToFourCC->Find(aFormat.iUid);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
	if(mime == NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
		err = KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
		aFourCC.Set(*mime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
	DP0_RET(err, "%d");
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
// CFourCCConvertor::FourCCToFormat
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
// ---------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
EXPORT_C TInt CFourCCConvertor::FourCCToFormat(TFourCC aFourCC, TUid &aFormat) const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
	DP_CONTEXT(CCFourCCConvertor::FourCCToFormat *CD1*, CtxDevSound, DPLOCAL);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
	DP_IN();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
	ASSERT(iHashFourCCToFormat);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
	TUint32 *mime= iHashFourCCToFormat->Find(aFourCC.FourCC());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
	if(mime == NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
		err = KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
		aFormat.iUid = *mime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
	DP0_RET(err, "%d");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
	}