os/mm/devsoundextensions/mmfcustominterfaces/EAacPlusDecoderIntfc/EAacPlusDecoderIntfcMsgHdlr/src/EAacPlusDecoderIntfcMsgHdlr.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2006 Nokia Corporation and/or its subsidiary(-ies). 
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description:   Message handler for eAAC+ decoder configuration interface.
sl@0
    15
*
sl@0
    16
*/
sl@0
    17
sl@0
    18
sl@0
    19
sl@0
    20
// INCLUDE FILES
sl@0
    21
#include    "EAacPlusDecoderIntfcMsgs.h"
sl@0
    22
#include    "EAacPlusDecoderIntfcMsgHdlr.h"
sl@0
    23
sl@0
    24
// EXTERNAL DATA STRUCTURES
sl@0
    25
sl@0
    26
// EXTERNAL FUNCTION PROTOTYPES
sl@0
    27
sl@0
    28
// CONSTANTS
sl@0
    29
sl@0
    30
// MACROS
sl@0
    31
sl@0
    32
// LOCAL CONSTANTS AND MACROS
sl@0
    33
sl@0
    34
// MODULE DATA STRUCTURES
sl@0
    35
sl@0
    36
// LOCAL FUNCTION PROTOTYPES
sl@0
    37
sl@0
    38
// FORWARD DECLARATIONS
sl@0
    39
sl@0
    40
// ============================= LOCAL FUNCTIONS ===============================
sl@0
    41
sl@0
    42
// ============================ MEMBER FUNCTIONS ===============================
sl@0
    43
sl@0
    44
/**
sl@0
    45
 * CEAacPlusDecoderIntfcMsgHdlr::CEAacPlusDecoderIntfcMsgHdlr
sl@0
    46
 * C++ default constructor can NOT contain any code, that might leave.
sl@0
    47
 */
sl@0
    48
CEAacPlusDecoderIntfcMsgHdlr::CEAacPlusDecoderIntfcMsgHdlr(
sl@0
    49
                              CEAacPlusDecoderIntfc* aAacDecoderConfigCI) :
sl@0
    50
	CMMFObject(KUidEAacPlusDecoderIntfc)
sl@0
    51
    {
sl@0
    52
    iAacDecoderConfigCI = aAacDecoderConfigCI;
sl@0
    53
    }
sl@0
    54
sl@0
    55
/**
sl@0
    56
 * CEAacPlusDecoderIntfcMsgHdlr::ConstructL
sl@0
    57
 * Symbian 2nd phase constructor can leave.
sl@0
    58
 */
sl@0
    59
void CEAacPlusDecoderIntfcMsgHdlr::ConstructL()
sl@0
    60
    {
sl@0
    61
    }
sl@0
    62
sl@0
    63
/**
sl@0
    64
 * CEAacPlusDecoderIntfcMsgHdlr::NewL
sl@0
    65
 * Two-phased constructor.
sl@0
    66
 */
sl@0
    67
EXPORT_C CEAacPlusDecoderIntfcMsgHdlr* CEAacPlusDecoderIntfcMsgHdlr::NewL(
sl@0
    68
                                       TAny* aAacDecoderConfigCI)
sl@0
    69
    {
sl@0
    70
    CEAacPlusDecoderIntfc* aacDecoderConfigCI =
sl@0
    71
                (CEAacPlusDecoderIntfc*)aAacDecoderConfigCI;
sl@0
    72
    CEAacPlusDecoderIntfcMsgHdlr* self =
sl@0
    73
                new (ELeave) CEAacPlusDecoderIntfcMsgHdlr(aacDecoderConfigCI);
sl@0
    74
    CleanupStack::PushL( self );
sl@0
    75
    self->ConstructL();
sl@0
    76
    CleanupStack::Pop( self );
sl@0
    77
sl@0
    78
    return self;
sl@0
    79
    }
sl@0
    80
sl@0
    81
/**
sl@0
    82
 * Destructor
sl@0
    83
 */
sl@0
    84
EXPORT_C CEAacPlusDecoderIntfcMsgHdlr::~CEAacPlusDecoderIntfcMsgHdlr()
sl@0
    85
	{
sl@0
    86
	delete iAacDecoderConfigCI;
sl@0
    87
	}
sl@0
    88
sl@0
    89
/**
sl@0
    90
 * CEAacPlusDecoderIntfcMsgHdlr::HandleRequest
sl@0
    91
 * Handles the messages from the proxy.
sl@0
    92
 * Calls a subfunction which determines what custom interface to call.
sl@0
    93
 * A subfunction is used to contain multiple leaving functions for a single
sl@0
    94
 * trap.
sl@0
    95
 * (other items were commented in a header).
sl@0
    96
 */
sl@0
    97
EXPORT_C void CEAacPlusDecoderIntfcMsgHdlr::HandleRequest(
sl@0
    98
                                            TMMFMessage& aMessage)
sl@0
    99
	{
sl@0
   100
	ASSERT(aMessage.Destination().InterfaceId() == KUidEAacPlusDecoderIntfc);
sl@0
   101
sl@0
   102
	TRAPD(error, DoHandleRequestL(aMessage));
sl@0
   103
	if(error)
sl@0
   104
		{
sl@0
   105
		aMessage.Complete(error);
sl@0
   106
		}
sl@0
   107
	}
sl@0
   108
sl@0
   109
/**
sl@0
   110
 * CEAacPlusDecoderIntfcMsgHdlr::DoHandleRequestL
sl@0
   111
 * Determines which custom interface to call.
sl@0
   112
 * (other items were commented in a header).
sl@0
   113
 */
sl@0
   114
void CEAacPlusDecoderIntfcMsgHdlr::DoHandleRequestL(TMMFMessage& aMessage)
sl@0
   115
	{
sl@0
   116
	switch(aMessage.Function())
sl@0
   117
		{
sl@0
   118
		case EEaacpdimApplyConfig:
sl@0
   119
			{
sl@0
   120
    		DoApplyConfigL(aMessage);
sl@0
   121
			break;
sl@0
   122
			}
sl@0
   123
		default:
sl@0
   124
			{
sl@0
   125
			aMessage.Complete(KErrNotSupported);
sl@0
   126
			}
sl@0
   127
		}
sl@0
   128
	}
sl@0
   129
sl@0
   130
/**
sl@0
   131
 * CEAacPlusDecoderIntfcMsgHdlr::DoApplyConfigL
sl@0
   132
 * Handles the message from the proxy and calls the custom interface method
sl@0
   133
 * to commit configuration settings to the decoder.
sl@0
   134
 * (other items were commented in a header).
sl@0
   135
 */
sl@0
   136
void CEAacPlusDecoderIntfcMsgHdlr::DoApplyConfigL(TMMFMessage& aMessage)
sl@0
   137
    {
sl@0
   138
	TPckgBuf<TEAacPlusDecoderConfig> pckgBuf;
sl@0
   139
	aMessage.ReadData1FromClientL(pckgBuf);
sl@0
   140
sl@0
   141
	iAacDecoderConfigCI->SetAudioObjectType(pckgBuf().iAudioObjectType);
sl@0
   142
	iAacDecoderConfigCI->SetInputSamplingFrequency(
sl@0
   143
	                     pckgBuf().iInputSamplingFrequency);
sl@0
   144
	iAacDecoderConfigCI->SetNumOfChannels(pckgBuf().iNumOfChannels);
sl@0
   145
	iAacDecoderConfigCI->SetSbr(pckgBuf().iSbrEnabled);
sl@0
   146
	iAacDecoderConfigCI->SetDownSampledMode(pckgBuf().iDsmEnabled);
sl@0
   147
sl@0
   148
	TInt status = iAacDecoderConfigCI->ApplyConfig();
sl@0
   149
    aMessage.Complete(status);
sl@0
   150
    }
sl@0
   151
sl@0
   152
// End of File