mirror of
https://gitee.com/ldcsaa/HP-Socket.git
synced 2024-12-02 03:37:50 +08:00
182 lines
3.9 KiB
C++
182 lines
3.9 KiB
C++
/*
|
|
* Copyright: JessMA Open Source (ldcsaa@gmail.com)
|
|
*
|
|
* Author : Bruce Liang
|
|
* Website : https://github.com/ldcsaa
|
|
* Project : https://github.com/ldcsaa/HP-Socket
|
|
* Blog : http://www.cnblogs.com/ldcsaa
|
|
* Wiki : http://www.oschina.net/p/hp-socket
|
|
* QQ Group : 44636872, 75375912
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "stdafx.h"
|
|
#include "UdpArqClient.h"
|
|
|
|
#ifdef _UDP_SUPPORT
|
|
|
|
BOOL CUdpArqClient::CheckParams()
|
|
{
|
|
DWORD dwMaxDatagramSize = GetMaxDatagramSize();
|
|
|
|
if(m_dwMtu == 0)
|
|
m_arqAttr.dwMtu = dwMaxDatagramSize;
|
|
else
|
|
{
|
|
if(m_dwMtu > dwMaxDatagramSize)
|
|
return FALSE;
|
|
|
|
m_arqAttr.dwMtu = m_dwMtu;
|
|
}
|
|
|
|
return __super::CheckParams() && m_arqAttr.IsValid();
|
|
}
|
|
|
|
void CUdpArqClient::PrepareStart()
|
|
{
|
|
__super::PrepareStart();
|
|
}
|
|
|
|
void CUdpArqClient::Reset()
|
|
{
|
|
m_arqSession.Reset();
|
|
|
|
__super::Reset();
|
|
}
|
|
|
|
void CUdpArqClient::OnWorkerThreadStart(THR_ID dwThreadID)
|
|
{
|
|
m_arqBuffer.Malloc(m_arqAttr.dwMaxMessageSize);
|
|
m_arqTimer.Set(m_arqAttr.dwFlushInterval);
|
|
|
|
}
|
|
|
|
void CUdpArqClient::OnWorkerThreadEnd(THR_ID dwThreadID)
|
|
{
|
|
m_arqTimer.Reset();
|
|
m_arqBuffer.Free();
|
|
}
|
|
|
|
HANDLE CUdpArqClient::GetUserEvent()
|
|
{
|
|
return m_arqTimer.GetHandle();
|
|
}
|
|
|
|
BOOL CUdpArqClient::OnUserEvent()
|
|
{
|
|
return m_arqSession.Check();
|
|
}
|
|
|
|
BOOL CUdpArqClient::Send(const BYTE* pBuffer, int iLength, int iOffset)
|
|
{
|
|
ASSERT(pBuffer && iLength > 0 && iLength <= (int)m_arqAttr.dwMaxMessageSize);
|
|
|
|
int result = NO_ERROR;
|
|
|
|
if(pBuffer && iLength > 0 && iLength <= (int)m_arqAttr.dwMaxMessageSize)
|
|
{
|
|
if(IsConnected())
|
|
{
|
|
if(iOffset != 0) pBuffer += iOffset;
|
|
result = m_arqSession.Send(pBuffer, iLength);
|
|
}
|
|
else
|
|
result = ERROR_INVALID_STATE;
|
|
}
|
|
else
|
|
result = ERROR_INVALID_PARAMETER;
|
|
|
|
if(result != NO_ERROR)
|
|
::SetLastError(result);
|
|
|
|
return (result == NO_ERROR);
|
|
}
|
|
|
|
BOOL CUdpArqClient::SendPackets(const WSABUF pBuffers[], int iCount)
|
|
{
|
|
ASSERT(pBuffers && iCount > 0);
|
|
|
|
if(!pBuffers || iCount <= 0)
|
|
return ERROR_INVALID_PARAMETER;
|
|
if(iCount == 1)
|
|
return Send((const BYTE*)pBuffers[0].buf, pBuffers[0].len);
|
|
if(!IsConnected())
|
|
return ERROR_INVALID_STATE;
|
|
|
|
int iLength = 0;
|
|
int iMaxLen = (int)m_arqAttr.dwMaxMessageSize;
|
|
|
|
for(int i = 0; i < iCount; i++)
|
|
iLength += pBuffers[i].len;
|
|
|
|
if(iLength <= 0 || iLength > iMaxLen)
|
|
return ERROR_INCORRECT_SIZE;
|
|
|
|
CBufferPtr sndBuffer(iLength);
|
|
sndBuffer.SetSize(0);
|
|
|
|
for(int i = 0; i < iCount; i++)
|
|
{
|
|
int iBufLen = pBuffers[i].len;
|
|
|
|
if(iBufLen > 0)
|
|
{
|
|
BYTE* pBuffer = (BYTE*)pBuffers[i].buf;
|
|
ASSERT(pBuffer);
|
|
|
|
sndBuffer.Cat(pBuffer, iBufLen);
|
|
}
|
|
}
|
|
|
|
int result = m_arqSession.Send(sndBuffer.Ptr(), (int)sndBuffer.Size());
|
|
|
|
if(result != NO_ERROR)
|
|
::SetLastError(result);
|
|
|
|
return (result == NO_ERROR);
|
|
}
|
|
|
|
int CUdpArqClient::ArqOutputProc(const char* pBuffer, int iLength, IKCPCB* kcp, LPVOID pv)
|
|
{
|
|
CUdpArqClient* pClient = (CUdpArqClient*)pv;
|
|
|
|
BOOL isOK = pClient->__super::Send((const BYTE*)pBuffer, iLength);
|
|
|
|
return isOK ? NO_ERROR : ::WSAGetLastError();
|
|
}
|
|
|
|
EnHandleResult CUdpArqClient::FireConnect()
|
|
{
|
|
EnHandleResult result = DoFireConnect(this);
|
|
|
|
if(result != HR_ERROR)
|
|
m_arqSession.Renew(this, this, m_arqAttr);
|
|
|
|
return result;
|
|
}
|
|
|
|
EnHandleResult CUdpArqClient::FireReceive(const BYTE* pData, int iLength)
|
|
{
|
|
return m_arqSession.Receive(pData, iLength, m_arqBuffer.Ptr(), (int)m_arqBuffer.Size());
|
|
}
|
|
|
|
BOOL CUdpArqClient::GetWaitingSendMessageCount(int& iCount)
|
|
{
|
|
iCount = m_arqSession.GetWaitingSend();
|
|
|
|
return (iCount >= 0);
|
|
}
|
|
|
|
#endif
|