fix channel comparison so messages actually get deleted after they're

ack'd.
This commit is contained in:
Eric House 2015-02-08 13:39:35 -08:00
parent acf5a01374
commit 88dd25fb21

View file

@ -1260,6 +1260,7 @@ removeFromQueue( CommsCtxt* comms, XP_PlayerAddr channelNo, MsgID msgID )
comms->msgQueueHead = comms->msgQueueTail = NULL; comms->msgQueueHead = comms->msgQueueTail = NULL;
comms->queueLen = 0; comms->queueLen = 0;
XP_PlayerAddr maskedChannelNo = ~CHANNEL_MASK & channelNo;
for ( ; !!elem; elem = next ) { for ( ; !!elem; elem = next ) {
XP_Bool knownGood = XP_FALSE; XP_Bool knownGood = XP_FALSE;
next = elem->next; next = elem->next;
@ -1269,10 +1270,11 @@ removeFromQueue( CommsCtxt* comms, XP_PlayerAddr channelNo, MsgID msgID )
queue, and receiving something from the server is an implicit queue, and receiving something from the server is an implicit
ACK -- IFF it isn't left over from the last game. */ ACK -- IFF it isn't left over from the last game. */
if ( ((CHANNEL_MASK & elem->channelNo) == 0) && (channelNo!= 0) ) { XP_PlayerAddr maskedElemChannelNo = ~CHANNEL_MASK & elem->channelNo;
if ( (maskedElemChannelNo == 0) && (channelNo != 0) ) {
XP_ASSERT( !comms->isServer ); XP_ASSERT( !comms->isServer );
XP_ASSERT( elem->msgID == 0 ); XP_ASSERT( elem->msgID == 0 );
} else if ( elem->channelNo != channelNo ) { } else if ( maskedElemChannelNo != maskedChannelNo ) {
knownGood = XP_TRUE; knownGood = XP_TRUE;
} }