diff -r 000000000000 -r e6b17d312c8b imservices/imfeatureplugin/srcimoperations/imconversation/operationsendmessage.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/imservices/imfeatureplugin/srcimoperations/imconversation/operationsendmessage.cpp Thu Dec 17 08:54:49 2009 +0200 @@ -0,0 +1,115 @@ +/* +* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: Concrete im send message operation + * +*/ + + + +#include +#include +#include +#include "imconversationinfoimp.h" +#include "operationsendmessage.h" +#include "ximpobjecthelpers.h" +//#include "ximprestrictedobjectcollectionimp.h" +//#include "ximphost.h" +//#include "ximpstatusimp.h" +//#include "ximprequestcompleteeventimp.h" +#include "protocolimdatahostimp.h" +#include "imlogutils.h" +#include + + +// ======== MEMBER FUNCTIONS ======== + +// --------------------------------------------------------------------------- +// COperationSendMessage::COperationSendMessage() +// --------------------------------------------------------------------------- +// +EXPORT_C COperationSendMessage::COperationSendMessage() + { + } +// --------------------------------------------------------------------------- +// COperationSendMessage::ConstructL +// --------------------------------------------------------------------------- +// +void COperationSendMessage::ConstructL( const TDesC8& aParamPck ) + { + XImLogger::Log(_L("COperationSendMessage::ConstructL Started")); + CImConversationInfoImp* convInfo = CImConversationInfoImp::NewLC(); + TXIMPObjectPacker< CImConversationInfoImp >::UnPackL( *convInfo, + aParamPck ); + CleanupStack::Pop( convInfo ); + iConvInfo = convInfo; + XImLogger::Log(_L("COperationSendMessage::ConstructL Completed")); + } + +// --------------------------------------------------------------------------- +// COperationSendMessage::~COperationSendMessage() +// --------------------------------------------------------------------------- +// +COperationSendMessage::~COperationSendMessage() + { + XImLogger::Log(_L("COperationSendMessage::~COperationSendMessage Started")); + delete iConvInfo; + XImLogger::Log(_L("COperationSendMessage::~COperationSendMessage Completed")); + } + + +// --------------------------------------------------------------------------- +// COperationSendMessage::ProcessL() +// --------------------------------------------------------------------------- +// +void COperationSendMessage::ProcessL() + { + XImLogger::Log(_L("COperationSendMessage::ProcessL Started")); + CXIMPOperationBase::ProcessL(); + + // Call to Adaptation. + //MProtocolImConversation& imconversation = iMyHost->GetConnection().ProtocolImFeatures()->ImConversation(); + + + // Pankaj : added to support dynamic resolution + CProtocolImFeatures* imProtocolFeature =static_cast< CProtocolImFeatures*> (iMyHost->GetConnection().GetProtocolInterface(CProtocolImFeatures::KInterfaceId)); + + MProtocolImConversation& imconversation = imProtocolFeature->ImConversation() ; + + + imconversation.DoSendMessageL(*iConvInfo,iReqId ); + XImLogger::Log(_L("COperationSendMessage::ProcessL Completed")); + } + +// --------------------------------------------------------------------------- +// COperationSendMessage::RequestCompleted() +// --------------------------------------------------------------------------- +// +void COperationSendMessage::RequestCompletedL() + { + XImLogger::Log(_L("COperationSendMessage::RequestCompletedL Started")); + CXIMPOperationBase::RequestCompletedL(); + XImLogger::Log(_L("COperationSendMessage::RequestCompletedL Completed")); + } + +// --------------------------------------------------------------------------- +// COperationSendMessage::Type() +// --------------------------------------------------------------------------- +// +TInt COperationSendMessage::Type() const + { + return NImOps::ESendImMessage; + } + + +// End of file