From 162ab11f12e100706d881911558b75e94800a9f7 Mon Sep 17 00:00:00 2001 From: Eric House Date: Mon, 21 Dec 2015 15:56:52 -0800 Subject: [PATCH] fix, at least for most cases, Marshmallow change that doesn't let an app know the BT/Mac addr of its own interface. The new bogus addr is transmitted in common/ structs, and so sending code need to look up by name when told to use that address. --- .../org/eehouse/android/xw4/BTService.java | 34 +++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/xwords4/android/XWords4/src/org/eehouse/android/xw4/BTService.java b/xwords4/android/XWords4/src/org/eehouse/android/xw4/BTService.java index eb4394996..e4c4070c8 100644 --- a/xwords4/android/XWords4/src/org/eehouse/android/xw4/BTService.java +++ b/xwords4/android/XWords4/src/org/eehouse/android/xw4/BTService.java @@ -42,6 +42,7 @@ import java.util.Iterator; import java.util.LinkedList; import java.util.ListIterator; import java.util.Map.Entry; +import java.util.Map; import java.util.Set; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.TimeUnit; @@ -56,6 +57,7 @@ import org.eehouse.android.xw4.loc.LocUtils; import junit.framework.Assert; public class BTService extends XWService { + private static final String BOGUS_MARSHMALLOW_ADDR = "02:00:00:00:00:00"; private static final long RESEND_TIMEOUT = 5; // seconds private static final int MAX_SEND_FAIL = 3; @@ -644,6 +646,29 @@ public class BTService extends XWService { return m_addrs.contains( btAddr ); } + private static Map s_namesToAddrs; + private String lookupAddr( String btName ) + { + if ( null == s_namesToAddrs ) { + s_namesToAddrs = new HashMap(); + } + if ( ! s_namesToAddrs.containsKey( btName ) ) { + BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter(); + if ( null != adapter ) { + Set devs = adapter.getBondedDevices(); + Iterator iter = devs.iterator(); + while ( iter.hasNext() ) { + BluetoothDevice dev = iter.next(); + s_namesToAddrs.put( dev.getName(), dev.getAddress() ); + } + } + } + + String result = s_namesToAddrs.get( btName ); + DbgUtils.logf( "lookupAddr(%s) => %s", btName, result ); + return result; + } + private void clearDevs( String[] btAddrs ) { if ( null != btAddrs ) { @@ -1191,9 +1216,14 @@ public class BTService extends XWService { @Override public int sendViaBluetooth( byte[] buf, int gameID, CommsAddrRec addr ) { + String btAddr = addr.bt_btAddr; + if ( BOGUS_MARSHMALLOW_ADDR.equals( btAddr ) ) { + btAddr = lookupAddr( addr.bt_hostName ); + } + Assert.assertTrue( addr.contains( CommsConnType.COMMS_CONN_BT ) ); - m_sender.add( new BTQueueElem( BTCmd.MESG_SEND, buf, - addr.bt_btAddr, gameID ) ); + m_sender.add( new BTQueueElem( BTCmd.MESG_SEND, buf, + btAddr, gameID ) ); return buf.length; } }