BUG: CCeSocket OnReceive() does not get called for accepted data sockets (253945)
The information in this article applies to:
- Microsoft Windows CE Operating System, Versions 2.12
- Microsoft Windows CE Operating System, Versions 2.11
- Microsoft Windows CE Operating System, Versions 2.0
- Microsoft Windows CE Operating System, Versions 1.0
- Microsoft Windows CE Operating System, Versions 3.0
This article was previously published under Q253945 SYMPTOMS
If you use the CCeSocket Microsoft Foundation Class (MFC) class to build a Transfer Control Protocol (TCP) server application, your override of the CCeSocket::OnReceive function is not called when data is received for the connection that you have accepted in your override of the CCeSocket::OnAccept function.
CAUSE
The problem is that the CCeSocketDataThread thread function does not check for incoming data if the private m_bConnectedCalled member variable of CCeSocket is not set. The problem does not occur in client applications that just use data sockets. In this case, the application calls the Connect member function to connect to a remote socket. Connect in turn calls the ConnectHelper function. The override of ConnectHelper in CCeSocket does set m_bConnectedCalled to TRUE and therefore DataThread does check for incoming data and CCeSocket::OnReceive does get called.
In case you build a server application, you do create a listen socket and the actual data socket is returned when you call Accept in your override of CCeSocket::OnAccept. However there is no override for Accept in CCeSocket and m_bConnectedCalled does not get set for the returned socket. The result is that DataThread does not check for incoming data and CCeSocket::OnReceive will never get called for this socket.
RESOLUTION
To work around this problem, in your override of CCeSocket::OnAccept, you can set the m_bConnectCalled member variable of the CCeSocket object to TRUE after it is returned by Accept.
The problem with this method is that m_bConnectCalled is declared as private and you do not have access to it in your code. To get the required access, you must modify the Wcesock.h SDK header file so that m_bConnectedCalled is declared as public before compiling your application. To do this, in Wcesock.h, insert a new line with just the "public:" statement on it before the "BOOL m_bConnectCalled;" line. Please make a backup copy of Wcesock.h before you modify it, and take care that you do not change anything else within the header file. Just changing the declaration does not change the memory layout of the class, and therefore your application will work properly with the MFC run-time dynamic-link library (DLL).
STATUSMicrosoft has confirmed that this is a problem in the Microsoft products that are listed in the "Applies to" section.
Modification Type: | Minor | Last Reviewed: | 4/30/2004 |
---|
Keywords: | kbAPI kbbug kbnetwork kbpending kbWinsock KB253945 kbAudDeveloper |
---|
|