os/mm/devsoundextensions/mmfcustominterfaces/IlbcDecoderIntfc/IlbcDecoderIntfcMsgHdlr/src/IlbcDecoderIntfcMsgHdlr.cpp
Update contrib.
2 * Copyright (c) 2002-2004 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
14 * Description: Message handler for Ilbc decoder interface
21 #include "IlbcDecoderIntfcMsgHdlr.h"
22 #include "IlbcDecoderIntfcMsgs.h"
23 #include <IlbcDecoderIntfc.h>
25 // EXTERNAL DATA STRUCTURES
27 // EXTERNAL FUNCTION PROTOTYPES
33 // LOCAL CONSTANTS AND MACROS
35 // MODULE DATA STRUCTURES
37 // LOCAL FUNCTION PROTOTYPES
39 // FORWARD DECLARATIONS
41 // ============================= LOCAL FUNCTIONS ===============================
43 // ============================ MEMBER FUNCTIONS ===============================
45 // -----------------------------------------------------------------------------
46 // CIlbcDecoderIntfcMsgHdlr::CIlbcDecoderIntfcMsgHdlr
47 // C++ default constructor can NOT contain any code, that
49 // -----------------------------------------------------------------------------
51 CIlbcDecoderIntfcMsgHdlr::CIlbcDecoderIntfcMsgHdlr(
52 CIlbcDecoderIntfc* aIlbcDecoderIntfcCI) :
53 CMMFObject(KUidIlbcDecoderIntfc)
55 iIlbcDecoderIntfcCI = aIlbcDecoderIntfcCI;
58 // -----------------------------------------------------------------------------
59 // CIlbcDecoderIntfcMsgHdlr::ConstructL
60 // Symbian 2nd phase constructor can leave.
61 // -----------------------------------------------------------------------------
63 void CIlbcDecoderIntfcMsgHdlr::ConstructL()
67 // -----------------------------------------------------------------------------
68 // CIlbcDecoderIntfcMsgHdlr::NewL
69 // Two-phased constructor.
70 // -----------------------------------------------------------------------------
72 EXPORT_C CIlbcDecoderIntfcMsgHdlr* CIlbcDecoderIntfcMsgHdlr::NewL(
73 TAny* aIlbcDecoderIntfcCI)
75 CIlbcDecoderIntfc* errorConcealmentIntfcCI =
76 (CIlbcDecoderIntfc*)aIlbcDecoderIntfcCI;
77 CIlbcDecoderIntfcMsgHdlr* self =
78 new (ELeave) CIlbcDecoderIntfcMsgHdlr(errorConcealmentIntfcCI);
79 CleanupStack::PushL( self );
81 CleanupStack::Pop( self );
87 EXPORT_C CIlbcDecoderIntfcMsgHdlr::~CIlbcDecoderIntfcMsgHdlr()
89 delete iIlbcDecoderIntfcCI;
92 // ---------------------------------------------------------
93 // CIlbcDecoderIntfcMsgHdlr::HandleRequest
94 // Handles the messages from the proxy.
95 // Calls a subfunction which determines which custom interface to call.
96 // A subfunction is used to contain multiple leaving functions for a single
98 // (other items were commented in a header).
99 // ---------------------------------------------------------
101 EXPORT_C void CIlbcDecoderIntfcMsgHdlr::HandleRequest(
102 TMMFMessage& aMessage)
104 ASSERT(aMessage.Destination().InterfaceId() == KUidIlbcDecoderIntfc);
105 TRAPD(error,DoHandleRequestL(aMessage));
108 aMessage.Complete(error);
112 // ---------------------------------------------------------
113 // CIlbcDecoderIntfcMsgHdlr::DoHandleRequestL
114 // Determines which custom interface to call.
115 // (other items were commented in a header).
116 // ---------------------------------------------------------
118 void CIlbcDecoderIntfcMsgHdlr::DoHandleRequestL(TMMFMessage& aMessage)
120 switch(aMessage.Function())
122 case EIlbcdimSetDecoderMode:
124 DoSetDecoderModeL(aMessage);
139 aMessage.Complete(KErrNotSupported);
144 // ---------------------------------------------------------
145 // CIlbcDecoderIntfcMsgHdlr::DoSetDecoderModeL
146 // Handles the message from the proxy and calls the custom interface method.
147 // The data passed from the proxy is read from the message and passed to
148 // the custom interface.
149 // (other items were commented in a header).
150 // ---------------------------------------------------------
152 void CIlbcDecoderIntfcMsgHdlr::DoSetDecoderModeL(TMMFMessage& aMessage)
154 TPckgBuf<CIlbcDecoderIntfc::TDecodeMode> pckgBuf;
155 aMessage.ReadData1FromClientL(pckgBuf);
156 TInt status = iIlbcDecoderIntfcCI->SetDecoderMode(pckgBuf());
157 aMessage.Complete(status);
160 // ---------------------------------------------------------
161 // CIlbcDecoderIntfcMsgHdlr::DoSetCngL
162 // Handles the message from the proxy and calls the custom interface method.
163 // The data passed from the proxy is read from the message and passed to
164 // the custom interface.
165 // (other items were commented in a header).
166 // ---------------------------------------------------------
168 void CIlbcDecoderIntfcMsgHdlr::DoSetCngL(TMMFMessage& aMessage)
170 TPckgBuf<TBool> pckgBuf;
171 aMessage.ReadData1FromClientL(pckgBuf);
172 TInt status = iIlbcDecoderIntfcCI->SetCng(pckgBuf());
173 aMessage.Complete(status);
176 // ---------------------------------------------------------
177 // CIlbcDecoderIntfcMsgHdlr::DoGetCngL
178 // Handles the message from the proxy and calls the custom interface method.
179 // The custom interface returns the data requested and this function
180 // writes it back to the proxy.
181 // (other items were commented in a header).
182 // ---------------------------------------------------------
184 void CIlbcDecoderIntfcMsgHdlr::DoGetCngL(TMMFMessage& aMessage)
187 TInt status = iIlbcDecoderIntfcCI->GetCng(cng);
188 if (status == KErrNone)
190 TPckgBuf<TBool> pckgBuf;
192 aMessage.WriteDataToClientL(pckgBuf);
194 aMessage.Complete(status);