diff -r 000000000000 -r 29b1cd4cb562 bthci/hci2implementations/CommandsEvents/symbian/src/acceptconnectionrequestcommand.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bthci/hci2implementations/CommandsEvents/symbian/src/acceptconnectionrequestcommand.cpp Fri Jan 15 08:13:17 2010 +0200 @@ -0,0 +1,141 @@ +// 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 "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 commandsource.tmpl +// on Thu, 29 May 2008 15:17:49 (time stamp) +// +// + +/** + @file + @internalComponent +*/ + +#include +#include +#include +#include +#include +#include + + +#ifdef __FLOG_ACTIVE +_LIT8(KLogComponent, LOG_COMPONENT_COMMANDSEVENTS_SYMBIAN); +#endif + + + +// Factory methods + +EXPORT_C CAcceptConnectionRequestCommand* CAcceptConnectionRequestCommand::NewL(const TBTDevAddr& aBDADDR, TUint8 aRole) + { + CAcceptConnectionRequestCommand* self = new (ELeave) CAcceptConnectionRequestCommand(aBDADDR, aRole); + CleanupStack::PushL(self); + self->CHCICommandBase::BaseConstructL(); + CleanupStack::Pop(self); + return self; + } + +EXPORT_C CAcceptConnectionRequestCommand* CAcceptConnectionRequestCommand::NewL() + { + CAcceptConnectionRequestCommand* self = new (ELeave) CAcceptConnectionRequestCommand(); + CleanupStack::PushL(self); + self->CHCICommandBase::BaseConstructL(); + CleanupStack::Pop(self); + return self; + } + +// Constructors + +CAcceptConnectionRequestCommand::CAcceptConnectionRequestCommand(const TBTDevAddr& aBDADDR, TUint8 aRole) + : CHCICommandBase(KAcceptConnectionRequestOpcode) + , iBDADDR(aBDADDR) + , iRole(aRole) + { + SetExpectsCommandCompleteEvent(EFalse); + } + +CAcceptConnectionRequestCommand::CAcceptConnectionRequestCommand() + : CHCICommandBase(KAcceptConnectionRequestOpcode) + { + SetExpectsCommandCompleteEvent(EFalse); + } + +// Destructor +CAcceptConnectionRequestCommand::~CAcceptConnectionRequestCommand() + { + + } + +/*virtual*/ void CAcceptConnectionRequestCommand::Match(const THCIEventBase& aEvent, TBool& aMatchesCmd, TBool& aConcludesCmd, TBool& aContinueMatching) const + { + if (aEvent.EventCode() == EConnectionCompleteEvent) + { + TConnectionCompleteEvent& event = TConnectionCompleteEvent::Cast(aEvent); + if (event.BDADDR() == BDADDR()) + { + aMatchesCmd = ETrue; + aConcludesCmd = ETrue; + aContinueMatching = EFalse; + } + } + // Command Status Event and default Command Complete Event matching + // is implemented in the base class. If we haven't matched already + // then we should try the default matching. + if (!aMatchesCmd) + { + CHCICommandBase::Match(aEvent, aMatchesCmd, aConcludesCmd, aContinueMatching); + } + } + + +// Override of pure virtual from CHCICommandBase. This method embodies the knowledge +// of how to format the specifics of this command into the HCTL command frame. +void CAcceptConnectionRequestCommand::Format(CHctlCommandFrame& aCommandFrame) const + { + aCommandFrame.PutDevAddr(iBDADDR); + aCommandFrame.PutByte(iRole); + } + +// Assign new values to the parameters of this command +EXPORT_C void CAcceptConnectionRequestCommand::Reset(const TBTDevAddr& aBDADDR, TUint8 aRole) + { + iBDADDR = aBDADDR; + iRole = aRole; + } + +// Accessor methods for the parameters of the command + +EXPORT_C TBTDevAddr CAcceptConnectionRequestCommand::BDADDR() const + { + return iBDADDR; + } + +EXPORT_C TUint8 CAcceptConnectionRequestCommand::Role() const + { + return iRole; + } + + + +// Extension function. Use this to retrieve any extension interfaces from CAcceptConnectionRequestCommand +// or any class from which it derives. +/*virtual*/ TInt CAcceptConnectionRequestCommand::Extension_(TUint aExtensionId, TAny*& aInterface, TAny* aData) + { + // To add an additional interface implementation specific for this class check the + // provided ID and return an appropriate interface. + + // If a specific interface implementation is not provided - forward the call to the base class. + return CHCICommandBase::Extension_(aExtensionId, aInterface, aData); + } +