mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
preexisting db field now a set, so treat it that way in the other place it's read
This commit is contained in:
parent
4e37947d94
commit
df093e1c10
2 changed files with 20 additions and 9 deletions
|
@ -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;
|
||||||
|
|
|
@ -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() ) {
|
||||||
|
|
Loading…
Reference in a new issue