split DlgDelegate interface in three

replace dlgButtonClicked() with separate methods for positive and
negative buttons and alert dismissal. I was making too many mistakes
because the old method was getting called twice (e.g. for negative and
then dismissal) and I hadn't needed to differentiate until adding that
new Action. There should be no behavior change with this, but it's
pervasive and replaces some spaghetti.
This commit is contained in:
Eric House 2017-01-06 07:07:17 -08:00
parent dc7ed9bfb2
commit 86e7142687
15 changed files with 473 additions and 475 deletions

View file

@ -168,16 +168,14 @@ public class BTInviteDelegate extends InviteDelegate {
// DlgDelegate.DlgClickNotify interface
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
switch( action ) {
case OPEN_BT_PREFS_ACTION:
if ( AlertDialog.BUTTON_POSITIVE == which ) {
BTService.openBTSettings( m_activity );
}
break;
default:
super.dlgButtonClicked( action, which, params );
super.onPosButton( action, params );
}
}
}

View file

@ -909,7 +909,7 @@ public class BoardDelegate extends DelegateBase
Action.COMMIT_ACTION )
.show();
} else {
dlgButtonClicked( Action.COMMIT_ACTION, AlertDialog.BUTTON_POSITIVE, null );
onPosButton( Action.COMMIT_ACTION, null );
}
break;
@ -1026,36 +1026,21 @@ public class BoardDelegate extends DelegateBase
//////////////////////////////////////////////////
// DlgDelegate.DlgClickNotify interface
//////////////////////////////////////////////////
@Override
public void dlgButtonClicked( Action action, int which,
final Object[] params )
{
boolean handled = false;
boolean positive = AlertDialog.BUTTON_POSITIVE == which;
DbgUtils.logd( TAG, "BoardDelegate.dlgButtonClicked(%s, %b)",
action.toString(), positive );
if ( Action.ENABLE_RELAY_DO_OR == action ) {
handled = true;
if ( positive ) {
@Override
public void onPosButton( Action action, final Object[] params )
{
JNICmd cmd = JNICmd.CMD_NONE;
switch ( action ) {
case ENABLE_RELAY_DO_OR:
RelayService.setEnabled( m_activity, true );
} else if ( AlertDialog.BUTTON_NEGATIVE == which ) {
m_dropOnDismiss = true;
} else if ( DlgDelegate.DISMISS_BUTTON == which && m_dropOnDismiss ) {
postDelayed( new Runnable() {
public void run() {
askDropRelay();
}
}, 10 );
}
} else if ( Action.RETRY_PHONE_STATE_ACTION == action ) {
break;
case RETRY_PHONE_STATE_ACTION:
Action stateAction = (Action)params[0];
DBUtils.SentInvitesInfo info = (DBUtils.SentInvitesInfo)params[1];
callInviteChoices( stateAction, info, false );
} else if ( positive ) {
handled = true;
JNICmd cmd = JNICmd.CMD_NONE;
switch ( action ) {
break;
case UNDO_LAST_ACTION:
cmd = JNICmd.CMD_UNDO_LAST;
break;
@ -1126,17 +1111,14 @@ public class BoardDelegate extends DelegateBase
break;
case ENABLE_SMS_DO:
handled = false; // so super gets called, before
// retrySMSInvites
post( new Runnable() {
public void run() {
retrySMSInvites( params );
}
} );
break;
// FALLTHRU: so super gets called, before
default:
handled = false;
super.onPosButton( action, params );
}
if ( JNICmd.CMD_NONE != cmd ) {
@ -1144,10 +1126,33 @@ public class BoardDelegate extends DelegateBase
}
}
if ( !handled ) {
super.dlgButtonClicked( action, which, params );
@Override
public void onNegButton( Action action, Object[] params )
{
switch ( action ) {
case ENABLE_RELAY_DO_OR:
m_dropOnDismiss = true;
break;
default:
super.onNegButton( action, params );
}
}
@Override
public void onDismissed( Action action, Object[] params )
{
switch ( action ) {
case ENABLE_RELAY_DO_OR:
if ( m_dropOnDismiss ) {
postDelayed( new Runnable() {
public void run() {
askDropRelay();
}
}, 10 );
}
break;
}
}
} // dlgButtonClicked
public void inviteChoiceMade( Action action, InviteMeans means,
Object[] params )
@ -1628,8 +1633,7 @@ public class BoardDelegate extends DelegateBase
DbgUtils.logi( TAG, "handleConndMessage(): toastStr: %s", toastStr );
m_toastStr = toastStr;
if ( naMsg == 0 ) {
dlgButtonClicked( Action.SHOW_EXPL_ACTION,
AlertDialog.BUTTON_POSITIVE, null );
onPosButton( Action.SHOW_EXPL_ACTION, null );
} else {
makeNotAgainBuilder( naMsg, naKey, Action.SHOW_EXPL_ACTION )
.show();

View file

@ -226,19 +226,17 @@ public class ChatDelegate extends DelegateBase {
}
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
switch ( action ) {
case CLEAR_ACTION:
if ( AlertDialog.BUTTON_POSITIVE == which ) {
DBUtils.clearChatHistory( m_activity, m_rowid );
TableLayout layout =
(TableLayout)findViewById( R.id.chat_history );
layout.removeAllViews();
}
break;
default:
super.dlgButtonClicked( action, which, params );
super.onPosButton( action, params );
}
}

View file

@ -636,17 +636,13 @@ public class DelegateBase implements DlgClickNotify,
//////////////////////////////////////////////////////////////////////
// DlgDelegate.DlgClickNotify interface
//////////////////////////////////////////////////////////////////////
public void dlgButtonClicked( Action action, int button, Object[] params )
public void onPosButton( Action action, Object[] params )
{
boolean handled = false;
if ( Action.PERMS_QUERY == action ) {
Perms23.onGotPermsAction( button, params );
handled = true;
} else if ( AlertDialog.BUTTON_POSITIVE == button ) {
DbgUtils.logd( TAG, "%s.posButtonClicked(%s)", getClass().getSimpleName(),
action.toString() );
switch( action ) {
case ENABLE_SMS_ASK:
showSMSEnableDialog( Action.ENABLE_SMS_DO, params );
handled = true;
break;
case ENABLE_SMS_DO:
XWPrefs.setSMSEnabled( m_activity, true );
@ -656,7 +652,9 @@ public class DelegateBase implements DlgClickNotify,
break;
case ENABLE_RELAY_DO:
RelayService.setEnabled( m_activity, true );
handled = true;
break;
case PERMS_QUERY:
Perms23.onGotPermsAction( true, params );
break;
default:
DbgUtils.logd( TAG, "unhandled action %s", action.toString() );
@ -665,28 +663,24 @@ public class DelegateBase implements DlgClickNotify,
}
}
if ( !handled && BuildConfig.DEBUG ) {
String buttonName = null;
switch( button ) {
case AlertDialog.BUTTON_POSITIVE:
buttonName = "positive";
break;
case AlertDialog.BUTTON_NEGATIVE:
buttonName = "negative";
break;
case AlertDialog.BUTTON_NEUTRAL:
buttonName = "neutral";
break;
case DlgDelegate.DISMISS_BUTTON:
buttonName = "dismiss";
public void onNegButton( Action action, Object[] params )
{
// DbgUtils.logd( TAG, "%s.negButtonClicked(%s)", getClass().getSimpleName(),
// action.toString() );
switch ( action ) {
case PERMS_QUERY:
Perms23.onGotPermsAction( false, params );
break;
default:
Assert.fail();
DbgUtils.logd( TAG, "onNegButton: unhandled action %s", action.toString() );
break;
}
DbgUtils.logi( TAG, "dlgButtonClicked(action=%s button=%s): UNHANDLED",
action.toString(), buttonName );
}
public void onDismissed( Action action, Object[] params )
{
DbgUtils.logd( TAG, "%s.dlgDismissed(%s)", getClass().getSimpleName(),
action.toString() );
}
public void inviteChoiceMade( Action action, DlgClickNotify.InviteMeans means, Object[] params )

View file

@ -300,9 +300,9 @@ public class DictBrowseDelegate extends DelegateBase
// DlgDelegate.DlgClickNotify interface
//////////////////////////////////////////////////
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
Assert.assertTrue( Action.FINISH_ACTION == action );
Assert.assertTrue( !BuildConfig.DEBUG || Action.FINISH_ACTION==action );
finish();
}

View file

@ -901,13 +901,11 @@ public class DictsDelegate extends ListDelegateBase
//////////////////////////////////////////////////////////////////////
// DlgDelegate.DlgClickNotify interface
//////////////////////////////////////////////////////////////////////
public void dlgButtonClicked( Action action, int which, Object[] params )
@Override
public void onPosButton( Action action, Object[] params )
{
DbgUtils.logd( TAG, "dlgButtonClicked(%s)", action.toString() );
boolean positive = DialogInterface.BUTTON_POSITIVE == which;
switch( action ) {
case DELETE_DICT_ACTION:
if ( positive ) {
XWListItem[] items = (XWListItem[])params[0];
for ( XWListItem item : items ) {
String name = item.getText();
@ -916,10 +914,8 @@ public class DictsDelegate extends ListDelegateBase
}
clearSelections();
mkListAdapter();
}
break;
case UPDATE_DICTS_ACTION:
if ( positive ) {
Uri[] uris = new Uri[m_needUpdates.size()];
String[] names = new String[uris.length];
int count = 0;
@ -931,20 +927,15 @@ public class DictsDelegate extends ListDelegateBase
++count;
}
DwnldDelegate.downloadDictsInBack( m_activity, uris, names, this );
}
break;
case MOVE_CONFIRMED:
if ( positive ) {
moveDictsWithPermission( params );
}
break;
case STORAGE_CONFIRMED:
if ( positive ) {
mkListAdapter();
}
break;
default:
super.dlgButtonClicked( action, which, params );
super.onPosButton( action, params );
}
}

View file

@ -308,7 +308,10 @@ public class DlgDelegate {
public static enum InviteMeans {
SMS, EMAIL, NFC, BLUETOOTH, CLIPBOARD, RELAY, WIFIDIRECT,
};
void dlgButtonClicked( Action action, int button, Object[] params );
void onPosButton( Action action, Object[] params );
void onNegButton( Action action, Object[] params );
void onDismissed( Action action, Object[] params );
void inviteChoiceMade( Action action, InviteMeans means, Object[] params );
}
public interface HasDlgDelegate {
@ -446,7 +449,7 @@ public class DlgDelegate {
}
// Puts up alert asking to choose a reason to enable SMS, and on dismiss
// calls dlgButtonClicked with the action and in params a Boolean
// calls onPosButton/onNegButton with the action and in params a Boolean
// indicating whether enabling is now ok.
public void showSMSEnableDialog( Action action, Object... params )
{
@ -468,9 +471,7 @@ public class DlgDelegate {
post( new Runnable() {
public void run() {
m_clickCallback
.dlgButtonClicked( action,
AlertDialog.BUTTON_POSITIVE,
params );
.onPosButton( action, params );
}
});
}
@ -702,10 +703,7 @@ public class DlgDelegate {
OnClickListener lstnr = new OnClickListener() {
public void onClick( DialogInterface dlg, int item ) {
checkNotAgainCheck( state, naView );
m_clickCallback.
dlgButtonClicked( more.action,
AlertDialog.BUTTON_POSITIVE,
more.params );
m_clickCallback.onPosButton( more.action, more.params );
}
};
builder.setNegativeButton( more.buttonStr, lstnr );
@ -866,9 +864,7 @@ public class DlgDelegate {
layout.findViewById( R.id.confirm_sms_reasons );
boolean enabled = 0 < reasons.getSelectedItemPosition();
Assert.assertTrue( enabled );
m_clickCallback.dlgButtonClicked( state.m_action,
AlertDialog.BUTTON_POSITIVE,
state.m_params );
m_clickCallback.onPosButton( state.m_action, state.m_params );
}
};
@ -917,9 +913,21 @@ public class DlgDelegate {
checkNotAgainCheck( state, naView );
if ( Action.SKIP_CALLBACK != state.m_action ) {
m_clickCallback.dlgButtonClicked( state.m_action,
button,
switch ( button ) {
case AlertDialog.BUTTON_POSITIVE:
m_clickCallback.onPosButton( state.m_action,
state.m_params );
break;
case AlertDialog.BUTTON_NEGATIVE:
m_clickCallback.onNegButton( state.m_action,
state.m_params );
break;
default:
DbgUtils.loge( TAG, "unexpected button %d",
button );
// ignore on release builds
Assert.assertFalse( BuildConfig.DEBUG );
}
}
}
};
@ -948,8 +956,7 @@ public class DlgDelegate {
public void onDismiss( DialogInterface di ) {
dropState( state );
if ( Action.SKIP_CALLBACK != state.m_action ) {
m_clickCallback.dlgButtonClicked( state.m_action,
DISMISS_BUTTON,
m_clickCallback.onDismissed( state.m_action,
state.m_params );
}
m_activity.removeDialog( id );

View file

@ -346,16 +346,26 @@ public class DwnldDelegate extends ListDelegateBase {
}
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
if ( Action.STORAGE_CONFIRMED == action ) {
if ( AlertDialog.BUTTON_POSITIVE == which ) {
switch ( action ) {
case STORAGE_CONFIRMED:
doWithPermissions( (Uri[])params[0] );
} else if ( AlertDialog.BUTTON_NEGATIVE == which ) {
finish();
break;
default:
super.onPosButton( action, params );
}
} else {
super.dlgButtonClicked( action, which, params );
}
@Override
public void onNegButton( Action action, Object[] params )
{
switch ( action ) {
case STORAGE_CONFIRMED:
finish();
break;
default:
super.onPosButton( action, params );
}
}

View file

@ -684,12 +684,9 @@ public class GameConfigDelegate extends DelegateBase
}
@Override
public void dlgButtonClicked( Action action, int button, Object[] params )
public void onPosButton( Action action, Object[] params )
{
boolean callSuper = false;
Assert.assertTrue( curThis() == this );
if ( AlertDialog.BUTTON_POSITIVE == button ) {
switch( action ) {
case LOCKED_CHANGE_ACTION:
handleLockedChange();
@ -709,24 +706,21 @@ public class GameConfigDelegate extends DelegateBase
setupRelayStuffIf( true );
break;
default:
callSuper = true;
super.onPosButton( action, params );
}
} else if ( AlertDialog.BUTTON_NEGATIVE == button ) {
}
@Override
public void onNegButton( Action action, Object[] params )
{
switch ( action ) {
case DELETE_AND_EXIT:
showDialog( DlgID.CHANGE_CONN );
break;
default:
callSuper = true;
super.onNegButton( action, params );
break;
}
} else {
callSuper = true;
}
if ( callSuper ) {
super.dlgButtonClicked( action, button, params );
}
}
public void onClick( View view )

View file

@ -1234,9 +1234,9 @@ public class GamesListDelegate extends ListDelegateBase
}
// DlgDelegate.DlgClickNotify interface
public void dlgButtonClicked( Action action, int which, Object[] params )
@Override
public void onPosButton( Action action, Object[] params )
{
if ( AlertDialog.BUTTON_POSITIVE == which ) {
switch( action ) {
case NEW_NET_GAME:
m_netLaunchInfo = (NetLaunchInfo)params[0];
@ -1333,17 +1333,26 @@ public class GamesListDelegate extends ListDelegateBase
default:
Assert.fail();
}
} else if ( AlertDialog.BUTTON_NEGATIVE == which ) {
}
@Override
public void onNegButton( Action action, Object[] params )
{
if ( Action.NEW_GAME_DFLT_NAME == action ) {
m_newGameParams = params;
makeThenLaunchOrConfigure();
}
} else if ( DlgDelegate.DISMISS_BUTTON == which ) {
}
@Override
public void onDismissed( Action action, Object[] params )
{
switch( action ) {
case ENABLE_DUALPANE_EXIT:
setDualpaneAndFinish( true );
break;
}
default:
super.onDismissed( action, params );
}
}

View file

@ -178,30 +178,25 @@ public class Perms23 {
}
builder.asyncQuery( m_delegate.getActivity(), new PermCbck() {
public void onPermissionResult( Map<Perm, Boolean> perms ) {
int button = perms.get( m_perm )
? AlertDialog.BUTTON_POSITIVE
: AlertDialog.BUTTON_NEGATIVE;
// DbgUtils.logd( TAG, "doIt() calling dlgButtonClicked(%s)",
// m_action.toString() );
m_cbck.dlgButtonClicked( m_action, button, m_params );
if ( perms.get( m_perm ) ) {
m_cbck.onPosButton( m_action, m_params );
} else {
m_cbck.onNegButton( m_action, m_params );
}
}
} );
}
// Post this in case we're called from inside dialog dismiss
// code. Better to unwind the stack...
private void handleButton( final int button )
private void handleButton( final boolean positive )
{
m_delegate.post( new Runnable() {
public void run() {
if ( AlertDialog.BUTTON_POSITIVE == button ) {
if ( positive ) {
doIt( false );
} else if ( AlertDialog.BUTTON_NEGATIVE == button ) {
// DbgUtils.logd( TAG, "handleButton calling dlgButtonClicked(%s)",
// m_action.toString() );
m_cbck.dlgButtonClicked( m_action,
AlertDialog.BUTTON_NEGATIVE,
m_params );
} else {
m_cbck.onNegButton( m_action, m_params );
}
}
} );
@ -221,11 +216,11 @@ public class Perms23 {
.doIt( true );
}
public static void onGotPermsAction( int button, Object[] params )
public static void onGotPermsAction( boolean positive, Object[] params )
{
// DbgUtils.logd( TAG, "onGotPermsAction(button=%d)", button );
QueryInfo info = (QueryInfo)params[0];
info.handleButton( button );
info.handleButton( positive );
}
private static Map<Integer, PermCbck> s_map = new HashMap<Integer, PermCbck>();

View file

@ -242,10 +242,8 @@ public class PrefsDelegate extends DelegateBase
}
@Override
public void dlgButtonClicked( Action action, int button, Object[] params )
public void onPosButton( Action action, Object[] params )
{
boolean handled = AlertDialog.BUTTON_POSITIVE == button;
if ( handled ) {
switch ( action ) {
case ENABLE_SMS_DO:
XWPrefs.setSMSEnabled( m_activity, true );
@ -256,12 +254,7 @@ public class PrefsDelegate extends DelegateBase
RelayCheckBoxPreference.setChecked();
break;
default:
handled = false;
}
}
if ( !handled ) {
super.dlgButtonClicked( action, button, params );
super.onPosButton( action, params );
}
}

View file

@ -278,10 +278,8 @@ public class RelayInviteDelegate extends InviteDelegate {
// DlgDelegate.DlgClickNotify interface
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
switch( which ) {
case AlertDialog.BUTTON_POSITIVE:
switch( action ) {
case CLEAR_ACTION:
clearSelectedImpl();
@ -289,17 +287,21 @@ public class RelayInviteDelegate extends InviteDelegate {
case USE_IMMOBILE_ACTION:
m_immobileConfirmed = true;
break;
}
default:
super.onPosButton( action, params );
break;
case DlgDelegate.DISMISS_BUTTON:
}
}
@Override
public void onDismissed( Action action, Object[] params )
{
if ( Action.USE_IMMOBILE_ACTION == action && m_immobileConfirmed ) {
makeConfirmThenBuilder( R.string.warn_unlimited,
Action.POST_WARNING_ACTION )
.setPosButton( R.string.button_yes )
.show();
}
break;
}
}
// private int countChecks()

View file

@ -187,34 +187,37 @@ public class SMSInviteDelegate extends InviteDelegate {
// DlgDelegate.DlgClickNotify interface
@Override
public void dlgButtonClicked( Action action, int which,
final Object[] params )
public void onPosButton( Action action, Object[] params )
{
boolean isPositive = AlertDialog.BUTTON_POSITIVE == which;
switch ( action ) {
case RETRY_CONTACTS_ACTION:
askContactsPermission( false );
break;
case CLEAR_ACTION:
if ( isPositive) {
clearSelectedImpl();
}
break;
case USE_IMMOBILE_ACTION:
m_immobileConfirmed = true;
break;
case POST_WARNING_ACTION:
if ( isPositive ) { // ???
PhoneRec rec = new PhoneRec( (String)params[1],
(String)params[0] );
m_phoneRecs.add( rec );
clearChecked();
onItemChecked( rec, true );
saveAndRebuild();
}
break;
default:
super.onPosButton( action, params );
}
}
@Override
public void onNegButton( Action action, final Object[] params )
{
switch ( action ) {
case USE_IMMOBILE_ACTION:
if ( isPositive ) {
m_immobileConfirmed = true;
} else if ( m_immobileConfirmed ) {
if ( m_immobileConfirmed ) {
// Putting up a new alert from inside another's handler
// confuses things. So post instead.
post( new Runnable() {
@ -229,6 +232,8 @@ public class SMSInviteDelegate extends InviteDelegate {
} );
}
break;
default:
super.onNegButton( action, params );
}
}

View file

@ -153,9 +153,8 @@ public class StudyListDelegate extends ListDelegateBase
// DlgDelegate.DlgClickNotify interface
//////////////////////////////////////////////////
@Override
public void dlgButtonClicked( Action action, int which, Object[] params )
public void onPosButton( Action action, Object[] params )
{
if ( AlertDialog.BUTTON_POSITIVE == which ) {
switch ( action ) {
case SL_CLEAR_ACTION:
String[] selWords = getSelWords();
@ -181,7 +180,6 @@ public class StudyListDelegate extends ListDelegateBase
break;
}
}
}
//////////////////////////////////////////////////
// AdapterView.OnItemSelectedListener interface