From ea03f968815f1af71b9f447836c231dd4f505d35 Mon Sep 17 00:00:00 2001 From: eihrul Date: Fri, 12 Oct 2007 17:37:31 +0000 Subject: *** empty log message *** --- protocol.c | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) (limited to 'protocol.c') diff --git a/protocol.c b/protocol.c index e426243..3173fe0 100644 --- a/protocol.c +++ b/protocol.c @@ -163,8 +163,6 @@ enet_protocol_remove_sent_reliable_command (ENetPeer * peer, enet_uint16 reliabl ENetOutgoingCommand * outgoingCommand; ENetListIterator currentCommand; ENetProtocolCommand commandNumber; - ENetChannel * channel; - enet_uint16 reliableWindow; for (currentCommand = enet_list_begin (& peer -> sentReliableCommands); currentCommand != enet_list_end (& peer -> sentReliableCommands); @@ -180,13 +178,16 @@ enet_protocol_remove_sent_reliable_command (ENetPeer * peer, enet_uint16 reliabl if (currentCommand == enet_list_end (& peer -> sentReliableCommands)) return ENET_PROTOCOL_COMMAND_NONE; - reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - channel = & peer -> channels [channelID]; - if (channel -> reliableWindows [reliableWindow] > 0) + if (channelID < peer -> channelCount) { - -- channel -> reliableWindows [reliableWindow]; - if (! channel -> reliableWindows [reliableWindow]) - channel -> usedReliableWindows &= ~ (1 << reliableWindow); + ENetChannel * channel = & peer -> channels [channelID]; + enet_uint16 reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; + if (channel -> reliableWindows [reliableWindow] > 0) + { + -- channel -> reliableWindows [reliableWindow]; + if (! channel -> reliableWindows [reliableWindow]) + channel -> usedReliableWindows &= ~ (1 << reliableWindow); + } } commandNumber = outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK; -- cgit v1.2.3