connectivity/com.nokia.tcf/native/TCFNative/TCFClient/TCFClient.cpp
author stechong
Wed, 20 Oct 2010 11:19:31 -0500
changeset 2165 2a7b5eccb0bc
parent 60 9d2210c8eed2
permissions -rw-r--r--
Keeping PlatSim internal only.
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
// TCFClient.cpp : Defines the entry point for the DLL application.
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
#include "stdafx.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    21
#include <stdio.h>
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    22
#include <sys/stat.h>
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    23
#include "ClientManager.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    24
#include "ServerClient.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    25
#include "InputStream.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    26
#include "ErrorMonitorData.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    27
#include "TCDebugLog.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    28
#include <vector>
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    29
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    30
// process wide data
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    31
CClientManager* gManager;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    32
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    33
BOOL gDoLogging = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    34
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    35
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    36
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    37
static void LogTime(FILE* f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    38
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    39
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    40
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    41
BOOL APIENTRY DllMain( HINSTANCE hinstDLL, 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    42
                       DWORD  fdwReason, 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    43
                       LPVOID lpReserved
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    44
					 )
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    45
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    46
    // Perform actions based on the reason for calling.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    47
    switch( fdwReason ) 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    48
    { 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    49
        case DLL_PROCESS_ATTACH:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    50
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    51
         // Initialize once for each new process.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    52
         // Return FALSE to fail DLL load.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    53
			DWORD currentProcessId = ::GetCurrentProcessId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    54
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    55
			// Create client manager for this process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    56
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    57
			struct _stat buf;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    58
			char* dirname = "c:\\tcf";
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    59
			int result = _stat(dirname, &buf);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    60
			if (result == 0) // exists
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    61
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    62
				gDoLogging = TRUE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    63
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    64
			else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    65
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    66
				gDoLogging = FALSE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    67
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    68
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    69
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    70
			gManager = new CClientManager(hinstDLL);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    71
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    72
			if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    73
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    74
				FILE* f = fopen("c:\\tcf\\TCF_DllMainDLL_PROCESS_ATTACH.txt", "at");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    75
				LogTime(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    76
				fprintf(f,"DLL_PROCESS_ATTACH:\n hinstDLL=%x\n processId=%d\n DllLocation=%s\n DebugLog->m_FileName=%s\n", 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    77
					hinstDLL, 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    78
					currentProcessId,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    79
					gManager->m_DllLocation,
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    80
					gManager->m_DebugLog->m_FileName);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    81
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    82
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    83
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    84
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    85
            break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    86
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    87
        case DLL_THREAD_ATTACH:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    88
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    89
         // Do thread-specific initialization.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    90
			DWORD currentThreadId = ::GetCurrentThreadId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    91
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    92
			if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    93
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    94
				FILE* f = fopen("c:\\tcf\\TCF_DllMainDLL_THREAD_ATTACH.txt", "at");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    95
				LogTime(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    96
				fprintf(f,"DLL_THREAD_ATTACH: hinstDLL=%x currentThreadId=%d\n", hinstDLL, currentThreadId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    97
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    98
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    99
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   100
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   101
            break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   102
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   103
        case DLL_THREAD_DETACH:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   104
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   105
         // Do thread-specific cleanup.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   106
			DWORD currentThreadId = ::GetCurrentThreadId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   107
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   108
			if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   109
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   110
				FILE* f = fopen("c:\\tcf\\TCF_DllMainDLL_THREAD_DETACH.txt", "at");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   111
				LogTime(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   112
				fprintf(f,"DLL_THREAD_DETTACH: hinstDLL=%x currentThreadId=%d\n", hinstDLL, currentThreadId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   113
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   114
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   115
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   116
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   117
            break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   118
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   119
        case DLL_PROCESS_DETACH:
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   120
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   121
         // Perform any necessary cleanup.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   122
			DWORD currentProcessId = ::GetCurrentProcessId();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   123
			// delete the client manager for this process
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   124
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   125
			if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   126
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   127
				FILE* f = fopen("c:\\tcf\\TCF_DllMainDLL_PROCESS_DETACH.txt", "at");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   128
				LogTime(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   129
				fprintf(f,"DLL_PROCESS_DETACH processId=%d\n", currentProcessId);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   130
				fclose(f);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   131
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   132
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   133
			if (gManager)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   134
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   135
				delete gManager;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   136
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   137
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   138
            break;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   139
    }
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   140
    return TRUE;  // Successful DLL_PROCESS_ATTACH.
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   141
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   142
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   143
static void LogTime(FILE* f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   144
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   145
	SYSTEMTIME sTime;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   146
	GetLocalTime(&sTime);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   147
	if (f)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   148
		fprintf(f, "%02.2d%02.2d-%02.2d:%02.2d:%02.2d.%03.3d: ", sTime.wDay, sTime.wMonth, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   149
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   150
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   151