bluetoothapitest/bluetoothsvs/T_BTSockAddrAPI/inc/T_RfcommSockAddrData.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 19 Aug 2010 11:01:00 +0300
branchRCL_3
changeset 22 786b94c6f0a4
parent 0 29b1cd4cb562
permissions -rw-r--r--
Revision: 201031 Kit: 201033

/*
* Copyright (c) 2005-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:
*
*/


#if (!defined __T_BT_SOCK_ADDR_API_TRFCOMMSOCKADDR_DATA_H__)
#define __T_BT_SOCK_ADDR_API_TRFCOMMSOCKADDR_DATA_H__

//	User Includes
#include "DataWrapperBase.h"
// Classes to get to protected members
#include "T_TRfcommSockAddrChild.h"

//	EPOC includes
#include <w32std.h>
#include <e32std.h>
#include <es_sock.h> // TSockAddr address 
#include <bt_sock.h> // Bluetooth address classes


class CT_TRfcommSockAddrData: public CDataWrapperBase
	{
public:
	/**
	* Two phase constructor
	*/
	static CT_TRfcommSockAddrData*	NewL();
	
	/**
	* Process a command read from the ini file
	*
	* @param aCommand			The command to process
	* @param aSection			The section in the ini containing data for the command
	* @param aAsyncErrorIndex	Command index for async calls to return errors to
	*
	* @return					ETrue if the command is processed
	*
	* @leave					System wide error
	*/
	virtual TBool	DoCommandL(const TTEFFunction& aCommand, const TTEFSectionName& aSection, const TInt aAsyncErrorIndex);
	
	/**
	* Destructor
	*/
	~CT_TRfcommSockAddrData();

	/**
	* Set the object that the data wraps
	*
	* @param	aObject object that the wrapper is testing
	*
	* @leave	KErrNotSupported if the the function is not supported
	*/
	virtual void	SetObjectL(TAny* aObject);

	/**
	* The object will no longer be owned by this
	*
	* @leave	KErrNotSupported if the the function is not supported
	*/
	virtual void	DisownObjectL();
	
	inline virtual TCleanupOperation CleanupOperation();

protected:
	/**
	* Protected constructor. First phase construction
	*/
	CT_TRfcommSockAddrData();
	
		/**
	* Return a pointer to the object that the data wraps
	*
	* \return pointer to the object that the data wraps
	*/
	virtual TAny*	GetObject();
private:	
	// Implementation of DoCommandL for each of the commands
	inline void TRfcommSockAddrConstruct(const TDesC& aSection);
	inline void TRfcommSockAddrCastFromTSockAddr(const TDesC& aSection);
	inline void TRfcommSockAddrSetBTAddr(const TDesC& aSection);
	inline void TRfcommSockAddrBTAddr(const TDesC& aSection);
	inline void TRfcommSockAddrSetSecurity(const TDesC& aSection);
	inline void TRfcommSockAddrBTSecurity(const TDesC& aSection);
	inline void TRfcommSockAddrSetFamily(const TDesC& aSection);
	inline void TRfcommSockAddrFamily(const TDesC& aSection);
	inline void TRfcommSockAddrSetPort(const TDesC& aSection);
	inline void TRfcommSockAddrPort(const TDesC& aSection);
	inline void TRfcommSockAddrCmpPort(const TDesC& aSection);
	inline void	TRfcommSockAddrPROTECTEDSetUserLen(const TDesC& aSection);
	inline void TRfcommSockAddrGetUserLen(const TDesC& aSection);
	inline void TRfcommSockAddrPROTECTEDUserPtr();
	inline void TRfcommSockAddrPROTECTEDEndBTSockAddrPtr();

	/**
	* Delete iTBTSockAddr if owned and set to 0
	*/
	void Cleanup();	
	
	static void CleanupOperation(TAny* aAny);

private:
	// An object of iT_TRfcommSockAddrChild class in order to retain state between calls
	// T_TRfcommSockAddrChild is a wrapper around the TRfcommSockAddr to reach protected methods

    T_TRfcommSockAddrChild* iTRfcommSockAddr;
    // Identifies if the iTRfcommSockAddr is owned, needed due to cast
    TBool iTRfcommSockAddrOwned;
    
	};
#endif /* __T_BT_SOCK_ADDR_API_TRFCOMMSOCKADDR_DATA_H__ */