mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-24 07:58:34 +01:00
try harder to respond to an intent with a rowID
Failure to immediately get a lock for a rowID in an intent meant that other intent processing kicked in, and might have done the wrong thing. So now if there's a rowid in it we try nothing else. And we use the GameLock callback mechanism to deal with the case where it's temporarily unavailable, as it will be when an incoming move is being dispatched to it.
This commit is contained in:
parent
4919f487eb
commit
10fff616ae
1 changed files with 61 additions and 29 deletions
|
@ -1014,6 +1014,7 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
@Override
|
@Override
|
||||||
protected void handleNewIntent( Intent intent )
|
protected void handleNewIntent( Intent intent )
|
||||||
{
|
{
|
||||||
|
Log.d( TAG, "handleNewIntent(extras={%s})", DbgUtils.extrasToString( intent ) );
|
||||||
m_launchedGames.clear();
|
m_launchedGames.clear();
|
||||||
Assert.assertNotNull( intent );
|
Assert.assertNotNull( intent );
|
||||||
invalRelayIDs( intent.getStringArrayExtra( RELAYIDS_EXTRA ) );
|
invalRelayIDs( intent.getStringArrayExtra( RELAYIDS_EXTRA ) );
|
||||||
|
@ -2130,35 +2131,44 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
return launched;
|
return launched;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startFirstHasDict( long rowid )
|
private boolean startFirstHasDict( final long rowid )
|
||||||
{
|
{
|
||||||
if ( -1 != rowid && DBUtils.haveGame( m_activity, rowid ) ) {
|
boolean handled = -1 != rowid && DBUtils.haveGame( m_activity, rowid );
|
||||||
boolean haveDict;
|
if ( handled ) {
|
||||||
try {
|
GameLock.getLockThen( rowid, 100L, m_handler,
|
||||||
haveDict = GameUtils.gameDictsHere( m_activity, rowid );
|
new GameLock.GotLockProc() {
|
||||||
} catch ( GameLock.GameLockedException
|
@Override
|
||||||
| GameUtils.NoSuchGameException gle ) {
|
public void gotLock( GameLock lock ) {
|
||||||
haveDict = true;
|
if ( lock != null ) {
|
||||||
}
|
boolean haveDict = GameUtils
|
||||||
|
.gameDictsHere( m_activity, lock );
|
||||||
|
lock.release();
|
||||||
if ( haveDict ) {
|
if ( haveDict ) {
|
||||||
launchGame( rowid );
|
launchGame( rowid );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
return handled;
|
||||||
|
}
|
||||||
|
|
||||||
private void startFirstHasDict( Intent intent )
|
private boolean startFirstHasDict( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean result = false;
|
||||||
if ( null != intent ) {
|
if ( null != intent ) {
|
||||||
String[] relayIDs = intent.getStringArrayExtra( RELAYIDS_EXTRA );
|
String[] relayIDs = intent.getStringArrayExtra( RELAYIDS_EXTRA );
|
||||||
if ( !startFirstHasDict( relayIDs ) ) {
|
if ( !startFirstHasDict( relayIDs ) ) {
|
||||||
long rowid = intent.getLongExtra( ROWID_EXTRA, -1 );
|
long rowid = intent.getLongExtra( ROWID_EXTRA, -1 );
|
||||||
startFirstHasDict( rowid );
|
result = startFirstHasDict( rowid );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startNewNetGame( NetLaunchInfo nli )
|
private boolean startNewNetGame( NetLaunchInfo nli )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
Assert.assertTrue( nli.isValid() );
|
Assert.assertTrue( nli.isValid() );
|
||||||
|
|
||||||
Date create = null;
|
Date create = null;
|
||||||
|
@ -2167,6 +2177,7 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
if ( null == create ) {
|
if ( null == create ) {
|
||||||
if ( checkWarnNoDict( nli ) ) {
|
if ( checkWarnNoDict( nli ) ) {
|
||||||
makeNewNetGame( nli );
|
makeNewNetGame( nli );
|
||||||
|
handled = true;
|
||||||
}
|
}
|
||||||
} else if ( XWPrefs.getSecondInviteAllowed( m_activity ) ) {
|
} else if ( XWPrefs.getSecondInviteAllowed( m_activity ) ) {
|
||||||
String msg = getString( R.string.dup_game_query_fmt,
|
String msg = getString( R.string.dup_game_query_fmt,
|
||||||
|
@ -2175,13 +2186,17 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
makeConfirmThenBuilder( msg, Action.NEW_NET_GAME )
|
makeConfirmThenBuilder( msg, Action.NEW_NET_GAME )
|
||||||
.setParams( nli )
|
.setParams( nli )
|
||||||
.show();
|
.show();
|
||||||
|
handled = true;
|
||||||
} else {
|
} else {
|
||||||
makeOkOnlyBuilder( R.string.dropped_dupe ).show();
|
makeOkOnlyBuilder( R.string.dropped_dupe ).show();
|
||||||
|
handled = true;
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
} // startNewNetGame
|
} // startNewNetGame
|
||||||
|
|
||||||
private void startNewNetGame( Intent intent )
|
private boolean startNewNetGame( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
NetLaunchInfo nli = null;
|
NetLaunchInfo nli = null;
|
||||||
if ( MultiService.isMissingDictIntent( intent ) ) {
|
if ( MultiService.isMissingDictIntent( intent ) ) {
|
||||||
nli = MultiService.getMissingDictData( m_activity, intent );
|
nli = MultiService.getMissingDictData( m_activity, intent );
|
||||||
|
@ -2192,34 +2207,43 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ( null != nli && nli.isValid() ) {
|
if ( null != nli && nli.isValid() ) {
|
||||||
startNewNetGame( nli );
|
handled = startNewNetGame( nli );
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
} // startNewNetGame
|
} // startNewNetGame
|
||||||
|
|
||||||
private void startHasGameID( int gameID )
|
private boolean startHasGameID( int gameID )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
long[] rowids = DBUtils.getRowIDsFor( m_activity, gameID );
|
long[] rowids = DBUtils.getRowIDsFor( m_activity, gameID );
|
||||||
if ( null != rowids && 0 < rowids.length ) {
|
if ( null != rowids && 0 < rowids.length ) {
|
||||||
launchGame( rowids[0] );
|
launchGame( rowids[0] );
|
||||||
|
handled = true;
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startHasGameID( Intent intent )
|
private boolean startHasGameID( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
int gameID = intent.getIntExtra( GAMEID_EXTRA, 0 );
|
int gameID = intent.getIntExtra( GAMEID_EXTRA, 0 );
|
||||||
if ( 0 != gameID ) {
|
if ( 0 != gameID ) {
|
||||||
startHasGameID( gameID );
|
handled = startHasGameID( gameID );
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new game that's a copy, sending invitations via the means it
|
// Create a new game that's a copy, sending invitations via the means it
|
||||||
// used to connect.
|
// used to connect.
|
||||||
private void startRematch( Intent intent )
|
private boolean startRematch( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
if ( -1 != intent.getLongExtra( REMATCH_ROWID_EXTRA, -1 ) ) {
|
if ( -1 != intent.getLongExtra( REMATCH_ROWID_EXTRA, -1 ) ) {
|
||||||
m_rematchExtras = intent.getExtras();
|
m_rematchExtras = intent.getExtras();
|
||||||
showDialogFragment( DlgID.GAMES_LIST_NAME_REMATCH );
|
showDialogFragment( DlgID.GAMES_LIST_NAME_REMATCH );
|
||||||
|
handled = true;
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startRematchWithName( final String gameName,
|
private void startRematchWithName( final String gameName,
|
||||||
|
@ -2298,8 +2322,9 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
m_rematchExtras = null;
|
m_rematchExtras = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void tryAlert( Intent intent )
|
private boolean tryAlert( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean handled = false;
|
||||||
String msg = intent.getStringExtra( ALERT_MSG );
|
String msg = intent.getStringExtra( ALERT_MSG );
|
||||||
if ( null != msg ) {
|
if ( null != msg ) {
|
||||||
DlgDelegate.DlgDelegateBuilder builder =
|
DlgDelegate.DlgDelegateBuilder builder =
|
||||||
|
@ -2309,18 +2334,23 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
R.string.board_menu_file_email );
|
R.string.board_menu_file_email );
|
||||||
}
|
}
|
||||||
builder.show();
|
builder.show();
|
||||||
|
handled = true;
|
||||||
}
|
}
|
||||||
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void tryNFCIntent( Intent intent )
|
private boolean tryNFCIntent( Intent intent )
|
||||||
{
|
{
|
||||||
|
boolean result = false;
|
||||||
String data = NFCUtils.getFromIntent( intent );
|
String data = NFCUtils.getFromIntent( intent );
|
||||||
if ( null != data ) {
|
if ( null != data ) {
|
||||||
NetLaunchInfo nli = NetLaunchInfo.makeFrom( m_activity, data );
|
NetLaunchInfo nli = NetLaunchInfo.makeFrom( m_activity, data );
|
||||||
if ( nli.isValid() ) {
|
if ( nli.isValid() ) {
|
||||||
startNewNetGame( nli );
|
startNewNetGame( nli );
|
||||||
|
result = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void askDefaultName()
|
private void askDefaultName()
|
||||||
|
@ -2533,12 +2563,14 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
private void tryStartsFromIntent( Intent intent )
|
private void tryStartsFromIntent( Intent intent )
|
||||||
{
|
{
|
||||||
Log.d( TAG, "tryStartsFromIntent(extras={%s})", DbgUtils.extrasToString( intent ) );
|
Log.d( TAG, "tryStartsFromIntent(extras={%s})", DbgUtils.extrasToString( intent ) );
|
||||||
startFirstHasDict( intent );
|
boolean handled = startFirstHasDict( intent )
|
||||||
startNewNetGame( intent );
|
|| startNewNetGame( intent )
|
||||||
startHasGameID( intent );
|
|| startHasGameID( intent )
|
||||||
startRematch( intent );
|
|| startRematch( intent )
|
||||||
tryAlert( intent );
|
|| tryAlert( intent )
|
||||||
tryNFCIntent( intent );
|
|| tryNFCIntent( intent )
|
||||||
|
;
|
||||||
|
Log.d( TAG, "tryStartsFromIntent() => handled: %b", handled );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doOpenGame( Object[] params )
|
private void doOpenGame( Object[] params )
|
||||||
|
|
Loading…
Add table
Reference in a new issue