From 88dd25fb21ea8fa3724fe4f4ef60851c98f263d4 Mon Sep 17 00:00:00 2001 From: Eric House Date: Sun, 8 Feb 2015 13:39:35 -0800 Subject: [PATCH] fix channel comparison so messages actually get deleted after they're ack'd. --- xwords4/common/comms.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/xwords4/common/comms.c b/xwords4/common/comms.c index a268b6c50..b4d4b9f20 100644 --- a/xwords4/common/comms.c +++ b/xwords4/common/comms.c @@ -1260,6 +1260,7 @@ removeFromQueue( CommsCtxt* comms, XP_PlayerAddr channelNo, MsgID msgID ) comms->msgQueueHead = comms->msgQueueTail = NULL; comms->queueLen = 0; + XP_PlayerAddr maskedChannelNo = ~CHANNEL_MASK & channelNo; for ( ; !!elem; elem = next ) { XP_Bool knownGood = XP_FALSE; 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 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( elem->msgID == 0 ); - } else if ( elem->channelNo != channelNo ) { + } else if ( maskedElemChannelNo != maskedChannelNo ) { knownGood = XP_TRUE; }