mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-09 05:24:44 +01:00
stop referring to this in AlertDialog buttons
There's a problem in dual-pane mode where activites outlive DelegateBase instances that are tied to fragments. AlertDialogs, being bound to the MainActivity, can sometimes outlive the delegates that create them, meaning the 'this' referred to from closures bound to onClick() handlers can come to be invalid (e.g. referencing a removed fragment). So add a global registry of current DelegateBase instances by class, and from onClick() handlers fetch and use the current instance instead of the 'this' that's bound.
This commit is contained in:
parent
aef95ae498
commit
7634c425ef
7 changed files with 175 additions and 111 deletions
|
@ -181,7 +181,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
handleViaThread( JNICmd.CMD_RESET );
|
curThis().handleViaThread( JNICmd.CMD_RESET );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( R.string.button_retry, lstnr );
|
ab.setNegativeButton( R.string.button_retry, lstnr );
|
||||||
|
@ -190,7 +190,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
doRematchIf();
|
curThis().doRematchIf();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( R.string.button_rematch, lstnr );
|
ab.setNegativeButton( R.string.button_rematch, lstnr );
|
||||||
|
@ -215,14 +215,14 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
|
BoardDelegate self = curThis();
|
||||||
if ( DlgID.DLG_USEDICT == dlgID ) {
|
if ( DlgID.DLG_USEDICT == dlgID ) {
|
||||||
setGotGameDict( m_getDict );
|
self.setGotGameDict( m_getDict );
|
||||||
} else {
|
} else {
|
||||||
DwnldDelegate
|
DwnldDelegate
|
||||||
.downloadDictInBack( m_activity,
|
.downloadDictInBack( self.m_activity,
|
||||||
m_gi.dictLang,
|
self.m_gi.dictLang,
|
||||||
m_getDict,
|
self.m_getDict, self );
|
||||||
BoardDelegate.this );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -241,7 +241,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
deleteAndClose();
|
curThis().deleteAndClose();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( R.string.button_delete, lstnr );
|
ab.setNegativeButton( R.string.button_delete, lstnr );
|
||||||
|
@ -259,7 +259,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
m_resultCode = 1;
|
curThis().m_resultCode = 1;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setPositiveButton( DlgID.QUERY_REQUEST_BLK == dlgID ?
|
ab.setPositiveButton( DlgID.QUERY_REQUEST_BLK == dlgID ?
|
||||||
|
@ -269,7 +269,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
m_resultCode = 0;
|
curThis().m_resultCode = 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( R.string.button_no, lstnr );
|
ab.setNegativeButton( R.string.button_no, lstnr );
|
||||||
|
@ -290,10 +290,11 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
showNotAgainDlgThen( R.string.not_again_lookup,
|
curThis().
|
||||||
R.string.
|
showNotAgainDlgThen( R.string.not_again_lookup,
|
||||||
key_na_lookup,
|
R.string.
|
||||||
Action.LOOKUP_ACTION );
|
key_na_lookup,
|
||||||
|
Action.LOOKUP_ACTION );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( buttonTxt, lstnr );
|
ab.setNegativeButton( buttonTxt, lstnr );
|
||||||
|
@ -309,7 +310,7 @@ public class BoardDelegate extends DelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int item ) {
|
int item ) {
|
||||||
m_resultCode = item;
|
curThis().m_resultCode = item;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setItems( m_texts, lstnr );
|
ab.setItems( m_texts, lstnr );
|
||||||
|
@ -322,8 +323,9 @@ public class BoardDelegate extends DelegateBase
|
||||||
OnClickListener undoClicked = new OnClickListener() {
|
OnClickListener undoClicked = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
m_resultCode = UtilCtxt.PICKER_BACKUP;
|
BoardDelegate self = curThis();
|
||||||
removeDialog( dlgID );
|
self.m_resultCode = UtilCtxt.PICKER_BACKUP;
|
||||||
|
self.removeDialog( dlgID );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setPositiveButton( R.string.tilepick_undo,
|
ab.setPositiveButton( R.string.tilepick_undo,
|
||||||
|
@ -332,8 +334,9 @@ public class BoardDelegate extends DelegateBase
|
||||||
OnClickListener doAllClicked = new OnClickListener() {
|
OnClickListener doAllClicked = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
m_resultCode = UtilCtxt.PICKER_PICKALL;
|
BoardDelegate self = curThis();
|
||||||
removeDialog( dlgID );
|
self.m_resultCode = UtilCtxt.PICKER_PICKALL;
|
||||||
|
self.removeDialog( dlgID );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNegativeButton( R.string.tilepick_all, doAllClicked );
|
ab.setNegativeButton( R.string.tilepick_all, doAllClicked );
|
||||||
|
@ -379,32 +382,34 @@ public class BoardDelegate extends DelegateBase
|
||||||
break;
|
break;
|
||||||
case DLG_INVITE:
|
case DLG_INVITE:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog, int item ){
|
||||||
int item ) {
|
BoardDelegate self = curThis();
|
||||||
if ( !m_relayMissing ||
|
if ( !self.m_relayMissing ||
|
||||||
! m_connTypes.contains(CommsConnType.COMMS_CONN_RELAY) ) {
|
! self.m_connTypes.contains(CommsConnType.COMMS_CONN_RELAY) ) {
|
||||||
Assert.assertTrue( 0 < m_nMissing );
|
Assert.assertTrue( 0 < self.m_nMissing );
|
||||||
if ( m_summary.hasRematchInfo() ) {
|
if ( self.m_summary.hasRematchInfo() ) {
|
||||||
tryRematchInvites( true );
|
self.tryRematchInvites( true );
|
||||||
} else {
|
} else {
|
||||||
showInviteChoicesThen( Action.LAUNCH_INVITE_ACTION,
|
self.showInviteChoicesThen( Action.LAUNCH_INVITE_ACTION,
|
||||||
m_sentInfo );
|
self.m_sentInfo );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
askDropRelay();
|
self.askDropRelay();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
OnClickListener lstnrWait = new OnClickListener() {
|
OnClickListener lstnrWait = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int item ) {
|
int item ) {
|
||||||
finish();
|
curThis().finish();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
OnClickListener lstnrMore = new OnClickListener() {
|
OnClickListener lstnrMore = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dialog,
|
public void onClick( DialogInterface dialog,
|
||||||
int item ) {
|
int item ) {
|
||||||
showOKOnlyDialog( m_sentInfo.getAsText( m_activity ) );
|
BoardDelegate self = curThis();
|
||||||
|
self.showOKOnlyDialog( self.m_sentInfo
|
||||||
|
.getAsText( self.m_activity ) );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1384,6 +1389,12 @@ public class BoardDelegate extends DelegateBase
|
||||||
return m_handler;
|
return m_handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected BoardDelegate curThis()
|
||||||
|
{
|
||||||
|
return (BoardDelegate)super.curThis();
|
||||||
|
}
|
||||||
|
|
||||||
private void deleteAndClose()
|
private void deleteAndClose()
|
||||||
{
|
{
|
||||||
GameUtils.deleteGame( m_activity, m_gameLock, false );
|
GameUtils.deleteGame( m_activity, m_gameLock, false );
|
||||||
|
|
|
@ -38,7 +38,11 @@ import android.view.ViewGroup;
|
||||||
import android.widget.CheckBox;
|
import android.widget.CheckBox;
|
||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import java.lang.ref.WeakReference;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.eehouse.android.xw4.DlgDelegate.Action;
|
import org.eehouse.android.xw4.DlgDelegate.Action;
|
||||||
import org.eehouse.android.xw4.DlgDelegate.ActionPair;
|
import org.eehouse.android.xw4.DlgDelegate.ActionPair;
|
||||||
|
@ -60,6 +64,8 @@ public class DelegateBase implements DlgClickNotify,
|
||||||
private View m_rootView;
|
private View m_rootView;
|
||||||
private boolean m_isVisible;
|
private boolean m_isVisible;
|
||||||
private ArrayList<Runnable> m_visibleProcs = new ArrayList<Runnable>();
|
private ArrayList<Runnable> m_visibleProcs = new ArrayList<Runnable>();
|
||||||
|
private static Map<Class, WeakReference<DelegateBase>> s_instances
|
||||||
|
= new HashMap<Class, WeakReference<DelegateBase>>();
|
||||||
|
|
||||||
public DelegateBase( Delegator delegator, Bundle bundle, int layoutID )
|
public DelegateBase( Delegator delegator, Bundle bundle, int layoutID )
|
||||||
{
|
{
|
||||||
|
@ -117,6 +123,8 @@ public class DelegateBase implements DlgClickNotify,
|
||||||
|
|
||||||
protected void onResume()
|
protected void onResume()
|
||||||
{
|
{
|
||||||
|
Assert.assertFalse( s_instances.containsKey(getClass()) );
|
||||||
|
s_instances.put( getClass(), new WeakReference<DelegateBase>(this) );
|
||||||
m_isVisible = true;
|
m_isVisible = true;
|
||||||
XWService.setListener( this );
|
XWService.setListener( this );
|
||||||
runIfVisible();
|
runIfVisible();
|
||||||
|
@ -124,10 +132,19 @@ public class DelegateBase implements DlgClickNotify,
|
||||||
|
|
||||||
protected void onPause()
|
protected void onPause()
|
||||||
{
|
{
|
||||||
|
s_instances.remove( getClass() );
|
||||||
m_isVisible = false;
|
m_isVisible = false;
|
||||||
XWService.setListener( null );
|
XWService.setListener( null );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected DelegateBase curThis()
|
||||||
|
{
|
||||||
|
WeakReference<DelegateBase> ref = s_instances.get( getClass() );
|
||||||
|
DelegateBase result = ref.get();
|
||||||
|
DbgUtils.logf( "%s.curThis() => %s", this.toString(), result.toString() );
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean onCreateOptionsMenu( Menu menu, MenuInflater inflater )
|
public boolean onCreateOptionsMenu( Menu menu, MenuInflater inflater )
|
||||||
{
|
{
|
||||||
boolean handled = 0 < m_optionsMenuID;
|
boolean handled = 0 < m_optionsMenuID;
|
||||||
|
|
|
@ -382,19 +382,20 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
|
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
DictLoc toLoc = itemToRealLoc( moveTo[0] );
|
DictsDelegate self = curThis();
|
||||||
|
DictLoc toLoc = self.itemToRealLoc( moveTo[0] );
|
||||||
for ( XWListItem selItem : selItems ) {
|
for ( XWListItem selItem : selItems ) {
|
||||||
DictLoc fromLoc = (DictLoc)selItem.getCached();
|
DictLoc fromLoc = (DictLoc)selItem.getCached();
|
||||||
String name = selItem.getText();
|
String name = selItem.getText();
|
||||||
if ( fromLoc == toLoc ) {
|
if ( fromLoc == toLoc ) {
|
||||||
DbgUtils.logf( "not moving %s: same loc", name );
|
DbgUtils.logf( "not moving %s: same loc", name );
|
||||||
} else if ( DictUtils.moveDict( m_activity,
|
} else if ( DictUtils.moveDict( self.m_activity,
|
||||||
name, fromLoc,
|
name, fromLoc,
|
||||||
toLoc ) ) {
|
toLoc ) ) {
|
||||||
selItem.setComment( m_locNames[toLoc.ordinal()] );
|
selItem.setComment( self.m_locNames[toLoc.ordinal()] );
|
||||||
selItem.setCached( toLoc );
|
selItem.setCached( toLoc );
|
||||||
selItem.invalidate();
|
selItem.invalidate();
|
||||||
DBUtils.dictsMoveInfo( m_activity, name,
|
DBUtils.dictsMoveInfo( self.m_activity, name,
|
||||||
fromLoc, toLoc );
|
fromLoc, toLoc );
|
||||||
} else {
|
} else {
|
||||||
DbgUtils.logf( "moveDict(%s) failed", name );
|
DbgUtils.logf( "moveDict(%s) failed", name );
|
||||||
|
@ -416,15 +417,16 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
final XWListItem row = m_selDicts.values().iterator().next();
|
final XWListItem row = m_selDicts.values().iterator().next();
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
|
DictsDelegate self = curThis();
|
||||||
if ( DialogInterface.BUTTON_NEGATIVE == item
|
if ( DialogInterface.BUTTON_NEGATIVE == item
|
||||||
|| DialogInterface.BUTTON_POSITIVE == item ) {
|
|| DialogInterface.BUTTON_POSITIVE == item ) {
|
||||||
setDefault( row, R.string.key_default_dict,
|
self.setDefault( row, R.string.key_default_dict,
|
||||||
R.string.key_default_robodict );
|
R.string.key_default_robodict );
|
||||||
}
|
}
|
||||||
if ( DialogInterface.BUTTON_NEGATIVE == item
|
if ( DialogInterface.BUTTON_NEGATIVE == item
|
||||||
|| DialogInterface.BUTTON_NEUTRAL == item ) {
|
|| DialogInterface.BUTTON_NEUTRAL == item ) {
|
||||||
setDefault( row, R.string.key_default_robodict,
|
self.setDefault( row, R.string.key_default_robodict,
|
||||||
R.string.key_default_dict );
|
R.string.key_default_dict );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -444,18 +446,18 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
case DICT_OR_DECLINE:
|
case DICT_OR_DECLINE:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
Intent intent = getIntent();
|
DictsDelegate self = curThis();
|
||||||
|
Intent intent = self.getIntent();
|
||||||
int lang = intent.getIntExtra( MultiService.LANG, -1 );
|
int lang = intent.getIntExtra( MultiService.LANG, -1 );
|
||||||
String name = intent.getStringExtra( MultiService.DICT );
|
String name = intent.getStringExtra( MultiService.DICT );
|
||||||
m_launchedForMissing = true;
|
self.m_launchedForMissing = true;
|
||||||
DwnldDelegate
|
DwnldDelegate
|
||||||
.downloadDictInBack( m_activity, lang,
|
.downloadDictInBack( self.m_activity, lang, name, self );
|
||||||
name, DictsDelegate.this );
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
lstnr2 = new OnClickListener() {
|
lstnr2 = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
finish();
|
curThis().finish();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1085,6 +1087,12 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
return canHandle;
|
return canHandle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected DictsDelegate curThis()
|
||||||
|
{
|
||||||
|
return (DictsDelegate)super.curThis();
|
||||||
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// XWListItem.ExpandedListener interface
|
// XWListItem.ExpandedListener interface
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -182,8 +182,9 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
public void
|
public void
|
||||||
onClick( DialogInterface dlg,
|
onClick( DialogInterface dlg,
|
||||||
int button ) {
|
int button ) {
|
||||||
getPlayerSettings( dlg );
|
GameConfigDelegate self = curThis();
|
||||||
loadPlayersList();
|
self.getPlayerSettings( dlg );
|
||||||
|
self.loadPlayersList();
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.setNegativeButton( android.R.string.cancel, null )
|
.setNegativeButton( android.R.string.cancel, null )
|
||||||
|
@ -211,7 +212,7 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
dlpos = new DialogInterface.OnClickListener() {
|
dlpos = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
loadPlayersList();
|
curThis().loadPlayersList();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
dialog = makeAlertBuilder()
|
dialog = makeAlertBuilder()
|
||||||
|
@ -224,9 +225,10 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
@Override
|
@Override
|
||||||
public void onDismiss( DialogInterface di )
|
public void onDismiss( DialogInterface di )
|
||||||
{
|
{
|
||||||
if ( m_gi.forceRemoteConsistent() ) {
|
GameConfigDelegate self = curThis();
|
||||||
showToast( R.string.forced_consistent );
|
if ( self.m_gi.forceRemoteConsistent() ) {
|
||||||
loadPlayersList();
|
self.showToast( R.string.forced_consistent );
|
||||||
|
self.loadPlayersList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -237,9 +239,10 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
dlpos = new DialogInterface.OnClickListener() {
|
dlpos = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
applyChanges( true );
|
GameConfigDelegate self = curThis();
|
||||||
|
self.applyChanges( true );
|
||||||
if ( DlgID.CONFIRM_CHANGE_PLAY == dlgID ) {
|
if ( DlgID.CONFIRM_CHANGE_PLAY == dlgID ) {
|
||||||
launchGame();
|
self.launchGame();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -251,7 +254,7 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
dlpos = new DialogInterface.OnClickListener() {
|
dlpos = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int whichButton ) {
|
int whichButton ) {
|
||||||
launchGame();
|
curThis().launchGame();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
|
@ -263,7 +266,7 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
dialog.setOnDismissListener( new DialogInterface.
|
dialog.setOnDismissListener( new DialogInterface.
|
||||||
OnDismissListener() {
|
OnDismissListener() {
|
||||||
public void onDismiss( DialogInterface di ) {
|
public void onDismiss( DialogInterface di ) {
|
||||||
finish();
|
curThis().finish();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
|
@ -289,16 +292,17 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
final DialogInterface.OnClickListener lstnr =
|
final DialogInterface.OnClickListener lstnr =
|
||||||
new DialogInterface.OnClickListener() {
|
new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int button ) {
|
public void onClick( DialogInterface dlg, int button ) {
|
||||||
m_conTypes = items.getTypes();
|
GameConfigDelegate self = curThis();
|
||||||
|
self.m_conTypes = items.getTypes();
|
||||||
if ( cb.isChecked()) {
|
if ( cb.isChecked()) {
|
||||||
XWPrefs.setAddrTypes( m_activity, m_conTypes );
|
XWPrefs.setAddrTypes( self.m_activity, self.m_conTypes );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_car.populate( m_activity, m_conTypes );
|
self.m_car.populate( self.m_activity, self.m_conTypes );
|
||||||
|
|
||||||
setConnLabel();
|
self.setConnLabel();
|
||||||
setupRelayStuffIf( false );
|
self.setupRelayStuffIf( false );
|
||||||
showHideRelayStuff();
|
self.showHideRelayStuff();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -794,6 +798,12 @@ public class GameConfigDelegate extends DelegateBase
|
||||||
return consumed;
|
return consumed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected GameConfigDelegate curThis()
|
||||||
|
{
|
||||||
|
return (GameConfigDelegate)super.curThis();
|
||||||
|
}
|
||||||
|
|
||||||
private void deleteGame()
|
private void deleteGame()
|
||||||
{
|
{
|
||||||
GameUtils.deleteGame( m_activity, m_rowid, false );
|
GameUtils.deleteGame( m_activity, m_rowid, false );
|
||||||
|
|
|
@ -620,18 +620,20 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
case WARN_NODICT_SUBST:
|
case WARN_NODICT_SUBST:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
|
GamesListDelegate self = curThis();
|
||||||
// no name, so user must pick
|
// no name, so user must pick
|
||||||
if ( null == m_missingDictName ) {
|
if ( null == m_missingDictName ) {
|
||||||
DictsDelegate.downloadForResult( m_activity,
|
DictsDelegate
|
||||||
RequestCode
|
.downloadForResult( self.m_activity,
|
||||||
.REQUEST_LANG_GL,
|
RequestCode
|
||||||
m_missingDictLang );
|
.REQUEST_LANG_GL,
|
||||||
|
self.m_missingDictLang );
|
||||||
} else {
|
} else {
|
||||||
DwnldDelegate
|
DwnldDelegate
|
||||||
.downloadDictInBack( m_activity,
|
.downloadDictInBack( self.m_activity,
|
||||||
m_missingDictLang,
|
self.m_missingDictLang,
|
||||||
m_missingDictName,
|
self.m_missingDictName,
|
||||||
GamesListDelegate.this );
|
self );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -660,7 +662,7 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
if ( DlgID.WARN_NODICT_SUBST == dlgID ) {
|
if ( DlgID.WARN_NODICT_SUBST == dlgID ) {
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
showDialog( DlgID.SHOW_SUBST );
|
curThis().showDialog( DlgID.SHOW_SUBST );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ab.setNeutralButton( R.string.button_substdict, lstnr );
|
ab.setNeutralButton( R.string.button_substdict, lstnr );
|
||||||
|
@ -674,15 +676,16 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg,
|
public void onClick( DialogInterface dlg,
|
||||||
int which ) {
|
int which ) {
|
||||||
|
GamesListDelegate self = curThis();
|
||||||
int pos = ((AlertDialog)dlg).getListView().
|
int pos = ((AlertDialog)dlg).getListView().
|
||||||
getCheckedItemPosition();
|
getCheckedItemPosition();
|
||||||
String dict = m_sameLangDicts[pos];
|
String dict = self.m_sameLangDicts[pos];
|
||||||
dict = DictLangCache.stripCount( dict );
|
dict = DictLangCache.stripCount( dict );
|
||||||
if ( GameUtils.replaceDicts( m_activity,
|
if ( GameUtils.replaceDicts( self.m_activity,
|
||||||
m_missingDictRowId,
|
self.m_missingDictRowId,
|
||||||
m_missingDictName,
|
self.m_missingDictName,
|
||||||
dict ) ) {
|
dict ) ) {
|
||||||
launchGameIf();
|
self.launchGameIf();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -702,10 +705,11 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
case RENAME_GAME:
|
case RENAME_GAME:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
String name = m_namer.getName();
|
GamesListDelegate self = curThis();
|
||||||
DBUtils.setName( m_activity, m_rowid,
|
String name = self.m_namer.getName();
|
||||||
|
DBUtils.setName( self.m_activity, self.m_rowid,
|
||||||
name );
|
name );
|
||||||
m_adapter.invalName( m_rowid );
|
self.m_adapter.invalName( self.m_rowid );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
GameSummary summary = DBUtils.getSummary( m_activity, m_rowid );
|
GameSummary summary = DBUtils.getSummary( m_activity, m_rowid );
|
||||||
|
@ -719,11 +723,12 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
case RENAME_GROUP:
|
case RENAME_GROUP:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
String name = m_namer.getName();
|
GamesListDelegate self = curThis();
|
||||||
DBUtils.setGroupName( m_activity,
|
String name = self.m_namer.getName();
|
||||||
m_groupid, name );
|
DBUtils.setGroupName( self.m_activity,
|
||||||
reloadGame( m_rowid );
|
self.m_groupid, name );
|
||||||
mkListAdapter();
|
self.reloadGame( self.m_rowid );
|
||||||
|
self.mkListAdapter();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
dialog = buildNamerDlg( m_adapter.groupName( m_groupid ),
|
dialog = buildNamerDlg( m_adapter.groupName( m_groupid ),
|
||||||
|
@ -735,15 +740,16 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
case NEW_GROUP:
|
case NEW_GROUP:
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
String name = m_namer.getName();
|
GamesListDelegate self = curThis();
|
||||||
DBUtils.addGroup( m_activity, name );
|
String name = self.m_namer.getName();
|
||||||
mkListAdapter();
|
DBUtils.addGroup( self.m_activity, name );
|
||||||
showNewGroupIf();
|
self.mkListAdapter();
|
||||||
|
self.showNewGroupIf();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
lstnr2 = new OnClickListener() {
|
lstnr2 = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
showNewGroupIf();
|
curThis().showNewGroupIf();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
dialog = buildNamerDlg( "", R.string.newgroup_label,
|
dialog = buildNamerDlg( "", R.string.newgroup_label,
|
||||||
|
@ -758,13 +764,14 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
final int[] selItem = {-1}; // hack!!!!
|
final int[] selItem = {-1}; // hack!!!!
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlgi, int item ) {
|
public void onClick( DialogInterface dlgi, int item ) {
|
||||||
|
GamesListDelegate self = curThis();
|
||||||
selItem[0] = item;
|
selItem[0] = item;
|
||||||
AlertDialog dlg = (AlertDialog)dlgi;
|
AlertDialog dlg = (AlertDialog)dlgi;
|
||||||
Button btn =
|
Button btn =
|
||||||
dlg.getButton( AlertDialog.BUTTON_POSITIVE );
|
dlg.getButton( AlertDialog.BUTTON_POSITIVE );
|
||||||
boolean enabled = startGroup == -1;
|
boolean enabled = startGroup == -1;
|
||||||
if ( !enabled ) {
|
if ( !enabled ) {
|
||||||
long newGroup = m_adapter.getGroupIDFor( item );
|
long newGroup = self.m_adapter.getGroupIDFor( item );
|
||||||
enabled = newGroup != startGroup;
|
enabled = newGroup != startGroup;
|
||||||
}
|
}
|
||||||
btn.setEnabled( enabled );
|
btn.setEnabled( enabled );
|
||||||
|
@ -772,20 +779,22 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
};
|
};
|
||||||
lstnr2 = new OnClickListener() {
|
lstnr2 = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
|
GamesListDelegate self = curThis();
|
||||||
Assert.assertTrue( -1 != selItem[0] );
|
Assert.assertTrue( -1 != selItem[0] );
|
||||||
long gid = m_adapter.getGroupIDFor( selItem[0] );
|
long gid = self.m_adapter.getGroupIDFor( selItem[0] );
|
||||||
for ( long rowid : m_rowids ) {
|
for ( long rowid : self.m_rowids ) {
|
||||||
DBUtils.moveGame( m_activity, rowid, gid );
|
DBUtils.moveGame( self.m_activity, rowid, gid );
|
||||||
}
|
}
|
||||||
DBUtils.setGroupExpanded( m_activity, gid, true );
|
DBUtils.setGroupExpanded( self.m_activity, gid, true );
|
||||||
mkListAdapter();
|
self.mkListAdapter();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
OnClickListener lstnr3 =
|
OnClickListener lstnr3 =
|
||||||
new OnClickListener() {
|
new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
m_moveAfterNewGroup = true;
|
GamesListDelegate self = curThis();
|
||||||
showDialog( DlgID.NEW_GROUP );
|
self.m_moveAfterNewGroup = true;
|
||||||
|
self.showDialog( DlgID.NEW_GROUP );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
String[] groups = m_adapter.groupNames();
|
String[] groups = m_adapter.groupNames();
|
||||||
|
@ -833,12 +842,12 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
final EditText edit = (EditText)view.findViewById( R.id.edit );
|
final EditText edit = (EditText)view.findViewById( R.id.edit );
|
||||||
lstnr = new OnClickListener() {
|
lstnr = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
makeThenLaunchOrConfigure( edit, true, false );
|
curThis().makeThenLaunchOrConfigure( edit, true, false );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
lstnr2 = new OnClickListener() {
|
lstnr2 = new OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
makeThenLaunchOrConfigure( edit, false, false );
|
curThis().makeThenLaunchOrConfigure( edit, false, false );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -862,7 +871,7 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
EditText edit = (EditText)((Dialog)dlg)
|
EditText edit = (EditText)((Dialog)dlg)
|
||||||
.findViewById( R.id.edit );
|
.findViewById( R.id.edit );
|
||||||
startRematchWithName( edit );
|
curThis().startRematchWithName( edit );
|
||||||
}
|
}
|
||||||
} )
|
} )
|
||||||
.create();
|
.create();
|
||||||
|
@ -1050,6 +1059,12 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected GamesListDelegate curThis()
|
||||||
|
{
|
||||||
|
return (GamesListDelegate)super.curThis();
|
||||||
|
}
|
||||||
|
|
||||||
// OnItemLongClickListener interface
|
// OnItemLongClickListener interface
|
||||||
public boolean onItemLongClick( AdapterView<?> parent, View view,
|
public boolean onItemLongClick( AdapterView<?> parent, View view,
|
||||||
int position, long id ) {
|
int position, long id ) {
|
||||||
|
@ -1813,7 +1828,7 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
final boolean solo = isSolos[ii];
|
final boolean solo = isSolos[ii];
|
||||||
button.setOnClickListener( new View.OnClickListener() {
|
button.setOnClickListener( new View.OnClickListener() {
|
||||||
public void onClick( View view ) {
|
public void onClick( View view ) {
|
||||||
handleNewGameButton( solo );
|
curThis().handleNewGameButton( solo );
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,7 +82,8 @@ public class PrefsDelegate extends DelegateBase
|
||||||
confirmID = R.string.confirm_revert_colors;
|
confirmID = R.string.confirm_revert_colors;
|
||||||
lstnr = new DialogInterface.OnClickListener() {
|
lstnr = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
SharedPreferences sp = getSharedPreferences();
|
PrefsDelegate self = (PrefsDelegate)curThis();
|
||||||
|
SharedPreferences sp = self.getSharedPreferences();
|
||||||
SharedPreferences.Editor editor = sp.edit();
|
SharedPreferences.Editor editor = sp.edit();
|
||||||
int[] colorKeys = {
|
int[] colorKeys = {
|
||||||
R.string.key_player0,
|
R.string.key_player0,
|
||||||
|
@ -103,7 +104,7 @@ public class PrefsDelegate extends DelegateBase
|
||||||
editor.remove( getString(colorKey) );
|
editor.remove( getString(colorKey) );
|
||||||
}
|
}
|
||||||
editor.commit();
|
editor.commit();
|
||||||
relaunch();
|
self.relaunch();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
break;
|
break;
|
||||||
|
@ -111,11 +112,12 @@ public class PrefsDelegate extends DelegateBase
|
||||||
confirmID = R.string.confirm_revert_all;
|
confirmID = R.string.confirm_revert_all;
|
||||||
lstnr = new DialogInterface.OnClickListener() {
|
lstnr = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
SharedPreferences sp = getSharedPreferences();
|
PrefsDelegate self = (PrefsDelegate)curThis();
|
||||||
|
SharedPreferences sp = self.getSharedPreferences();
|
||||||
SharedPreferences.Editor editor = sp.edit();
|
SharedPreferences.Editor editor = sp.edit();
|
||||||
editor.clear();
|
editor.clear();
|
||||||
editor.commit();
|
editor.commit();
|
||||||
relaunch();
|
self.relaunch();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
break;
|
break;
|
||||||
|
@ -149,13 +151,13 @@ public class PrefsDelegate extends DelegateBase
|
||||||
Button button = (Button)findViewById( R.id.revert_colors );
|
Button button = (Button)findViewById( R.id.revert_colors );
|
||||||
button.setOnClickListener( new View.OnClickListener() {
|
button.setOnClickListener( new View.OnClickListener() {
|
||||||
public void onClick( View v ) {
|
public void onClick( View v ) {
|
||||||
showDialog( DlgID.REVERT_COLORS );
|
curThis().showDialog( DlgID.REVERT_COLORS );
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
button = (Button)findViewById( R.id.revert_all );
|
button = (Button)findViewById( R.id.revert_all );
|
||||||
button.setOnClickListener(new View.OnClickListener() {
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
public void onClick( View v ) {
|
public void onClick( View v ) {
|
||||||
showDialog( DlgID.REVERT_ALL );
|
curThis().showDialog( DlgID.REVERT_ALL );
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
|
|
@ -147,13 +147,14 @@ public class SMSInviteDelegate extends InviteDelegate {
|
||||||
namerView.setKeyListener(DialerKeyListener.getInstance());
|
namerView.setKeyListener(DialerKeyListener.getInstance());
|
||||||
lstnr = new DialogInterface.OnClickListener() {
|
lstnr = new DialogInterface.OnClickListener() {
|
||||||
public void onClick( DialogInterface dlg, int item ) {
|
public void onClick( DialogInterface dlg, int item ) {
|
||||||
|
SMSInviteDelegate self = (SMSInviteDelegate)curThis();
|
||||||
String number = namerView.getName();
|
String number = namerView.getName();
|
||||||
PhoneRec rec = new PhoneRec( number );
|
PhoneRec rec = new PhoneRec( number );
|
||||||
m_pendingNumber = number;
|
self.m_pendingNumber = number;
|
||||||
m_pendingName = null;
|
self.m_pendingName = null;
|
||||||
showConfirmThen( R.string.warn_unlimited,
|
self.showConfirmThen( R.string.warn_unlimited,
|
||||||
R.string.button_yes,
|
R.string.button_yes,
|
||||||
Action.POST_WARNING_ACTION );
|
Action.POST_WARNING_ACTION );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
dialog = makeAlertBuilder()
|
dialog = makeAlertBuilder()
|
||||||
|
|
Loading…
Reference in a new issue