messagingfw/wappushfw/plugins/inc/CContentHandlerBase.inl
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 18 Jan 2010 20:36:02 +0200
changeset 0 8e480a14352b
permissions -rw-r--r--
Revision: 201001 Kit: 201003

// Copyright (c) 2001-2009 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:
// Local includes
// 
//

/**
 @file
 @publishedPartner
 @released
*/

// System includes
//
#include <ecom/ecom.h>
#include <push/ccontenthandlerbase.h>
#include <push/pushlog.h>
#include <push/pluginkiller.h>


/** 
Constructor. 
*/
inline CContentHandlerBase::CContentHandlerBase()
: CPushHandlerBase()
	{
	}


/** 
Destructor. 
*/
inline CContentHandlerBase::~CContentHandlerBase()
	{
	__LOG_PTR_DEBUG("CContentHandlerBase:: Destructor Called");
	Cancel();
	delete iMessage;
	}


/** 
Finds and instantiates an ECom WAP Push Content Handler plug-in that matches 
the specified media type.

@param aMatchData 
Media type.

@return 
WAP Push plug-in that handles the specified media type.
*/
inline CContentHandlerBase* CContentHandlerBase::NewL(const TDesC& aMatchData)
	{
	// Call base class interface CPushHandlerBase::NewL()
	return REINTERPRET_CAST(CContentHandlerBase*, 
							CPushHandlerBase::NewL(aMatchData, KUidPushContentHandlerBase));
	}


/** 
Sets a parent message server entry for any output to be saved in the message 
server.

@param aParentID 
ID of the parent message server entry. This is stored in iParentID. 
*/
inline void CContentHandlerBase::SetParent(TMsvId aParentID)
	{
	iParentID = aParentID;
	}


/** 
Provides clean-up for the plug-in.

A derived class calls this when handling of the message is complete: it deletes 
the plug-in, and if the asynchronous request iAcknowledge flag is set, sets 
the status with the passed error code.

@param aError 
Error code. 
*/
inline void CContentHandlerBase::Complete(TInt aError)
	{
	__LOG_PTR_DEBUG("CContentHandlerPluginBase:: Complete Called");
	if (iAcknowledge)
		SignalConfirmationStatus(aError);
	iPluginKiller->KillPushPlugin();
	}	


/** 
Utility that completes this active object with KErrNone. 
*/
inline void CContentHandlerBase::IdleComplete()
	{
	TRequestStatus* pS = &iStatus;
	User::RequestComplete(pS,KErrNone);
	SetActive();
	}