From b1ae563ae67c4ef6d379776ba45e3507636a2022 Mon Sep 17 00:00:00 2001 From: Eric House Date: Wed, 20 Nov 2013 06:54:51 -0800 Subject: [PATCH] fix NPE when installed with existing SMS invites in inbox --- xwords4/android/XWords4/res/values/strings.xml | 2 ++ .../src/org/eehouse/android/xw4/GameUtils.java | 18 +++++++----------- 2 files changed, 9 insertions(+), 11 deletions(-) diff --git a/xwords4/android/XWords4/res/values/strings.xml b/xwords4/android/XWords4/res/values/strings.xml index 1074cabd5..7900c63d6 100644 --- a/xwords4/android/XWords4/res/values/strings.xml +++ b/xwords4/android/XWords4/res/values/strings.xml @@ -2184,4 +2184,6 @@ This setting is ignored on devices like yours that depend on the \"Action bar\". + + Tap the receiving device now diff --git a/xwords4/android/XWords4/src/org/eehouse/android/xw4/GameUtils.java b/xwords4/android/XWords4/src/org/eehouse/android/xw4/GameUtils.java index b542ca4b9..2fbd4e466 100644 --- a/xwords4/android/XWords4/src/org/eehouse/android/xw4/GameUtils.java +++ b/xwords4/android/XWords4/src/org/eehouse/android/xw4/GameUtils.java @@ -411,7 +411,7 @@ public class GameUtils { { long rowid = -1; - Assert.assertNotNull( inviteID ); + Assert.assertNotNull( inviteID ); // firing CurGameInfo gi = new CurGameInfo( context, inviteID ); gi.setLang( lang[0], dict[0] ); lang[0] = gi.dictLang; @@ -513,8 +513,10 @@ public class GameUtils { if ( isHost ) { addr = new CommsAddrRec(CommsAddrRec.CommsConnType.COMMS_CONN_SMS); } + String inviteID = GameUtils.formatGameID( gameID ); return makeNewMultiGame( context, groupID, addr, langa, dicta, - nPlayersT, nPlayersH, null, gameID, isHost ); + nPlayersT, nPlayersH, inviteID, gameID, + isHost ); } public static void launchInviteActivity( Activity activity, int chosen, @@ -524,20 +526,14 @@ public class GameUtils { { Assert.assertNotNull( inviteID ); - String msgString; if ( DlgDelegate.NFC_BTN == chosen ) { - msgString = NetLaunchInfo.makeLaunchJSON( activity, room, inviteID, - lang, dict, nPlayers ); + Utils.showToast( activity, R.string.sms_ready_text ); } else { Uri gameUri = NetLaunchInfo.makeLaunchUri( activity, room, inviteID, lang, dict, nPlayers ); - msgString = null == gameUri ? null : gameUri.toString(); - } + String msgString = null == gameUri ? null : gameUri.toString(); - if ( null != msgString ) { - if ( DlgDelegate.NFC_BTN == chosen ) { - Utils.showToast( activity, "Tap the receiving device now" ); - } else { + if ( null != msgString ) { boolean choseEmail = DlgDelegate.EMAIL_BTN == chosen; int fmtId = choseEmail? R.string.invite_htmf : R.string.invite_txtf;