connectivity/com.nokia.tcf/native/TCFNative/TCFCommTCP/TcpComm.cpp
author timkelly
Sun, 06 Dec 2009 20:47:07 -0600
changeset 642 20fd716f8eaa
parent 506 44dbbc3220b8
permissions -rw-r--r--
merge commit
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
// TcpComm.cpp: implementation of the CTcpComm 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 "TcpComm.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    23
//#include "pn_const.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    24
//#include "OSTConstants.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    25
#include "Connection.h"
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    26
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    27
//////////////////////////////////////////////////////////////////////
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    28
// Construction/Destruction
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    29
//////////////////////////////////////////////////////////////////////
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    30
CTcpComm::CTcpComm()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    31
{
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
	if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    34
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    35
//		FILE* f = fopen("c:\\tcf\\tcpcommlog.txt", "at");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    36
//		fprintf(f, "CTcpComm::CTcpComm() (default constructor)\n");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    37
//		fclose(f);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    38
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    39
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    40
	m_socket = INVALID_SOCKET;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    41
	m_timeOut.tv_sec = TIMEOUT_SEC(DEFAULT_SOCKET_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    42
	m_timeOut.tv_usec = TIMEOUT_USEC(DEFAULT_SOCKET_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    43
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    44
	m_hSocketEvent = WSA_INVALID_EVENT;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    45
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    46
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    47
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    48
CTcpComm::CTcpComm(ConnectData* connectSettings, DWORD connectionId, CBaseProtocol* protocol)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    49
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    50
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    51
	if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    52
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    53
//		FILE* f = fopen("c:\\tcf\\tcpcommlog.txt", "at");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    54
//		fprintf(f, "connectSettings=%x connectionId=%d, protocol=%x\n", connectSettings, connectionId, protocol);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    55
//		fclose(f);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    56
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    57
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    58
	m_connId = connectionId;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    59
	m_Protocol = protocol;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    61
	m_ConnectSettings = new ConnectData();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    62
	memcpy(m_ConnectSettings, connectSettings, sizeof(ConnectData));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    63
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    64
#if (defined(LOG_COMM) || defined(LOG_PROCCOMM)) && defined(_DEBUG)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    65
	if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    66
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    67
		m_CommDebugLog = new TCDebugLog("TCF_Comm", connectionId, 2000L);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    68
		m_ProcDebugLog = new TCDebugLog("TCF_CommP", connectionId, 2000L);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    69
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    70
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    71
	m_socket = INVALID_SOCKET;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    72
	m_timeOut.tv_sec = TIMEOUT_SEC(DEFAULT_SOCKET_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    73
	m_timeOut.tv_usec = TIMEOUT_USEC(DEFAULT_SOCKET_TIMEOUT);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    74
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    75
	m_hSocketEvent = WSA_INVALID_EVENT;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    76
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    77
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    78
CTcpComm::~CTcpComm()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    79
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    80
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    81
	if (gDoLogging)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    82
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    83
//		FILE* f = fopen("c:\\tcf\\tcpcommlog.txt", "at");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    84
//		fprintf(f, "CTcpComm::~CTcpComm()\n");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    85
//		fclose(f);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    86
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    87
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    88
	if (IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    89
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    90
		if (m_socket != INVALID_SOCKET)
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    91
		{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    92
			shutdown(m_socket, SD_BOTH);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    93
			closesocket(m_socket);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    94
			WSAClose();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    95
		}
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
    96
		m_isConnected = false;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    97
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    98
	if (m_pBuffer)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
    99
		delete[] m_pBuffer;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   100
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   101
	if (m_hSocketEvent != WSA_INVALID_EVENT)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   102
		WSACloseEvent(m_hSocketEvent);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   103
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   104
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   105
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   106
//#define USE_EVENTS
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   107
;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   108
long CTcpComm::OpenPort()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   109
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   110
	COMMLOGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   111
	COMMLOGS("CTcpComm::OpenPort\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   112
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   113
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   114
	char* ipAddress = m_ConnectSettings->tcpSettings.ipAddress;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   115
	char* ipPort = m_ConnectSettings->tcpSettings.ipPort;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   116
	// set this to set socket to non-blocking
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   117
	// DWORD nonblock = 1;		// non-blocking
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   118
	DWORD nonblock = 0;		// blocking
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   119
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   120
	COMMLOGA2("CTcpComm::OpenPort ipAddress=%s ipPort=%s\n", ipAddress, ipPort);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   121
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   122
	int wsaErr = 0;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   123
	wsaErr = WSAInit();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   124
	if (wsaErr != 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   125
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   126
		err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   127
//		err = -1;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   128
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   129
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   130
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   131
		m_socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   132
		COMMLOGA1("CTcpComm::OpenPort socket=%x\n", m_socket);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   133
		if (m_socket == INVALID_SOCKET)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   134
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   135
			m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   136
			WSASetLastError(0);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   137
			WSAClose();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   138
			err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   139
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   140
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   141
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   142
			if (ioctlsocket(m_socket, FIONBIO, &nonblock) == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   143
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   144
				m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   145
				WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   146
				closesocket(m_socket);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   147
				m_socket = INVALID_SOCKET;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   148
				WSAClose();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   149
				err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   150
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   151
			else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   152
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   153
				int i = SO_MAX_MSG_SIZE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   154
				// set socket options
389
de80f483b7e6 Turn keepalive back on to be compatible with 2.0.x releases.
Chad Peckham <chad.peckham@nokia.com>
parents: 366
diff changeset
   155
				BOOL keepAlive = TRUE;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   156
				setsockopt(m_socket, SOL_SOCKET, SO_KEEPALIVE, (const char*)&keepAlive, sizeof(BOOL));
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   157
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   158
				struct linger l;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   159
				l.l_onoff = 0; l.l_linger = 0;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   160
				setsockopt(m_socket, SOL_SOCKET, SO_LINGER, (const char*)&l, sizeof(l));
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   161
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   162
				int sockRecvSize = MAX_TCP_MESSAGE_BUFFER_LENGTH;//(256*1024L);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   163
				setsockopt(m_socket, SOL_SOCKET, SO_RCVBUF, (const char*)&sockRecvSize, sizeof(int));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   164
				int sockSendSize = (64*1024L);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   165
				setsockopt(m_socket, SOL_SOCKET, SO_SNDBUF, (const char*)&sockSendSize, sizeof(int));
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   166
				WSAGetLastError(); // ignore error for now
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   167
				WSASetLastError(0);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   168
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   169
				// connect
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   170
				WORD wPort = atoi(ipPort);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   171
				m_clientService.sin_family = AF_INET;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   172
				m_clientService.sin_addr.S_un.S_addr = inet_addr(ipAddress);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   173
				m_clientService.sin_port = htons(wPort);
478
2d6f57ea6ce2 Debug logging changes
Chad Peckham <chad.peckham@nokia.com>
parents: 458
diff changeset
   174
2d6f57ea6ce2 Debug logging changes
Chad Peckham <chad.peckham@nokia.com>
parents: 458
diff changeset
   175
				COMMLOGS("CTcpComm::OpenPort connect start\n");
2d6f57ea6ce2 Debug logging changes
Chad Peckham <chad.peckham@nokia.com>
parents: 458
diff changeset
   176
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   177
				if (connect(m_socket, (SOCKADDR*)&m_clientService, sizeof(m_clientService)) == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   178
				{
478
2d6f57ea6ce2 Debug logging changes
Chad Peckham <chad.peckham@nokia.com>
parents: 458
diff changeset
   179
					COMMLOGS("CTcpComm::OpenPort connect SOCKET_ERROR\n");
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   180
					int wsaErr = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   181
					WSASetLastError(0);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   182
					COMMLOGA1("CTcpComm::OpenPort connect=wsaErr=%d\n", wsaErr);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   183
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   184
					// socket is non-blocking
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   185
					if (wsaErr != WSAEWOULDBLOCK)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   186
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   187
						m_lastCommError = wsaErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   188
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   189
						closesocket(m_socket);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   190
						m_socket = INVALID_SOCKET;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   191
						WSAClose();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   192
						err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   193
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   194
					else // WSAEWOULDBLOCK error returned
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   195
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   196
						// WSAEWOULDBLOCK use select now
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   197
						fd_set readfds, writefds, exceptfds;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   198
						FD_ZERO(&readfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   199
						FD_ZERO(&writefds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   200
						FD_ZERO(&exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   201
						FD_SET(m_socket, &readfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   202
						FD_SET(m_socket, &writefds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   203
						FD_SET(m_socket, &exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   204
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   205
						int selRes = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   206
						while(1)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   207
						{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   208
							selRes = select(0, &readfds, &writefds, &exceptfds, &m_timeOut);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   209
							if (selRes == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   210
							{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   211
								wsaErr = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   212
								WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   213
								if (wsaErr != WSAEWOULDBLOCK)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   214
								{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   215
									// real error
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   216
									m_lastCommError = wsaErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   217
									shutdown(m_socket, SD_BOTH);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   218
									closesocket(m_socket);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   219
									m_socket = INVALID_SOCKET;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   220
									WSAClose();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   221
									err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   222
								}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   223
								// else do another select
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   224
							}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   225
							else if (selRes > 0)// select OK 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   226
							{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   227
								m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   228
								m_isConnected = true;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   229
								break; // done
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   230
							}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   231
							else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   232
							{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   233
								// timed out
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   234
								m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   235
								WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   236
								shutdown(m_socket, SD_BOTH);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   237
								closesocket(m_socket);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   238
								m_socket = INVALID_SOCKET;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   239
								WSAClose();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   240
								err = TCAPI_ERR_WHILE_CONFIGURING_MEDIA;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   241
							}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   242
						}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   243
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   244
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   245
				else // connect return OK
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   246
				{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   247
					COMMLOGS("CTcpComm::OpenPort connect OK\n");
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   248
					m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   249
					m_isConnected = true;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   250
				}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   251
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   252
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   253
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   254
	if (err == TCAPI_ERR_NONE)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   255
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   256
		// we are connected
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   257
		m_numberBytes = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   258
		m_pBuffer = new BYTE[MAX_TCP_MESSAGE_BUFFER_LENGTH];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   259
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   260
#ifdef USE_EVENTS
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   261
		// create an event for the socket closing
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   262
		m_hSocketEvent = WSACreateEvent();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   263
		::WSAEventSelect(m_socket, m_hSocketEvent, FD_CLOSE);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   264
		// above call sets socket to non-blocking
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   265
		//  cannot reset to blocking after using WSAEventSelect
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   266
		//  thus this ioctlsocket call will fail
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   267
		ioctlsocket(m_socket, FIONBIO, &nonblock);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   268
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   269
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   270
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   271
	COMMLOGA1("CTcpComm::OpenPort err=%d\n", err);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   272
	COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   273
	return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   274
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   275
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   276
long CTcpComm::ClosePort()
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   277
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   278
	COMMLOGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   279
	COMMLOGS("CTcpComm::ClosePort\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   280
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   281
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   282
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   283
	if (!IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   284
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   285
		err = TCAPI_ERR_MEDIA_NOT_OPEN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   286
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   287
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   288
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   289
		if (m_socket != INVALID_SOCKET)
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   290
		{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   291
			shutdown(m_socket, SD_BOTH);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   292
			closesocket(m_socket);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   293
			m_socket = INVALID_SOCKET;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   294
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   295
			WSAClose();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   296
		}
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   297
		m_isConnected = false;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   298
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   299
		delete[] m_pBuffer;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   300
		m_pBuffer = NULL;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   301
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   302
		if (m_hSocketEvent != WSA_INVALID_EVENT)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   303
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   304
			WSACloseEvent(m_hSocketEvent);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   305
			m_hSocketEvent = WSA_INVALID_EVENT;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   306
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   307
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   308
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   309
	COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   310
	return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   311
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   312
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   313
long CTcpComm::PollPort(DWORD &outSize)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   314
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   315
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   316
	DWORD numBytes = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   317
	outSize = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   318
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   319
	if (!IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   320
		return TCAPI_ERR_MEDIA_NOT_OPEN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   321
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   322
#ifdef USE_EVENTS
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   323
	int ret = ::WSAWaitForMultipleEvents(1, &m_hSocketEvent, FALSE, 0, FALSE);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   324
	if (ret == WSA_WAIT_EVENT_0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   325
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   326
		::WSAResetEvent(m_hSocketEvent);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   327
		err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   328
		m_lastCommError = WSAESHUTDOWN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   329
		return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   330
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   331
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   332
	int sockErr = 0; int optLen = sizeof(int);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   333
	int getErr = getsockopt(m_socket, SOL_SOCKET, SO_ERROR, (char*)&sockErr, &optLen);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   334
	if (getErr == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   335
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   336
		if (sockErr)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   337
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   338
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   339
			m_lastCommError = sockErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   340
			return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   341
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   342
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   343
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   344
	fd_set readfds, writefds, exceptfds;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   345
	FD_ZERO(&readfds); 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   346
	FD_ZERO(&writefds); 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   347
	FD_ZERO(&exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   348
	FD_SET(m_socket, &readfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   349
	FD_SET(m_socket, &writefds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   350
	FD_SET(m_socket, &exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   351
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   352
	bool portReady = false;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   353
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   354
		TIMEVAL pollTimeout = {0,0}; // just poll the status
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   355
		int selErr = select(0, &readfds, 0, 0, &pollTimeout);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   356
		if (selErr > 0)
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 (FD_ISSET(m_socket, &readfds))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   359
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   360
				m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   361
				portReady = true;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   362
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   363
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   364
		else if (selErr == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   365
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   366
			m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   367
			WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   368
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   369
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   370
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   371
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   372
	if (portReady)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   373
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   374
		// read was signaled as ready
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   375
		int recvRet = recv(m_socket, (char*)&m_pPeekBuffer, sizeof(m_pPeekBuffer), MSG_PEEK);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   376
		if (recvRet > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   377
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   378
			if (ioctlsocket(m_socket, FIONREAD, &numBytes) == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   379
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   380
				m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   381
				outSize = numBytes;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   382
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   383
			else // SOCKET_ERROR
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   384
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   385
				m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   386
				WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   387
				err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   388
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   389
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   390
		else if (recvRet == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   391
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   392
			// read was signalled as ready but recv=0 signals that remote shutdown
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   393
			m_lastCommError = WSAESHUTDOWN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   394
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   395
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   396
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   397
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   398
			// SOCKET_ERROR: error on recv other than a shutdown
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   399
			m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   400
			WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   401
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   402
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   403
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   404
	return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   405
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   406
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   407
long CTcpComm::ReadPort(DWORD inSize, void *outData, DWORD &outSize)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   408
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   409
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   410
	DWORD numBytes = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   411
	outSize = 0;
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 (!IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   414
		return TCAPI_ERR_MEDIA_NOT_OPEN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   415
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   416
	if (ioctlsocket(m_socket, FIONREAD, &numBytes) == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   417
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   418
		if (numBytes > inSize)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   419
			numBytes = inSize;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   420
		int res = recv(m_socket, (char*)outData, numBytes, 0);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   421
		if (res == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   422
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   423
			long commErr = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   424
			WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   425
			if ((DWORD)commErr != m_lastCommError)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   426
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   427
				m_lastCommError = commErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   428
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   429
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   430
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   431
		else if (res == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   432
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   433
			// recv=0 --> connection closed
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   434
			m_lastCommError = WSAESHUTDOWN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   435
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   436
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   437
		else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   438
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   439
			m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   440
			outSize = numBytes;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   441
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   442
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   443
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   444
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   445
		// SOCKET_ERROR on ioctlsocket
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   446
		m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   447
		WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   448
		err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   449
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   450
	return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   451
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   452
long CTcpComm::ProcessBuffer(CConnection* pConn, CRegistry* pRegistry, long& numberProcessed)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   453
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   454
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   455
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   456
	long routingErr = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   457
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   458
	if (!IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   459
		return TCAPI_ERR_MEDIA_NOT_OPEN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   460
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   461
	if (!m_Protocol)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   462
		return TCAPI_ERR_UNKNOWN_MEDIA_TYPE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   463
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   464
	DWORD protocolHeaderLength = m_Protocol->GetHeaderLength();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   465
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   466
	// fill buffer
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   467
	if (m_numberBytes < MAX_TCP_MESSAGE_BUFFER_LENGTH)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   468
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   469
		DWORD outLen = MAX_TCP_MESSAGE_BUFFER_LENGTH - m_numberBytes;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   470
		BYTE* ptr = &m_pBuffer[m_numberBytes];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   471
		err = ReadPort(outLen, ptr, outLen);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   472
		if (err == TCAPI_ERR_NONE && outLen > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   473
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   474
			m_numberBytes += outLen;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   475
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   476
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   477
	
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   478
	// now process buffer but only for complete messages
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   479
	if (err == TCAPI_ERR_NONE)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   480
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   481
		if (m_numberBytes >= protocolHeaderLength)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   482
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   483
			BYTE* ptr = m_pBuffer;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   484
			long bytesRemaining = m_numberBytes;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   485
			long usedLen = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   486
			bool done = false;
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   487
			long numberSkipped=0;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   488
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   489
			while (!done)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   490
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   491
				DWORD fullMessageLength = bytesRemaining;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   492
				DWORD rawLength = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   493
				BYTE* fullMessage = ptr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   494
				BYTE* rawMessage = ptr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   495
				BYTE msgId = 0;
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   496
				int result = m_Protocol->DecodeMessage(fullMessage, fullMessageLength, msgId, rawMessage, rawLength);
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   497
				if (result == DECODE_NOT_ENOUGH_BYTES_TO_SEARCH)
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   498
				{
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   499
					done = true;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   500
				}
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   501
				else if (result == DECODE_MESSAGE_NOT_FOUND)
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   502
				{
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   503
					numberSkipped++;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   504
					usedLen += fullMessageLength;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   505
					bytesRemaining -= fullMessageLength;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   506
					ptr += fullMessageLength;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   507
					if (bytesRemaining < protocolHeaderLength)
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   508
						done = true;
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   509
				}
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   510
				else if (result == DECODE_MESSAGE_FOUND)
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   511
				{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   512
					err = PreProcessMessage(msgId, fullMessageLength, fullMessage);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   513
					if (err != TCAPI_ERR_NONE)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   514
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   515
						PROCLOGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   516
						PROCLOGA1("CTcpComm::ProcessBuffer Notify err = %x\n", err);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   517
						PROCLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   518
						// notify all clients right now 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   519
						pConn->NotifyClientsCommError(err, false, 0);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   520
						err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   521
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   522
#ifdef _DEBUG
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   523
					int reallen = fullMessageLength;
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   524
					if (reallen > 100) reallen = 100;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   525
					bool wasAlnum = false;
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   526
					char msg[6];
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   527
					msg[0] = '\0';
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   528
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   529
					sTcpLogMsg[0] = '\0';
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   530
					if (reallen > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   531
					{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   532
						sTcpLogMsg[0] = '\0';
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   533
						for (int i = 0; i < reallen; i++)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   534
						{
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   535
							if (isgraph/*isalnum*/(ptr[i]) && i > protocolHeaderLength)
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   536
							{
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   537
								// string printables next to each other
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   538
								sprintf(msg, "%c", ptr[i]);
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   539
								wasAlnum = true;
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   540
							}
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   541
							else
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   542
							{
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   543
								if (wasAlnum)
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   544
								{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   545
									// break from last alnum char
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   546
									sprintf(msg, " %02.2x ", ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   547
								}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   548
								else
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   549
								{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   550
									// no break
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   551
									sprintf(msg, "%02.2x ", ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   552
								}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   553
								wasAlnum = false;
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   554
							}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   555
							strcat(sTcpLogMsg, msg);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   556
						}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   557
					}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   558
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   559
					PROCLOGOPEN();
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   560
					PROCLOGA5("CTcpComm::ProcessBuffer - RouteMesssage pRegistry = %x id=%x len=%d len=%d msg=%s\n", pRegistry, msgId, fullMessageLength, rawLength, sTcpLogMsg);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   561
					PROCLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   562
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   563
					err = pRegistry->RouteMessage(msgId, fullMessage, fullMessageLength, rawMessage, rawLength);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   564
					if (err != TCAPI_ERR_NONE) routingErr = err; // saved for future
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   565
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   566
					numberProcessed++;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   567
					usedLen += fullMessageLength;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   568
					bytesRemaining -= fullMessageLength;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   569
					ptr += fullMessageLength;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   570
					if (bytesRemaining < protocolHeaderLength)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   571
						done = true;
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
			DeleteMsg(usedLen);
458
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   575
			PROCLOGOPEN();
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   576
			PROCLOGA2("CTcpComm::ProcessBuffer - numberSkipped=%d numberProcessed=%d\n", numberSkipped, numberProcessed);
70467d598794 Fix for bug 9652
Chad Peckham <chad.peckham@nokia.com>
parents: 425
diff changeset
   577
			PROCLOGCLOSE();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   578
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   579
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   580
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   581
	if (routingErr == TCAPI_ERR_NONE)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   582
		return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   583
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   584
		return routingErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   585
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   586
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   587
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   588
long CTcpComm::SendDataToPort(DWORD inSize, const void* inData)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   589
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   590
	COMMLOGOPEN();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   591
	COMMLOGS("CTcpComm::SendDataToPort\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   592
	
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   593
	long err = TCAPI_ERR_NONE;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   594
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   595
	if (!IsConnected())
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   596
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   597
		COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   598
		return TCAPI_ERR_MEDIA_NOT_OPEN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   599
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   600
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   601
#ifdef USE_EVENTS
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   602
	int ret = ::WSAWaitForMultipleEvents(1, &m_hSocketEvent, FALSE, 0, FALSE);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   603
	if (ret == WSA_WAIT_EVENT_0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   604
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   605
		::WSAResetEvent(m_hSocketEvent);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   606
		err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   607
		m_lastCommError = WSAESHUTDOWN;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   608
		COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   609
		return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   610
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   611
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   612
	int sockErr = 0; int optLen = sizeof(int);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   613
	int getErr = getsockopt(m_socket, SOL_SOCKET, SO_ERROR, (char*)&sockErr, &optLen);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   614
	if (getErr == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   615
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   616
		if (sockErr)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   617
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   618
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   619
			m_lastCommError = sockErr;
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   620
			COMMLOGA1("CTcpComm::SendDataToPort getsockopt=%d\n", sockErr);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   621
			COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   622
			return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   623
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   624
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   625
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   626
	fd_set readfds, writefds, exceptfds;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   627
	FD_ZERO(&readfds); 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   628
	FD_ZERO(&writefds); 
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   629
	FD_ZERO(&exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   630
	FD_SET(m_socket, &readfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   631
	FD_SET(m_socket, &writefds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   632
	FD_SET(m_socket, &exceptfds);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   633
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   634
	COMMLOGS("CTcpComm::SendDataToPort select\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   635
	bool portReady = false;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   636
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   637
		int selErr = select(0, &readfds, &writefds, &exceptfds, &m_timeOut);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   638
		if (selErr > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   639
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   640
			if (FD_ISSET(m_socket, &writefds))
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   641
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   642
				m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   643
				portReady = true;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   644
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   645
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   646
		else if (selErr == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   647
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   648
			m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   649
			WSASetLastError(0);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   650
			COMMLOGA1("CTcpComm::SendDataToPort select(SOCKET_ERROR)=%d\n", m_lastCommError);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   651
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   652
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   653
		else if (selErr == 0) // timeout
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   654
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   655
			m_lastCommError = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   656
			WSASetLastError(0);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   657
			COMMLOGA1("CTcpComm::SendDataToPort select(timeout)=%d\n", m_lastCommError);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   658
			err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   659
		}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   660
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   661
	COMMLOGA1("CTcpComm::SendDataToPort portReady=%d\n", portReady);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   662
	if (portReady)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   663
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   664
		COMMLOGS("CTcpComm::SendDataToPort send start\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   665
		// loop until all bytes are sent
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   666
		DWORD bytesRemaining = inSize;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   667
		DWORD nSent = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   668
		char* unsent = (char*)inData;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   669
		while (bytesRemaining)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   670
		{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   671
			nSent = send(m_socket, unsent, bytesRemaining, 0);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   672
			if (nSent == SOCKET_ERROR)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   673
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   674
				int wsaErr = WSAGetLastError();
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   675
				WSASetLastError(0);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   676
				// ignore "would block" errors
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   677
				if (wsaErr != WSAEWOULDBLOCK)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   678
				{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   679
					// TODO: error handling
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   680
					COMMLOGA1("CTcpComm::SendDataToPort send(SOCKET_ERROR)=%d\n", wsaErr);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   681
					m_lastCommError = wsaErr;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   682
					err = TCAPI_ERR_COMM_ERROR;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   683
					break;
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
			else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   687
			{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   688
				m_lastCommError = 0;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   689
				unsent += nSent;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   690
				bytesRemaining -= nSent;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   691
			}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   692
		} // end while
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   693
		COMMLOGS("CTcpComm::SendDataToPort send done\n");
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   694
#ifdef _DEBUG
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   695
		DWORD protocolHeaderLength = m_Protocol->GetHeaderLength();
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   696
		BYTE* ptr = (BYTE*)inData;
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   697
		int reallen = inSize;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   698
		if (reallen > 100) reallen = 100;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   699
		bool wasAlnum = false;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   700
		char msg[6];
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   701
		msg[0] = '\0';
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   702
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   703
		sTcpLogMsgSend[0] = '\0';
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   704
		if (reallen > 0)
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   705
		{
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   706
			sTcpLogMsgSend[0] = '\0';
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   707
			for (int i = 0; i < reallen; i++)
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   708
			{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   709
				if (isgraph/*isalnum*/(ptr[i]) && i > protocolHeaderLength)
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   710
				{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   711
					// string printables next to each other
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   712
					sprintf(msg, "%c", ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   713
					wasAlnum = true;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   714
				}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   715
				else
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   716
				{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   717
					if (wasAlnum)
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   718
					{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   719
						// break from last alnum char
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   720
						sprintf(msg, " %02.2x ", ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   721
					}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   722
					else
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   723
					{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   724
						// no break
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   725
						sprintf(msg, "%02.2x ", ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   726
					}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   727
					wasAlnum = false;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   728
				}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   729
				strcat(sTcpLogMsgSend, msg);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   730
			}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   731
		}
506
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   732
//		BYTE* ptr = (BYTE*)inData;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   733
//		long numBytes = (inSize > 20) ? 20 : inSize;
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   734
//		char msg[200];
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   735
//		sprintf(msg, "CTcpComm::SendDataToPort data = ");
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   736
//		for (int i = 0; i < numBytes; i++)
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   737
//		{
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   738
//			sprintf(msg, "%s %02.2x", msg, ptr[i]);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   739
//		}
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   740
//		sprintf(msg, "%s\n", msg);
44dbbc3220b8 add different logging to send & recieve messages so we can see the messages better in debug version
Chad Peckham <chad.peckham@nokia.com>
parents: 478
diff changeset
   741
		COMMLOGA2("CTcpComm::SendDataToPort len=%d msg=%s\n", inSize, sTcpLogMsgSend);
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   742
#endif
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   743
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   744
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   745
	COMMLOGCLOSE();
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   746
	return err;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   747
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   748
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   749
void CTcpComm::DeleteMsg(DWORD inMsgLength)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   750
{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   751
	// inMsgLength includes header
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   752
	// delete from beginning of buffer
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   753
	if (inMsgLength == 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   754
		return;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   755
	if (m_numberBytes > 0 && m_numberBytes >= inMsgLength)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   756
	{
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   757
		size_t moveLen = m_numberBytes - inMsgLength;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   758
		if (moveLen > 0)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   759
			memcpy(&m_pBuffer[0], &m_pBuffer[inMsgLength], moveLen);
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   760
		m_numberBytes -= inMsgLength;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   761
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   762
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   763
bool CTcpComm::IsConnectionEqual(ConnectData* pConn)
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   764
{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   765
	if ((strcmp(pConn->tcpSettings.ipAddress, m_ConnectSettings->tcpSettings.ipAddress) == 0))
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   766
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   767
		if ((strcmp(pConn->tcpSettings.ipPort, m_ConnectSettings->tcpSettings.ipPort) == 0))
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   768
		{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   769
			// same port and same IP
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   770
			return true;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   771
		}
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   772
		else
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   773
		{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   774
			// different port but same IP
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   775
			return false;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   776
		}
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   777
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   778
	else
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   779
	{
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   780
		// different IP
60
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   781
		return false;
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   782
	}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   783
}
9d2210c8eed2 Commit changes for 2.1.0
chpeckha
parents:
diff changeset
   784
366
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   785
int CTcpComm::WSAInit() 
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   786
{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   787
	int wsaErr = 0;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   788
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   789
	COMMLOGOPEN();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   790
	COMMLOGS("CTcpComm::WSAInit\n");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   791
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   792
	WSADATA wsaData;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   793
	wsaErr = WSAStartup(MAKEWORD(2,2), &wsaData);
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   794
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   795
	COMMLOGCLOSE();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   796
	return wsaErr;
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   797
}
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   798
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   799
void CTcpComm::WSAClose()
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   800
{
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   801
	COMMLOGOPEN();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   802
	COMMLOGS("CTcpComm::WSAClose\n");
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   803
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   804
	WSACleanup();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   805
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   806
	COMMLOGCLOSE();
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   807
}
b054461d2f85 fix bug 9433 - also some logging changes
chpeckha
parents: 60
diff changeset
   808