From 9b01d044f19fc0246253896256b3f681308526b5 Mon Sep 17 00:00:00 2001 From: Eric House Date: Thu, 16 May 2019 12:23:33 -0700 Subject: [PATCH] try to fix assertion by catching null UDP socket I think there's a rare race condition here. Assuming it results from a bad network state rather than two sends coming too quickly, respond to not having a connection by killing the thread so the next send will retry. --- .../org/eehouse/android/xw4/RelayService.java | 20 +++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/RelayService.java b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/RelayService.java index 554fbc048..64600df3d 100644 --- a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/RelayService.java +++ b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/RelayService.java @@ -360,6 +360,7 @@ public class RelayService extends XWJIService m_handler = new Handler(); m_onInactivity = new Runnable() { + @Override public void run() { // Log.d( TAG, "m_onInactivity fired" ); if ( !shouldMaintainConnection() ) { @@ -733,6 +734,7 @@ public class RelayService extends XWJIService closeUDPSocket( udpSocket ); service.m_handler.post( new Runnable() { + @Override public void run() { service.stopUDPReadThread(); } @@ -811,19 +813,22 @@ public class RelayService extends XWJIService synchronized ( sUDPReadThreadRef ) { thread = sUDPReadThreadRef.get(); if ( null == thread ) { - thread = new UDPReadThread(); + thread = new UDPReadThread( this ); sUDPReadThreadRef.set( thread ); thread.start(); + } else if ( null != s_UDPSocket ) { + thread.setService( this ); } else { - Assert.assertTrue( null != s_UDPSocket || !BuildConfig.DEBUG ); + Log.e( TAG, "startUDPReadThreadOnce(): s_UDPSocket NULL" ); + stopUDPReadThread(); + thread = null; } - thread.setService( this ); } } else { - Log.i( TAG, "startUDPThreadsOnce(): UDP disabled" ); + Log.i( TAG, "startUDPReadThreadOnce(): UDP disabled" ); } return thread; - } // startUDPThreadsOnce + } // startUDPReadThreadOnce private void stopUDPReadThread() { @@ -1265,7 +1270,10 @@ public class RelayService extends XWJIService private static class UDPReadThread extends Thread { private RelayService[] mServiceHolder = {null}; - UDPReadThread() { super("UDPReadThread"); } + UDPReadThread( RelayService service ) { + super( "UDPReadThread" ); + setService( service ); + } void setService( RelayService service ) {