wifi tweaks

Show net status as failing when no sockets available, and notice when
they're closed.
This commit is contained in:
Eric House 2016-11-17 23:22:28 -08:00
parent 4389c63718
commit 930146cf11
2 changed files with 24 additions and 5 deletions

View file

@ -133,7 +133,7 @@ public class BiDiSockWrap {
DbgUtils.logex( ioe ); DbgUtils.logex( ioe );
} }
mIface.connectStateChanged( this, false ); mIface.connectStateChanged( this, false );
mQueue.add(null); mQueue.add( new byte[0] );
} }
private void startThreads() private void startThreads()
@ -150,7 +150,8 @@ public class BiDiSockWrap {
DbgUtils.logd( BiDiSockWrap.class, DbgUtils.logd( BiDiSockWrap.class,
"write thread got packet of len %d", "write thread got packet of len %d",
packet.length ); packet.length );
if ( null == packet || 0 == packet.length ) { Assert.assertNotNull( packet );
if ( 0 == packet.length ) {
closeSocket(); closeSocket();
break; break;
} }

View file

@ -192,9 +192,10 @@ public class WiDirService extends XWService {
public static String formatNetStateInfo() public static String formatNetStateInfo()
{ {
return String.format( "name: %s; mac: %s; role: %s", return String.format( "name: %s; mac: %s; role: %s; nThreads: %d",
sDeviceName, getMyMacAddress(), sDeviceName, getMyMacAddress(),
sAmServer ? "group owner" : "guest" ); sAmServer ? "owner" : "guest",
Thread.activeCount() );
} }
private static String getMyMacAddress() { return getMyMacAddress(null); } private static String getMyMacAddress() { return getMyMacAddress(null); }
@ -232,6 +233,7 @@ public class WiDirService extends XWService {
public static int sendPacket( Context context, String macAddr, int gameID, public static int sendPacket( Context context, String macAddr, int gameID,
byte[] buf ) byte[] buf )
{ {
DbgUtils.logd( CLAZZ, "sendPacket(len=%d,addr=%s)", buf.length, macAddr );
int nSent = -1; int nSent = -1;
boolean[] forwarding = { false }; boolean[] forwarding = { false };
@ -314,6 +316,7 @@ public class WiDirService extends XWService {
public void connectStateChanged( BiDiSockWrap wrap, boolean nowConnected ) public void connectStateChanged( BiDiSockWrap wrap, boolean nowConnected )
{ {
DbgUtils.logd( CLAZZ, "connectStateChanged(con=%b)", nowConnected );
if ( nowConnected ) { if ( nowConnected ) {
try { try {
wrap.send( new JSONObject() wrap.send( new JSONObject()
@ -323,6 +326,15 @@ public class WiDirService extends XWService {
} catch ( JSONException jse ) { } catch ( JSONException jse ) {
DbgUtils.logex( jse ); DbgUtils.logex( jse );
} }
} else {
int sizeBefore = sSocketWrapMap.size();
sSocketWrapMap.values().remove( wrap );
DbgUtils.logd( CLAZZ, "removed wrap; had %d, now have %d",
sizeBefore, sSocketWrapMap.size() );
if ( 0 == sSocketWrapMap.size() ) {
updateStatusIn( false );
updateStatusOut( false );
}
} }
} }
@ -357,6 +369,7 @@ public class WiDirService extends XWService {
} }
} }
} }
DbgUtils.logd( CLAZZ, "thread count: %d", Thread.activeCount() );
new Handler().postDelayed( new Runnable() { new Handler().postDelayed( new Runnable() {
@Override @Override
public void run() { public void run() {
@ -470,7 +483,9 @@ public class WiDirService extends XWService {
discoverServices(); discoverServices();
} }
@Override @Override
public void onFailure(int code) { Assert.fail(); } public void onFailure(int code) {
tryAgain( "discoverPeers", code );
}
} ); } );
} }
@ -788,6 +803,9 @@ public class WiDirService extends XWService {
forwarding[0] = true; forwarding[0] = true;
} }
if ( null == wrap ) {
updateStatusOut( false );
}
return wrap; return wrap;
} }