From 176e3c932c6d9d1d10038956a3a83ef8277dd5d9 Mon Sep 17 00:00:00 2001 From: tomch Date: Mon, 19 Oct 2009 21:33:12 +0000 Subject: [PATCH] SerialComms: Changed queue to deque so we can clear() the container. --- AppleWin/source/SerialComms.cpp | 20 +++++++++----------- AppleWin/source/SerialComms.h | 4 ++-- 2 files changed, 11 insertions(+), 13 deletions(-) diff --git a/AppleWin/source/SerialComms.cpp b/AppleWin/source/SerialComms.cpp index c79184a9..e3e95191 100644 --- a/AppleWin/source/SerialComms.cpp +++ b/AppleWin/source/SerialComms.cpp @@ -99,9 +99,9 @@ void CSuperSerialCard::InternalReset() m_vbTxIrqPending = false; m_vbRxIrqPending = false; - m_qComSerialBuffer[0].c.clear(); - m_qComSerialBuffer[1].c.clear(); - m_qTcpSerialBuffer.c.clear(); + m_qComSerialBuffer[0].clear(); + m_qComSerialBuffer[1].clear(); + m_qTcpSerialBuffer.clear(); } CSuperSerialCard::~CSuperSerialCard() @@ -351,10 +351,8 @@ void CSuperSerialCard::CommTcpSerialClose() closesocket(m_hCommAcceptSocket); m_hCommAcceptSocket = INVALID_SOCKET; } - while (!m_qTcpSerialBuffer.empty()) - { - m_qTcpSerialBuffer.pop(); - } + + m_qTcpSerialBuffer.clear(); } //=========================================================================== @@ -381,7 +379,7 @@ void CSuperSerialCard::CommTcpSerialReceive() { for (int i = 0; i < nReceived; i++) { - m_qTcpSerialBuffer.push(Data[i]); + m_qTcpSerialBuffer.push_back(Data[i]); } } @@ -603,7 +601,7 @@ BYTE __stdcall CSuperSerialCard::CommReceive(WORD, WORD, BYTE, BYTE, ULONG) if (!m_qTcpSerialBuffer.empty()) { result = m_qTcpSerialBuffer.front(); - m_qTcpSerialBuffer.pop(); + m_qTcpSerialBuffer.pop_front(); } else if (m_hCommHandle != INVALID_HANDLE_VALUE) // COM { @@ -614,7 +612,7 @@ BYTE __stdcall CSuperSerialCard::CommReceive(WORD, WORD, BYTE, BYTE, ULONG) if (!m_qComSerialBuffer[uSSCIdx].empty()) { result = m_qComSerialBuffer[uSSCIdx].front(); - m_qComSerialBuffer[uSSCIdx].pop(); + m_qComSerialBuffer[uSSCIdx].pop_front(); UINT uNewSSCIdx = uSSCIdx; if ( m_qComSerialBuffer[uSSCIdx].empty() && // Current SSC buffer is empty @@ -956,7 +954,7 @@ void CSuperSerialCard::CheckCommEvent(DWORD dwEvtMask) { const UINT uCOMIdx = m_vuRxCurrBuffer; for (DWORD i = 0; i < dwReceived; i++) - m_qComSerialBuffer[uCOMIdx].push(Data[i]); + m_qComSerialBuffer[uCOMIdx].push_back(Data[i]); } LeaveCriticalSection(&m_CriticalSection); } diff --git a/AppleWin/source/SerialComms.h b/AppleWin/source/SerialComms.h index 9a2775e3..d5d227e0 100644 --- a/AppleWin/source/SerialComms.h +++ b/AppleWin/source/SerialComms.h @@ -113,9 +113,9 @@ private: // CRITICAL_SECTION m_CriticalSection; // To guard /g_vRecvBytes/ - queue m_qComSerialBuffer[2]; + deque m_qComSerialBuffer[2]; volatile UINT m_vuRxCurrBuffer; // Written to on COM recv. SSC reads from other one - queue m_qTcpSerialBuffer; + deque m_qTcpSerialBuffer; //