preexisting db field now a set, so treat it that way in the other place it's read

This commit is contained in:
Eric House 2014-10-17 07:55:04 -07:00
parent 4e37947d94
commit df093e1c10
2 changed files with 20 additions and 9 deletions

View file

@ -522,10 +522,10 @@ public class DBUtils {
return result; return result;
} }
public static HashMap<Long,CommsConnType> public static HashMap<Long,CommsConnTypeSet>
getGamesWithSendsPending( Context context ) getGamesWithSendsPending( Context context )
{ {
HashMap<Long, CommsConnType> result = new HashMap<Long,CommsConnType>(); HashMap<Long, CommsConnTypeSet> result = new HashMap<Long,CommsConnTypeSet>();
String[] columns = { ROW_ID, DBHelper.CONTYPE }; String[] columns = { ROW_ID, DBHelper.CONTYPE };
String selection = String.format( "%s > 0", DBHelper.NPACKETSPENDING ); String selection = String.format( "%s > 0", DBHelper.NPACKETSPENDING );
initDB( context ); initDB( context );
@ -537,8 +537,10 @@ public class DBUtils {
int indx2 = cursor.getColumnIndex( DBHelper.CONTYPE ); int indx2 = cursor.getColumnIndex( DBHelper.CONTYPE );
for ( int ii = 0; cursor.moveToNext(); ++ii ) { for ( int ii = 0; cursor.moveToNext(); ++ii ) {
long rowid = cursor.getLong( indx1 ); long rowid = cursor.getLong( indx1 );
CommsConnType typ = CommsConnType.values()[cursor.getInt(indx2)]; CommsConnTypeSet typs = intToConnTypeSet( cursor.getInt(indx2) );
result.put( rowid, typ ); // Better have an address if has pending sends
Assert.assertTrue( 0 < typs.size() );
result.put( rowid, typs );
} }
cursor.close(); cursor.close();
db.close(); db.close();
@ -2134,6 +2136,7 @@ public class DBUtils {
private static final int BIT_VECTOR_MASK = 0x8000; private static final int BIT_VECTOR_MASK = 0x8000;
private static CommsConnTypeSet intToConnTypeSet( int asInt ) private static CommsConnTypeSet intToConnTypeSet( int asInt )
{ {
DbgUtils.logf( "intToConnTypeSet(in: %s)", asInt );
CommsConnTypeSet result = new CommsConnTypeSet(); CommsConnTypeSet result = new CommsConnTypeSet();
boolean isVector = 0 != (BIT_VECTOR_MASK & asInt); boolean isVector = 0 != (BIT_VECTOR_MASK & asInt);
asInt &= ~BIT_VECTOR_MASK; asInt &= ~BIT_VECTOR_MASK;
@ -2142,6 +2145,7 @@ public class DBUtils {
for ( CommsConnType value : values ) { for ( CommsConnType value : values ) {
int ord = value.ordinal(); int ord = value.ordinal();
if ( 0 != (asInt & (1 << (ord - 1)))) { if ( 0 != (asInt & (1 << (ord - 1)))) {
DbgUtils.logf( "intToConnTypeSet: adding %s", value.toString() );
result.add( value ); result.add( value );
} }
} }
@ -2153,9 +2157,11 @@ public class DBUtils {
private static int connTypeSetToInt( CommsConnTypeSet set ) private static int connTypeSetToInt( CommsConnTypeSet set )
{ {
DbgUtils.logf( "connTypeSetToInt(setSize: %d)", set.size() );
int result = BIT_VECTOR_MASK; int result = BIT_VECTOR_MASK;
for ( Iterator<CommsConnType> iter = set.iterator(); iter.hasNext(); ) { for ( Iterator<CommsConnType> iter = set.iterator(); iter.hasNext(); ) {
CommsConnType typ = iter.next(); CommsConnType typ = iter.next();
DbgUtils.logf( "connTypeSetToInt: adding %s", typ.toString() );
result |= 1 << (typ.ordinal() - 1); result |= 1 << (typ.ordinal() - 1);
} }
return result; return result;

View file

@ -46,6 +46,7 @@ import junit.framework.Assert;
import org.eehouse.android.xw4.jni.*; import org.eehouse.android.xw4.jni.*;
import org.eehouse.android.xw4.loc.LocUtils; import org.eehouse.android.xw4.loc.LocUtils;
import org.eehouse.android.xw4.jni.CommsAddrRec.CommsConnType; import org.eehouse.android.xw4.jni.CommsAddrRec.CommsConnType;
import org.eehouse.android.xw4.jni.CommsAddrRec.CommsConnTypeSet;
import org.eehouse.android.xw4.jni.CurGameInfo.DeviceRole; import org.eehouse.android.xw4.jni.CurGameInfo.DeviceRole;
import org.eehouse.android.xw4.jni.LastMoveInfo; import org.eehouse.android.xw4.jni.LastMoveInfo;
@ -391,7 +392,8 @@ public class GameUtils {
} }
if ( force ) { if ( force ) {
HashMap<Long,CommsConnType> games = DBUtils.getGamesWithSendsPending( context ); HashMap<Long,CommsConnTypeSet> games =
DBUtils.getGamesWithSendsPending( context );
if ( 0 < games.size() ) { if ( 0 < games.size() ) {
new ResendTask( context, games, filter, showUI ).execute(); new ResendTask( context, games, filter, showUI ).execute();
} }
@ -1076,12 +1078,12 @@ public class GameUtils {
private static class ResendTask extends AsyncTask<Void, Void, Void> { private static class ResendTask extends AsyncTask<Void, Void, Void> {
private Context m_context; private Context m_context;
private HashMap<Long,CommsConnType> m_games; private HashMap<Long,CommsConnTypeSet> m_games;
private boolean m_showUI; private boolean m_showUI;
private CommsConnType m_filter; private CommsConnType m_filter;
private int m_nSent = 0; private int m_nSent = 0;
public ResendTask( Context context, HashMap<Long,CommsConnType> games, public ResendTask( Context context, HashMap<Long,CommsConnTypeSet> games,
CommsConnType filter, boolean showUI ) CommsConnType filter, boolean showUI )
{ {
m_context = context; m_context = context;
@ -1096,9 +1098,12 @@ public class GameUtils {
Iterator<Long> iter = m_games.keySet().iterator(); Iterator<Long> iter = m_games.keySet().iterator();
while ( iter.hasNext() ) { while ( iter.hasNext() ) {
long rowid = iter.next(); long rowid = iter.next();
if ( null != m_filter && m_filter != m_games.get( rowid ) ) { if ( null != m_filter ) {
CommsConnTypeSet gameSet = m_games.get( rowid );
if ( gameSet != null && ! gameSet.contains( m_filter ) ) {
continue; continue;
} }
}
GameLock lock = new GameLock( rowid, false ); GameLock lock = new GameLock( rowid, false );
if ( lock.tryLock() ) { if ( lock.tryLock() ) {