bthci/bthci2/CommandsEvents/generator/completeeventsource.tmpl
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:12:20 +0200
changeset 4 28479eeba3fb
parent 0 29b1cd4cb562
child 13 16aa830c86c8
permissions -rw-r--r--
Revision: 201003

// Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "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:
// This file was generated automatically from the template completeeventsource.tmpl
// on $GENERATE_TIME_STAMP
// 
//

/**
 @file
 @internalComponent
*/

#include <bluetooth/hci/$FILENAME.h>
#include <bluetooth/hci/hciframe.h>
#include <bluetooth/hci/hciopcodes.h>
#include "symbiancommandseventsutils.h"

#ifdef __FLOG_ACTIVE
_LIT8(KLogComponent, LOG_COMPONENT_COMMANDSEVENTS_SYMBIAN);
#endif

// Construct an event object to wrap existing event data received from the Controller
EXPORT_C $CLASSNAME::$CLASSNAME(const TDesC8& aEventData)
	: THCICommandCompleteEvent(aEventData)
	{
	$EVENTSETERRORCODEBYEXTRACT
	}

// Construct an event object to generate a faked event using the supplied parameters
EXPORT_C $CLASSNAME::$CLASSNAME($FAKERPARAMETERS)
	: THCICommandCompleteEvent($FAKER_PARAMETER_TOTAL_LENGTH, aNumHCICommandPackets, $OPCODE, aEventData)
	{
	$FAKERSETERRORCODEBYPARAM
	$FAKERWRITE_IMPLEMENTATION
	iEventData.Set(aEventData);
	}

// The static Cast method is used to obtain a pointer to the derived class object
EXPORT_C $CLASSNAME& $CLASSNAME::Cast(const THCIEventBase& aEvent)
	{
	__ASSERT_DEBUG(aEvent.EventCode() == ECommandCompleteEvent, PANIC(KSymbianCommandsEventsPanicCat, EWrongEventCode));
	__ASSERT_DEBUG(THCICommandCompleteEvent::Cast(aEvent).CommandOpcode() == $OPCODE, PANIC(KSymbianCommandsEventsPanicCat, EWrongEventCode));
	return *(reinterpret_cast<$CLASSNAME*>(&const_cast<THCIEventBase&>(aEvent)));
	}

// Accessor methods for the parameters of the event

$ACCESSOR_IMPLEMENTATION