connectivity/com.nokia.tcf/native/TCFNative/TCFServer/Client.cpp
author chpeckha
Mon, 06 Apr 2009 15:18:48 -0500
changeset 60 9d2210c8eed2
permissions -rw-r--r--
Commit changes for 2.1.0

/*
* Copyright (c) 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: 
*
*/
// Client.cpp: implementation of the CClient class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Client.h"
#include "ServerManager.h"

extern CServerManager* gManager;
#ifdef _DEBUG
extern BOOL gDoLogging;
#endif

//#define LOG_CLIENT
#if defined(LOG_CLIENT) && defined(_DEBUG)
extern char TCDebugMsg[];
#define TCDEBUGOPEN() if (gDoLogging) { gManager->m_DebugLog->WaitForAccess(); }
#define TCDEBUGLOGS(s) if (gDoLogging) { sprintf(TCDebugMsg,"%s", s); gManager->m_DebugLog->log(TCDebugMsg); }
#define TCDEBUGLOGA1(s, a1) if (gDoLogging) { sprintf(TCDebugMsg, s, a1); gManager->m_DebugLog->log(TCDebugMsg); }
#define TCDEBUGLOGA2(s, a1, a2) if (gDoLogging) { sprintf(TCDebugMsg, s, a1, a2); gManager->m_DebugLog->log(TCDebugMsg); }
#define TCDEBUGLOGA3(s, a1, a2, a3) if (gDoLogging) { sprintf(TCDebugMsg, s, a1, a2, a3); gManager->m_DebugLog->log(TCDebugMsg); }
#define TCDEBUGCLOSE() if (gDoLogging) { gManager->m_DebugLog->ReleaseAccess(); }
#else
#define TCDEBUGOPEN()
#define TCDEBUGLOGS(s)
#define TCDEBUGLOGA1(s, a1)
#define TCDEBUGLOGA2(s, a1, a2)
#define TCDEBUGLOGA3(s, a1, a2, a3)
#define TCDEBUGCLOSE()
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CClient::CClient()
{
	TCDEBUGOPEN();
	TCDEBUGLOGS("CClient::CClient\n");
	
	m_InputStream = NULL;
	m_MessageFile = NULL;
	m_ErrorMonitor = NULL;
	m_Connection = NULL;
	m_Status = eStopped;
	m_ClientId = -1;
	m_Options.ostVersion = 1;
	m_Options.unWrapFormat = DEFAULT_UNWRAP_OPTION;
	m_MessageDestination = eDestinationInputStream;	// default - changed later

	TCDEBUGCLOSE();
}

CClient::CClient(CConnection* connection, ClientOptions& options, DWORD clientId)
{
	TCDEBUGOPEN();
	TCDEBUGLOGS("CClient::CClient\n");
	
	m_Connection = connection;
	m_Options.ostVersion = options.ostVersion;
	m_Options.unWrapFormat = options.unWrapFormat;
	m_ClientId = clientId;
	m_Status = eStopped;

	m_ErrorMonitor = new CErrorMonitor(m_ClientId);
	m_ErrorMonitor->CreateData();
	m_InputStream = NULL; // created on open instead
	m_MessageFile = NULL;
	m_MessageDestination = eDestinationInputStream;	// default - changed later


	TCDEBUGCLOSE();
}
CClient::~CClient()
{
	TCDEBUGOPEN();
	TCDEBUGLOGS("CClient::~CClient\n");
	
	if (m_ErrorMonitor)
		delete m_ErrorMonitor;

	if (m_InputStream)
		delete m_InputStream;

	if (m_MessageFile)
		delete m_MessageFile;

	TCDEBUGCLOSE();
}
BOOL CClient::OpenStream(DestinationOptions* streamOptions)
{
	TCDEBUGOPEN();
	TCDEBUGLOGS("CClient::OpenStream\n");
	
	BOOL done = TRUE;

	if (m_InputStream == NULL)
	{
		m_InputStream = new CInputStream(streamOptions->destinationFile, streamOptions->streamSize, streamOptions->overFlowToFile, m_ClientId);
		m_InputStream->CreateStream();
	}

	TCDEBUGCLOSE();
	return done;
}

BOOL CClient::CloseStream()
{
	TCDEBUGOPEN();
	TCDEBUGLOGS("CClient::CloseStream\n");
	
	BOOL done = TRUE;

	if (m_InputStream)
	{
		delete m_InputStream;
		m_InputStream = NULL;
	}

	TCDEBUGCLOSE();
	return done;
}
BOOL CClient::OpenMessageFile(DestinationOptions *messageFileOptions)
{
	BOOL done = TRUE;
	if (m_MessageFile == NULL)
	{
		m_MessageFile = new CMessageFile(messageFileOptions->destinationFile, m_ClientId);
		m_MessageFile->Open();
	}

	return done;
}
BOOL CClient::CloseMessageFile()
{
	BOOL done = TRUE;

	if (m_MessageFile)
	{
		delete m_MessageFile;
		m_MessageFile = NULL;
	}

	return done;
}
BOOL CClient::ClearMessageFile()
{
	BOOL done = TRUE;

	if (m_MessageFile)
	{
		m_MessageFile->ClearFile();
	}

	return done;
}