connectivity/com.nokia.tcf/native/TCFNative/TCFClient/ClientManager.cpp
author Chad Peckham <chad.peckham@nokia.com>
Mon, 13 Sep 2010 13:17:04 -0500
changeset 1991 1c752f14a126
parent 1481 c7f22cc57d44
permissions -rw-r--r--
add Ed's changes to allow multiple Carbide instances to use same TCFServer
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     1
/*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     3
* All rights reserved.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     4
* This component and the accompanying materials are made available
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     6
* which accompanies this distribution, and is available
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     8
*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
     9
* Initial Contributors:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    11
*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    12
* Contributors:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    13
*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    14
* Description: 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    15
*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    16
*/
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    17
// ClientManager.cpp: implementation of the CClientManager class.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    18
//
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    19
//////////////////////////////////////////////////////////////////////
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    20
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    21
#include "stdafx.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    22
#include "ClientManager.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    23
#include "TCErrorConstants.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    24
#include "resource.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    25
#include <stdio.h>
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
    26
#ifdef _PSAPI_PRESENT
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
    27
	#include "psapi.h"
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
    28
#endif
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    29
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    30
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    31
extern BOOL gDoLogging;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    32
extern char TCDebugMsg[100];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    33
#define TCDEBUGOPEN() if (gDoLogging) m_DebugLog->WaitForAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    34
#define TCDEBUGLOGS(s) if (gDoLogging) sprintf(TCDebugMsg,"%s", s); if (gDoLogging) m_DebugLog->log(TCDebugMsg);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    35
#define TCDEBUGLOGA1(s, a1) if (gDoLogging) sprintf(TCDebugMsg, s, a1); if (gDoLogging) m_DebugLog->log(TCDebugMsg);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    36
#define TCDEBUGLOGA2(s, a1, a2) if (gDoLogging) sprintf(TCDebugMsg, s, a1, a2); if (gDoLogging) m_DebugLog->log(TCDebugMsg);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    37
#define TCDEBUGLOGA3(s, a1, a2, a3) if (gDoLogging) sprintf(TCDebugMsg, s, a1, a2, a3); if (gDoLogging) m_DebugLog->log(TCDebugMsg);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    38
#define TCDEBUGCLOSE() if (gDoLogging) m_DebugLog->ReleaseAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    39
#else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    40
#define TCDEBUGOPEN()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    41
#define TCDEBUGLOGS(s)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    42
#define TCDEBUGLOGA1(s, a1)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    43
#define TCDEBUGLOGA2(s, a1, a2)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    44
#define TCDEBUGLOGA3(s, a1, a2, a3)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    45
#define TCDEBUGCLOSE()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    46
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    47
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    48
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    49
static char* GetErrorText(DWORD inError);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    50
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    51
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    52
//////////////////////////////////////////////////////////////////////
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    53
// Construction/Destruction
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    54
//////////////////////////////////////////////////////////////////////
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    55
CClientManager::CClientManager()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    56
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    57
	m_Server = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    58
	m_StreamList = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    59
	m_ErrorMonitorList = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    60
	m_DebugLog = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    61
	m_DllLocation = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    62
	m_hServer = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    63
	m_hServerThread = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    64
	m_Version[0] = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    65
	m_ServerLockFile = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    66
	m_ServerExeFile = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    67
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    68
CClientManager::CClientManager(HINSTANCE hinstDLL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    69
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    70
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    71
	if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    72
		m_DebugLog = new TCDebugLog("TCF_ClientLog", ::GetCurrentProcessId());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    73
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    74
		m_DebugLog = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    75
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    76
#else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    77
	m_DebugLog = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    78
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    79
	TCDEBUGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    80
	TCDEBUGLOGS("CClientManager::CClientManager\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    81
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    82
	m_Server = new CServerCommand();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    83
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    84
	// lock server access (it might be running)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    85
	m_Server->WaitforServerPipeAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    86
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    87
	m_StreamList = new InputStreamList();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    88
	m_StreamList->clear();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    89
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    90
	m_ErrorMonitorList = new ErrorMonitorList();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    91
	m_ErrorMonitorList->clear();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    92
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    93
	m_DllLocation = new char[MAX_DLLPATHNAME];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    94
	::GetModuleFileName(hinstDLL, m_DllLocation, MAX_DLLPATHNAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    95
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    96
	char exeDirectory[MAX_DLLPATHNAME] = {0};
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    97
	strncpy(exeDirectory, m_DllLocation, MAX_DLLPATHNAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    98
	size_t len = strlen(exeDirectory);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    99
	// remove file
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   100
	for (int i = len-1; i > 0; i--)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   101
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   102
		if (exeDirectory[i] == PATH_DELIMITER)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   103
			break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   104
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   105
	exeDirectory[i] = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   106
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   107
	m_ServerExeFile = new char[MAX_DLLPATHNAME];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   108
	sprintf(m_ServerExeFile, "\"%s%c%s\"", exeDirectory, PATH_DELIMITER, SERVER_PROCESS_NAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   109
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   110
	m_ServerLockFile = new char[MAX_DLLPATHNAME];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   111
	sprintf(m_ServerLockFile, "%s%c%s", exeDirectory, PATH_DELIMITER, SERVER_LOCKFILE_NAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   112
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   113
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   114
#ifdef _PSAPI_PRESENT
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   115
	FindOrCreateRunningServer();
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   116
#endif
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   117
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   118
	char name[100];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   119
	sprintf(name, "%s%ld", ERRORMONITORLIST_MUTEX_BASENAME, ::GetCurrentProcessId());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   120
	m_ErrorMonitorListMutex.Open(name, ERRORMONITORLIST_MUTEX_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   121
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   122
	sprintf(name, "%s%ld", INPUTSTREAMLIST_MUTEX_BASENAME, ::GetCurrentProcessId());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   123
	m_StreamListMutex.Open(name, INPUTSTREAMLIST_MUTEX_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   124
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   125
	m_hServer = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   126
	m_hServerThread = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   127
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   128
	// release server access
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   129
	m_Server->ReleaseServerPipeAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   130
	int ret = ::LoadString(hinstDLL, IDS_VERSION, m_Version, MAX_VERSION_STRING);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   131
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   132
	TCDEBUGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   133
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   134
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   135
CClientManager::~CClientManager()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   136
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   137
	TCDEBUGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   138
	TCDEBUGLOGS("CClientManager::~CClientManager\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   139
	pServerProcessData pData = m_Server->GetProcessPtr();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   140
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   141
	if (m_Server)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   142
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   143
		delete m_Server;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   144
		m_Server = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   145
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   146
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   147
	WaitForStreamListAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   148
	TCDEBUGLOGA1("CClientManager::~CClientManager: erasing stream list size=%d\n", InputStreamListSize());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   149
	if (m_StreamList)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   150
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   151
		InputStreamList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   152
		for (iter = m_StreamList->begin(); iter != m_StreamList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   153
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   154
			TCDEBUGLOGS("CClientManager::~CClientManager: erasing stream list next 1\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   155
//			m_StreamList->erase(iter);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   156
			delete *iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   157
//			TCDEBUGLOGS("CClientManager::~CClientManager: erasing stream list next 2\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   158
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   159
		m_StreamList->clear();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   160
		TCDEBUGLOGS("CClientManager::~CClientManager: erasing stream list done 1\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   161
		delete m_StreamList;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   162
		TCDEBUGLOGS("CClientManager::~CClientManager: erasing stream list done 2\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   163
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   164
	ReleaseStreamListAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   165
	m_StreamListMutex.Close();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   166
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   167
	WaitForErrorMonitorListAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   168
	TCDEBUGLOGA1("CClientManager::~CClientManager: erasing monitor list size=%d\n", ErrorMonitorListSize());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   169
	if (m_ErrorMonitorList)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   170
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   171
		ErrorMonitorList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   172
		for (iter = m_ErrorMonitorList->begin(); iter != m_ErrorMonitorList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   173
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   174
			TCDEBUGLOGS("CClientManager::~CClientManager: erasing monitor list next 1\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   175
//			m_ErrorMonitorList->erase(iter);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   176
			delete *iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   177
//			TCDEBUGLOGS("CClientManager::~CClientManager: erasing monitor list next 1\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   178
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   179
		m_ErrorMonitorList->clear();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   180
		TCDEBUGLOGS("CClientManager::~CClientManager: erasing monitor list done 1\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   181
		delete m_ErrorMonitorList;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   182
		TCDEBUGLOGS("CClientManager::~CClientManager: erasing monitor list done 2\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   183
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   184
	ReleaseErrorMonitorListAccess();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   185
	m_ErrorMonitorListMutex.Close();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   186
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   187
	if (m_DllLocation)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   188
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   189
		delete[] m_DllLocation;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   190
		m_DllLocation = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   191
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   192
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   193
	if (m_ServerLockFile)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   194
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   195
		delete[] m_ServerLockFile;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   196
		m_ServerLockFile = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   197
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   198
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   199
	if (m_ServerExeFile)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   200
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   201
		delete[] m_ServerExeFile;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   202
		m_ServerExeFile = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   203
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   204
	TCDEBUGLOGS("CClientManager::~CClientManager: closing log\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   205
	TCDEBUGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   206
	if (m_DebugLog)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   207
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   208
		delete m_DebugLog;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   209
		m_DebugLog = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   210
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   211
}
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   212
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   213
#ifdef _PSAPI_PRESENT
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   214
void
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   215
CClientManager::FindOrCreateRunningServer()
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   216
{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   217
	TCDEBUGOPEN();
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   218
	TCDEBUGLOGS("CClientManager::FindOrCreateRunningServer: searching for existing TCFServer.exe\n");
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   219
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   220
	// Directory where TCFServer.exe lives
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   221
	char exeDirectory[MAX_DLLPATHNAME] = {0};
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   222
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   223
	BOOL foundRunningServer = FALSE;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   224
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   225
	// Get the list of process identifiers.
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   226
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   227
	DWORD aProcesses[1024], cbNeeded, cProcesses;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   228
	unsigned int i;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   229
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   230
	if ( EnumProcesses( aProcesses, sizeof(aProcesses), &cbNeeded ) )
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   231
	{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   232
		// Calculate how many process identifiers were returned.
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   233
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   234
		cProcesses = cbNeeded / sizeof(DWORD);
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   235
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   236
		// Find existing TCFServer
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   237
		for ( i = 0; i < cProcesses; i++ )
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   238
		{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   239
			if( aProcesses[i] != 0 )
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   240
			{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   241
				TCHAR szProcessName[MAX_PATH] = TEXT("<unknown>");
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   242
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   243
				// Get a handle to the process.
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   244
				HANDLE hProcess = OpenProcess( PROCESS_QUERY_INFORMATION |
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   245
											   PROCESS_VM_READ,
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   246
											   FALSE, aProcesses[i] );
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   247
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   248
				// Get the process name.
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   249
				if (NULL != hProcess )
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   250
				{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   251
					HMODULE hMod;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   252
					DWORD cbNeeded;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   253
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   254
					if ( EnumProcessModules( hProcess, &hMod, sizeof(hMod),
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   255
						 &cbNeeded) )
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   256
					{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   257
						if (GetModuleBaseNameA( hProcess, hMod, szProcessName,
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   258
										   sizeof(szProcessName)/sizeof(char) ))
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   259
						{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   260
							if (strcmp(SERVER_PROCESS_NAME, szProcessName) == 0)
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   261
							{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   262
								// get the full path
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   263
								GetModuleFileNameExA(hProcess, hMod, exeDirectory,
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   264
											sizeof(exeDirectory)/sizeof(char) );
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   265
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   266
								TCDEBUGLOGA1("Found TCFServer at %s\n", exeDirectory);
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   267
								CloseHandle( hProcess );
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   268
								foundRunningServer = TRUE;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   269
								break;
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   270
							}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   271
						}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   272
					}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   273
				}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   274
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   275
				CloseHandle( hProcess );
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   276
			}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   277
		}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   278
	}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   279
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   280
	if (!foundRunningServer)
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   281
	{
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   282
		// start the one next to the DLL
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   283
		strncpy(exeDirectory, m_DllLocation, strlen(m_DllLocation) + 1);
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   284
	}
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   285
	size_t len = strlen(exeDirectory);
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   286
	// remove file
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   287
	int j;
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   288
	for (j = len-1; j > 0; j--)
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   289
	{
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   290
		if (exeDirectory[j] == PATH_DELIMITER)
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   291
			break;
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   292
	}
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   293
	exeDirectory[j] = NULL;
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   294
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   295
	m_ServerExeFile = new char[MAX_DLLPATHNAME];
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   296
	sprintf(m_ServerExeFile, "\"%s%c%s\"", exeDirectory, PATH_DELIMITER, SERVER_PROCESS_NAME);
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   297
	TCDEBUGLOGA1("exeFile at %s\n", m_ServerExeFile);
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   298
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   299
	m_ServerLockFile = new char[MAX_DLLPATHNAME];
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   300
	sprintf(m_ServerLockFile, "%s%c%s", exeDirectory, PATH_DELIMITER, SERVER_LOCKFILE_NAME);
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   301
	TCDEBUGLOGA1("lockFile at %s\n", m_ServerLockFile);
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   302
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   303
1481
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   304
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   305
	TCDEBUGCLOSE();
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   306
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   307
}
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   308
#endif
c7f22cc57d44 Commit some changes from Ed, also for USB, return different error for h/w comm error as opposed to where there is no error reported by windows, but the bytes did not get sent to the device (not responding)
Chad Peckham <chad.peckham@nokia.com>
parents: 914
diff changeset
   309
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   310
CErrorMonitor*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   311
CClientManager::FindErrorMonitor(long inClientId)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   312
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   313
	CErrorMonitor* errorMonitor = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   314
	ErrorMonitorList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   315
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   316
	for (iter = m_ErrorMonitorList->begin(); iter != m_ErrorMonitorList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   317
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   318
		if ((*iter)->IsThisClient(inClientId))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   319
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   320
			errorMonitor = *iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   321
			break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   322
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   323
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   324
	return errorMonitor;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   325
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   326
long CClientManager::ErrorMonitorListSize()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   327
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   328
	long size = m_ErrorMonitorList->size();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   329
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   330
	return size;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   331
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   332
void CClientManager::AddErrorMonitor(CErrorMonitor* monitor)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   333
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   334
	m_ErrorMonitorList->push_back(monitor);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   335
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   336
void CClientManager::RemoveErrorMonitor(CErrorMonitor* monitor)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   337
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   338
	ErrorMonitorList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   339
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   340
	for (iter = m_ErrorMonitorList->begin(); iter != m_ErrorMonitorList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   341
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   342
		if ((*iter)->IsThisClient(monitor->GetClientId()))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   343
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   344
			m_ErrorMonitorList->erase(iter);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   345
			break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   346
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   347
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   348
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   349
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   350
CInputStream*
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   351
CClientManager::FindInputStream(long inClientId)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   352
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   353
	CInputStream* inputStream = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   354
	InputStreamList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   355
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   356
	for (iter = m_StreamList->begin(); iter != m_StreamList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   357
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   358
		if ((*iter)->IsThisClient(inClientId))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   359
//		if ((*iter).IsThisClient(inClientId))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   360
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   361
			inputStream = *iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   362
//			inputStream = iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   363
			break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   364
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   365
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   366
	return inputStream;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   367
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   368
long CClientManager::InputStreamListSize()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   369
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   370
	long size = m_StreamList->size();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   371
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   372
	return size;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   373
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   374
void CClientManager::AddInputStream(CInputStream* stream)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   375
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   376
	m_StreamList->push_back(stream);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   377
//	m_StreamList->push_back(*stream);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   378
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   379
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   380
void CClientManager::RemoveInputStream(CInputStream* stream)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   381
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   382
	InputStreamList::iterator iter;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   383
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   384
	for (iter = m_StreamList->begin(); iter != m_StreamList->end(); iter++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   385
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   386
		if ((*iter)->IsThisClient(stream->GetClientId()))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   387
//		if ((*iter).IsThisClient(stream->GetClientId()))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   388
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   389
			m_StreamList->erase(iter);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   390
			break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   391
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   392
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   393
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   394
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   395
BOOL CClientManager::StartServer(pServerProcessData pData)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   396
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   397
	TCDEBUGLOGA1("CClientManager::StartServer numRefs = %d\n",pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   398
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   399
	BOOL serverStarted = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   400
	// server is ref counted
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   401
	// refcount = 0 => server is not running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   402
	// refcount > 0 => server already started by some other process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   403
	if (pData->numRefs == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   404
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   405
		// server not running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   406
		// get exe location
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   407
		char exeLocation[MAX_DLLPATHNAME] = {0};
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   408
		strncpy(exeLocation, m_DllLocation, MAX_DLLPATHNAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   409
		size_t len = strlen(exeLocation);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   410
		// remove file
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   411
		for (int i = len-1; i > 0; i--)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   412
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   413
			if (exeLocation[i] == PATH_DELIMITER)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   414
				break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   415
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   416
		exeLocation[i] = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   417
		char quotedLocation[MAX_DLLPATHNAME] = {0};
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   418
		sprintf(quotedLocation, "\"%s%c%s\"", exeLocation, PATH_DELIMITER, SERVER_PROCESS_NAME);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   419
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   420
		TCDEBUGLOGA1("  exeLocation=%s\n", quotedLocation);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   421
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   422
		// create process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   423
		STARTUPINFO si;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   424
		memset(&si,0,sizeof(si));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   425
		si.cb = sizeof(si);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   426
		memset(&pData->serverProcess, 0, sizeof(pData->serverProcess));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   427
		pData->serverProcess.hProcess = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   428
		if (!::CreateProcess(
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   429
			NULL,			// module location
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   430
			quotedLocation,	// command line
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   431
			NULL,			// process attributes
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   432
			NULL,			// thread attributes
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   433
			FALSE,			// inherit our handles
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   434
			CREATE_NO_WINDOW,	// no window
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   435
			NULL,			// use our environment
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   436
			NULL,			// user our current directory
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   437
			&si,			// startup info
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   438
			&pData->serverProcess)) // process info
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   439
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   440
			// TODO: error creating process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   441
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   442
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   443
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   444
			// we are the creator so save handles for later
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   445
			m_hServer = pData->serverProcess.hProcess;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   446
			m_hServerThread = pData->serverProcess.hThread;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   447
			// add a refcount
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   448
			pData->numRefs++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   449
			serverStarted = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   450
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   451
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   452
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   453
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   454
		// already running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   455
		// add a refcount and open our process handle to it
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   456
		pData->numRefs++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   457
		m_hServer = ::OpenProcess(0, FALSE, pData->serverProcess.dwProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   458
		serverStarted = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   459
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   460
	TCDEBUGLOGA1("CClientManager::StartServer serverStarted=%d\n", serverStarted);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   461
	return serverStarted;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   462
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   463
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   464
BOOL CClientManager::StopServer(pServerProcessData pData)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   465
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   466
	TCDEBUGLOGS("CClientManager::StopServer\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   467
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   468
	BOOL serverStopped = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   469
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   470
	if (pData->serverProcess.hProcess == NULL || pData->numRefs <= 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   471
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   472
		serverStopped = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   473
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   474
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   475
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   476
		TCDEBUGLOGA1(" numRefs = %d\n",pData->numRefs); 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   477
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   478
		// substract ref count
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   479
		pData->numRefs--;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   480
		// if refcount == 0 then really stop the server process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   481
		if (pData->numRefs <= 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   482
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   483
			// last client process is closing
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   484
			// tell server to exit
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   485
			ServerCommandData cmdrsp;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   486
			cmdrsp.command = eCmdExit;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   487
		TCDEBUGLOGS(" SendCommand eCmdExit\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   488
			m_Server->SendCommand(&cmdrsp);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   489
		TCDEBUGLOGS(" GetResponse eExit\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   490
			m_Server->GetResponse(&cmdrsp);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   491
			// wait for process to exit
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   492
		TCDEBUGLOGS(" WaitForSingleObject start\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   493
			WaitForSingleObject(m_hServer, 10000L /*INFINITE*/);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   494
		TCDEBUGLOGS(" WaitForSingleObject found\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   495
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   496
			if (m_hServer != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   497
				CloseHandle(m_hServer);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   498
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   499
			if (m_hServerThread != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   500
				CloseHandle(m_hServerThread);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   501
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   502
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   503
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   504
			// just close our handle to server process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   505
			if (m_hServer != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   506
				CloseHandle(m_hServer);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   507
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   508
			if (m_hServerThread != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   509
				CloseHandle(m_hServerThread);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   510
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   511
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   512
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   513
	TCDEBUGLOGS("CClientManager::StopServer end\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   514
	return TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   515
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   516
long CClientManager::StartServer()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   517
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   518
	long ret = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   519
	pServerProcessData pData = m_Server->GetProcessPtr();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   520
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   521
	TCDEBUGLOGA3("CClientManager::StartServer this = %x m_hServer = %x numRefs = %d\n", this, m_hServer, pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   522
//	TCDEBUGLOGA1("  mgrRefs = %d\n", m_MgrServerRef);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   523
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   524
	BOOL serverStarted = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   525
	// server is ref counted
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   526
	// refcount = 0 => server is not running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   527
	// refcount > 0 => server already started by some other process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   528
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   529
	// terminate the TCFServer if it is already running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   530
	TerminateServerThroughLockFile(pData);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   531
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   532
	if (pData->numRefs == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   533
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   534
		// server not running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   535
		TCDEBUGLOGA1("  TCFServer exe =%s\n", m_ServerExeFile);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   536
		TCDEBUGLOGA1("  TCFServer lock=%s\n", m_ServerLockFile);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   537
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   538
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   539
		// create process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   540
		STARTUPINFO si;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   541
		memset(&si,0,sizeof(si));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   542
		si.cb = sizeof(si);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   543
		memset(&pData->serverProcess, 0, sizeof(pData->serverProcess));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   544
		pData->serverProcess.hProcess = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   545
		if (!::CreateProcess(
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   546
			NULL,			// module location
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   547
			m_ServerExeFile,	// command line
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   548
			NULL,			// process attributes
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   549
			NULL,			// thread attributes
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   550
			FALSE,			// inherit our handles
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   551
			CREATE_NO_WINDOW,	// no window
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   552
			NULL,			// use our environment
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   553
			NULL,			// user our current directory
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   554
			&si,			// startup info
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   555
			&pData->serverProcess)) // process info
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   556
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   557
			// TODO: error creating process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   558
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   559
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   560
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   561
			// we are the creator so save handles for later
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   562
			m_hServer = pData->serverProcess.hProcess;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   563
			m_hServerThread = pData->serverProcess.hThread;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   564
			// add a refcount
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   565
			pData->numRefs++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   566
			serverStarted = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   567
			TCDEBUGLOGA3("CClientManager::StartServer created m_hServer = %x processId = %d numRefs = %d\n", m_hServer, pData->serverProcess.dwProcessId, pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   568
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   569
			// create lock file and save process ID
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   570
			TCDEBUGLOGS("CClientManager::StartServer CreateLockFile\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   571
			CreateLockFile(pData->serverProcess.dwProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   572
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   573
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   574
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   575
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   576
		// already running
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   577
		// add a refcount and open our process handle to it only if we haven't opened it already
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   578
		pData->numRefs++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   579
		if (m_hServer == NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   580
			m_hServer = ::OpenProcess(SYNCHRONIZE|PROCESS_TERMINATE, FALSE, pData->serverProcess.dwProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   581
		if (m_hServer == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   582
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   583
			TCDEBUGLOGA1("CClientManager::StartServer opened m_hServer null error=%d\n", ::GetLastError());
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   584
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   585
		m_hServerThread = NULL;		// only creator gets real thread handle
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   586
		serverStarted = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   587
		TCDEBUGLOGA3("CClientManager::StartServer opened m_hServer = %x processId = %d numRefs = %d\n", m_hServer, pData->serverProcess.dwProcessId, pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   588
		// save our process id to lock file
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   589
		AppendToLockFile(pData->serverProcess.dwProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   590
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   591
	if (serverStarted)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   592
		m_ServerRunning = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   593
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   594
	TCDEBUGLOGA1("CClientManager::StartServer end numRefs = %d\n", pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   595
	return ret;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   596
}
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   597
BOOL CClientManager::IsTCFServerActive(DWORD processId)
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   598
{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   599
	HANDLE h = ::OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, processId);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   600
	if (h)
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   601
	{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   602
		// is it really still alive?
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   603
		DWORD exitCode = -5;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   604
		BOOL exitCall = ::GetExitCodeProcess(h, &exitCode);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   605
		::CloseHandle(h);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   606
		if (exitCall == TRUE && exitCode != STILL_ACTIVE)
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   607
		{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   608
			// TCFServer is really dead
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   609
			return FALSE;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   610
		}
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   611
		else
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   612
		{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   613
			// TCFServer is still active
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   614
			return TRUE;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   615
		}
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   616
	}
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   617
	else
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   618
	{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   619
		// TCFServer is really dead
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   620
		return FALSE;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   621
	}
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   622
}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   623
long CClientManager::StopServer()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   624
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   625
	long ret = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   626
	pServerProcessData pData = m_Server->GetProcessPtr();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   627
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   628
	TCDEBUGLOGA3("CClientManager::StopServer this = %x m_hServer = %x numRefs = %d\n", this, m_hServer, pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   629
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   630
	BOOL serverStopped = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   631
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   632
	if (pData->serverProcess.hProcess == NULL || pData->numRefs <= 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   633
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   634
		TCDEBUGLOGS("CClientManager::StopServer hProcess NULL or numRefs <= 0\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   635
		serverStopped = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   636
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   637
#if (0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   638
	else if (m_hServer == NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   639
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   640
		// we've already closed our handle to server
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   641
		// don't close it again
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   642
		TCDEBUGLOGS("CClientManager::StopServer m_hServer null\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   643
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   644
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   645
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   646
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   647
		// substract ref count
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   648
		pData->numRefs--;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   649
		if (pData->numRefs < 0) pData->numRefs = 0;
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   650
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   651
		bool sendStop = true;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   652
		if (!IsTCFServerActive(pData->serverProcess.dwProcessId))
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   653
		{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   654
			sendStop = false;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   655
			pData->numRefs = 0;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   656
		}
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   657
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   658
		// if refcount == 0 then really stop the server process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   659
		if (pData->numRefs == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   660
		{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   661
			if (sendStop)
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   662
			{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   663
				// last client process is closing
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   664
				// tell server to exit
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   665
				ServerCommandData cmdrsp;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   666
				cmdrsp.command = eCmdExit;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   667
				
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   668
				TCDEBUGLOGS(" SendCommand eCmdExit\n");
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   669
				m_Server->SendCommand(&cmdrsp);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   670
				TCDEBUGLOGS(" GetResponse eExit\n");
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   671
				m_Server->GetResponse(&cmdrsp);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   672
				
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   673
				// wait for process to exit
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   674
				TCDEBUGLOGS(" WaitForSingleObject start\n");
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   675
				DWORD waitErr = ::WaitForSingleObject(m_hServer, 10000L /*INFINITE*/);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   676
				TCDEBUGLOGA1("CClientManager::StopServer WaitForSingleObject = %d\n", waitErr);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   677
			}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   678
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   679
			// now close our handle to server process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   680
			if (m_hServer != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   681
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   682
				CloseHandle(m_hServer);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   683
				m_hServer = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   684
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   685
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   686
			if (m_hServerThread != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   687
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   688
				CloseHandle(m_hServerThread);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   689
				m_hServerThread = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   690
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   691
			serverStopped = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   692
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   693
			// delete lock file
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   694
			TCDEBUGLOGS("CClientManager::StopServer DeleteLockFile\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   695
			DeleteLockFile();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   696
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   697
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   698
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   699
			// just close our handle to server process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   700
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   701
			if (m_hServer != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   702
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   703
				CloseHandle(m_hServer);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   704
				m_hServer = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   705
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   706
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   707
			if (m_hServerThread != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   708
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   709
				CloseHandle(m_hServerThread);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   710
				m_hServerThread = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   711
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   712
			DeleteFromLockFile(pData->serverProcess.dwProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   713
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   714
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   715
	if (serverStopped)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   716
		m_ServerRunning = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   717
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   718
	TCDEBUGLOGA1("CClientManager::StopServer end numRefs = %d\n", pData->numRefs);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   719
	return ret;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   720
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   721
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   722
BOOL CClientManager::IsServerRunning()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   723
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   724
	pServerProcessData pData = m_Server->GetProcessPtr();
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   725
	if (IsTCFServerActive(pData->serverProcess.dwProcessId))
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   726
	{
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   727
		return TRUE;
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   728
	}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   729
	else
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   730
	{
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   731
		return FALSE;
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   732
	}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   733
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   734
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   735
void CClientManager::CreateLockFile(DWORD processId)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   736
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   737
	if (m_ServerLockFile != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   738
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   739
		FILE* f = fopen(m_ServerLockFile, "wt");
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   740
		TCDEBUGLOGA2("CClientManager::CreateLockFile f=%x, lockFile=%s\n", f, m_ServerLockFile);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   741
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   742
		if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   743
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   744
			DWORD callingProcessId = ::GetCurrentProcessId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   745
			TCDEBUGLOGA2("CClientManager::CreateLockFile callingProcessId=%d processId=%d\n", callingProcessId, processId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   746
			fprintf(f, "%ld %ld\n", callingProcessId, processId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   747
			fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   748
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   749
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   750
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   751
			DWORD err = ::GetLastError();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   752
			TCDEBUGLOGA2("CClientManager::CreateLockFile fopenErr=%d:%s\n", err, GetErrorText(err));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   753
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   754
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   755
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   756
void CClientManager::AppendToLockFile(DWORD processId)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   757
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   758
	if (m_ServerLockFile != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   759
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   760
		FILE* f = fopen(m_ServerLockFile, "at");
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   761
		TCDEBUGLOGA2("CClientManager::AppendToLockFile f=%x, lockFile=%s\n", f, m_ServerLockFile);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   762
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   763
		if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   764
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   765
			DWORD callingProcessId = ::GetCurrentProcessId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   766
			TCDEBUGLOGA2("CClientManager::AppendToLockFile callingProcessId=%d processId=%d\n", callingProcessId, processId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   767
			fprintf(f, "%ld %ld\n", callingProcessId, processId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   768
			fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   769
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   770
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   771
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   772
			DWORD err = ::GetLastError();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   773
			TCDEBUGLOGA2("CClientManager::AppendToLockFile fopenErr=%d:%s\n", err, GetErrorText(err));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   774
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   775
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   776
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   777
void CClientManager::DeleteLockFile()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   778
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   779
	if (m_ServerLockFile != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   780
	{
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   781
		TCDEBUGLOGA1("CClientManager::DeleteLockFile lockFile=%s\n", m_ServerLockFile);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   782
		::remove(m_ServerLockFile);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   783
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   784
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   785
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   786
void CClientManager::DeleteFromLockFile(DWORD serverProcessId)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   787
{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   788
	DWORD creatorIds[10];
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   789
	DWORD serverIds[10];
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   790
	int numIds = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   791
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   792
	DWORD ourProcessId = ::GetCurrentProcessId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   793
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   794
	if (m_ServerLockFile != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   795
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   796
		DWORD attr = ::GetFileAttributes(m_ServerLockFile);
1991
1c752f14a126 add Ed's changes to allow multiple Carbide instances to use same TCFServer
Chad Peckham <chad.peckham@nokia.com>
parents: 1481
diff changeset
   797
		TCDEBUGLOGA2("CClientManager::DeleteFromLockFile attr=%x, lockFile=%s\n", attr, m_ServerLockFile);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   798
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   799
		if (attr != 0xffffffff) // error
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   800
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   801
			// file exists
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   802
			// read the process Ids from it 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   803
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   804
			FILE *f = fopen(m_ServerLockFile, "rt");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   805
			TCDEBUGLOGA1("CClientManager::DeleteFromLockFile f=%x\n", f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   806
			if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   807
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   808
				BOOL done = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   809
				while (!done)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   810
				{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   811
					DWORD creatorId = 0xffffffff;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   812
					DWORD serverId = 0xffffffff;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   813
					int n = fscanf(f, "%ld %ld\n", &creatorId, &serverId);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   814
					if (n == 2)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   815
					{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   816
						TCDEBUGLOGA3("CClientManager::DeleteFromLockFile numIds=%d creatorId=%d serverId=%d\n", numIds, creatorId, serverId);
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   817
						if (creatorId != ourProcessId || serverId != serverProcessId)
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   818
						{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   819
							creatorIds[numIds] = creatorId;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   820
							serverIds[numIds] = serverId;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   821
							numIds++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   822
							if (numIds > 9)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   823
								done = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   824
						}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   825
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   826
					else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   827
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   828
						done = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   829
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   830
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   831
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   832
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   833
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   834
			// now rewrite lock file without us
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   835
			::remove(m_ServerLockFile);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   836
			if (numIds > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   837
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   838
				f = fopen(m_ServerLockFile, "wt");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   839
				if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   840
				{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   841
					for (int i = 0; i < numIds; i++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   842
					{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   843
						fprintf(f, "%ld %ld\n", creatorIds[i], serverIds[i]);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   844
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   845
					fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   846
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   847
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   848
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   849
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   850
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   851
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   852
// Currently assumes there is only ONE TCFServer, but multiple client processes (that use that server)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   853
// we should not have more than a few Carbide processes connecting to the same TCFServer
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   854
void CClientManager::TerminateServerThroughLockFile(pServerProcessData pData)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   855
{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   856
	DWORD creatorIds[10];
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   857
	DWORD serverIds[10];
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   858
	BOOL liveCaller[10];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   859
	int numIds = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   860
	if (m_ServerLockFile != NULL)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   861
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   862
		DWORD attr = ::GetFileAttributes(m_ServerLockFile);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   863
		TCDEBUGLOGA1("CClientManager::TerminateServerThroughLockFile attr=%x\n", attr);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   864
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   865
		if (attr != 0xffffffff) // error
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   866
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   867
			// file exists
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   868
			// read the process Ids from it 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   869
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   870
			FILE *f = fopen(m_ServerLockFile, "rt");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   871
			TCDEBUGLOGA1("CClientManager::TerminateServerThroughLockFile f=%x\n", f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   872
			if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   873
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   874
				BOOL done = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   875
				while (!done)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   876
				{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   877
					DWORD creatorId = 0xffffffff;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   878
					DWORD serverId = 0xffffffff;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   879
					int n = fscanf(f, "%ld %ld\n", &creatorId, &serverId);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   880
					if (n == 2)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   881
					{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   882
						TCDEBUGLOGA3("CClientManager::TerminateServerThroughLockFile n=%d creatorId=%d serverId=%d\n", n, creatorId, serverId);
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   883
						creatorIds[numIds] = creatorId;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   884
						serverIds[numIds] = serverId;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   885
						numIds++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   886
						if (numIds > 9)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   887
							done = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   888
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   889
					else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   890
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   891
						done = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   892
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   893
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   894
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   895
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   896
				int numDeadCallers = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   897
				for (int i = 0; i < numIds; i++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   898
				{
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   899
					HANDLE h = ::OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, creatorIds[i]);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   900
					if (h)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   901
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   902
						// calling process is still alive
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   903
						liveCaller[i] = TRUE;
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   904
						DWORD exitCode = -5;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   905
						BOOL exitCall = ::GetExitCodeProcess(h, &exitCode);
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   906
						DWORD id = ::GetCurrentProcessId();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   907
						::CloseHandle(h);
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   908
						TCDEBUGLOGA3("CClientManager::TerminateServerThroughLockFile %d alive exitCall=%d currentId=%d\n", creatorIds[i], exitCall, id);
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   909
						if (exitCall == TRUE && exitCode != STILL_ACTIVE)
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   910
						{
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   911
							liveCaller[i] = FALSE;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   912
							numDeadCallers++;
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   913
						}
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   914
						{
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   915
							TCDEBUGLOGA2("CClientManager::TerminateServerThroughLockFile exitCode=%d still_active=%d\n", exitCode, STILL_ACTIVE);
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   916
						}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   917
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   918
					else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   919
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   920
						liveCaller[i] = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   921
						numDeadCallers++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   922
						DWORD err = ::GetLastError();
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   923
						TCDEBUGLOGA3("CClientManager::TerminateServerThroughLockFile %d dead err=%d:%s\n", creatorIds[i], err, GetErrorText(err));
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   924
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   925
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   926
				if (numDeadCallers == numIds)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   927
				{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   928
					// All clients of this TCFServer are dead
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   929
					// terminate the TCFServer, and delete lock file
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   930
					pData->numRefs = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   931
					::remove(m_ServerLockFile);
505
6de8d9cfdda1 modify how we determine if the TCFServer process creator is still alive - this will help in killing orphan TCFServer processes on startup
Chad Peckham <chad.peckham@nokia.com>
parents: 60
diff changeset
   932
					HANDLE h = ::OpenProcess(SYNCHRONIZE|PROCESS_TERMINATE, FALSE, serverIds[0]);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   933
					if (h)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   934
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   935
						BOOL ret = ::TerminateProcess(h, -1);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   936
						if (ret == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   937
						{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   938
							DWORD err = ::GetLastError();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   939
							TCDEBUGLOGA2("CClientManager::TerminateServerThroughLockFile TerminateProcess=%d:%s\n", err, GetErrorText(err));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   940
						}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   941
						::CloseHandle(h);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   942
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   943
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   944
				else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   945
				{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   946
					// some java clients are still alive
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   947
					//   check to see if TCFServer is still alive
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   948
					if (IsTCFServerActive(serverIds[0]))
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   949
					{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   950
						// TCFServer is still active
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   951
						// leave TCFServer running, recreate lock file and save live callers
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   952
						::remove(m_ServerLockFile);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   953
						f = fopen(m_ServerLockFile, "wt");
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   954
						if (f)
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   955
						{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   956
							for (int i = 0; i < numIds; i++)
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   957
							{
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   958
								if (liveCaller[i])
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   959
								{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   960
									fprintf(f, "%ld %ld\n", creatorIds[i], serverIds[i]);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   961
								}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   962
							}
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   963
							fclose(f);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   964
						}
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   965
						pData->numRefs -= numDeadCallers;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   966
						if (pData->numRefs < 0) pData->numRefs = 0;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   967
					}
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   968
					else
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   969
					{
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   970
						// TCFServer is really dead
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   971
						pData->numRefs = 0;
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   972
						::remove(m_ServerLockFile);
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   973
					}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   974
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   975
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   976
			else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   977
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   978
				// error opening lock file
914
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   979
				// perhaps the user deleted it,
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   980
				//   if so, we assume he has also deleted the TCFServer as we now have no way of verifying if the 
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   981
				//   process is dead.
46f36a149510 Fix TCFServer life-cycle issues bug 10621
Chad Peckham <chad.peckham@nokia.com>
parents: 505
diff changeset
   982
				pData->numRefs = 0;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   983
				DWORD err = ::GetLastError();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   984
				TCDEBUGLOGA2("CClientManager::TerminateServerThroughLockFile fopenErr=%d:%s\n", err, GetErrorText(err));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   985
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   986
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   987
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   988
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   989
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   990
static char* GetErrorText(DWORD inError)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   991
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   992
	static char msg[256];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   993
	FormatMessage(
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   994
		FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   995
		NULL,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   996
		inError,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   997
		MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   998
		(LPTSTR) &msg,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   999
		sizeof(msg) - 1,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1000
		NULL);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1001
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1002
	return msg;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1003
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1004
#else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1005
static char* GetErrorText(DWORD inError)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1006
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1007
	return NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1008
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
  1009
#endif