oops: save outgoing UDP acks, not web ones

Incorrect ! meant that outbound ACKs were saved for web sends rather
than UDP and so couldn't be resent in the case where fallback to web was
needed.
This commit is contained in:
Eric House 2017-12-27 12:30:02 -08:00
parent 10df914897
commit de691af7ca

View file

@ -768,9 +768,8 @@ public class RelayService extends XWService
private long m_lastRunMS = 0; private long m_lastRunMS = 0;
private void runUDPAckTimer() private void runUDPAckTimer()
{ {
Log.d( TAG, "runUDPAckTimer()" );
long nowMS = System.currentTimeMillis(); long nowMS = System.currentTimeMillis();
if ( m_lastRunMS + 3000 > nowMS ) { if ( m_lastRunMS + 3000 > nowMS ) { // never more frequently than 3 sec.
// Log.d( TAG, "runUDPAckTimer(): too soon, so skipping" ); // Log.d( TAG, "runUDPAckTimer(): too soon, so skipping" );
} else { } else {
m_lastRunMS = nowMS; m_lastRunMS = nowMS;
@ -814,9 +813,9 @@ public class RelayService extends XWService
private void noteSent( PacketData packet, boolean fromUDP ) private void noteSent( PacketData packet, boolean fromUDP )
{ {
Log.d( TAG, "Sent [udp?] packet: cmd=%s, id=%d", Log.d( TAG, "Sent (fromUDP=%b) packet: cmd=%s, id=%d",
packet.m_cmd.toString(), packet.m_packetID ); fromUDP, packet.m_cmd.toString(), packet.m_packetID );
if ( !fromUDP || packet.m_cmd != XWRelayReg.XWPDEV_ACK ) { if ( fromUDP || packet.m_cmd != XWRelayReg.XWPDEV_ACK ) {
List<PacketData> list = fromUDP ? s_packetsSentUDP : s_packetsSentWeb; List<PacketData> list = fromUDP ? s_packetsSentUDP : s_packetsSentWeb;
synchronized( list ) { synchronized( list ) {
list.add(packet ); list.add(packet );
@ -827,12 +826,12 @@ public class RelayService extends XWService
private void noteSent( List<PacketData> packets, boolean fromUDP ) private void noteSent( List<PacketData> packets, boolean fromUDP )
{ {
List<PacketData> map = fromUDP ? s_packetsSentUDP : s_packetsSentWeb; List<PacketData> map = fromUDP ? s_packetsSentUDP : s_packetsSentWeb;
Log.d( TAG, "noteSent(): adding %d; size before: %d", Log.d( TAG, "noteSent(fromUDP=%b): adding %d; size before: %d",
packets.size(), map.size() ); fromUDP, packets.size(), map.size() );
for ( PacketData packet : packets ) { for ( PacketData packet : packets ) {
noteSent( packet, fromUDP ); noteSent( packet, fromUDP );
} }
Log.d( TAG, "noteSent(): size after: %d", map.size() ); Log.d( TAG, "noteSent(fromUDP=%b): size after: %d", fromUDP, map.size() );
} }
private void stopUDPThreadsIf() private void stopUDPThreadsIf()